ElementParameterFilter
Description:
A filter used to match elements by one or more parameter filter rules.
A filter used to match elements by one or more parameter filter rules.
Remarks:
This filter is a slow filter. Slow filters require that the Element be obtained and expanded in memory first. Thus it is preferable to couple this filter with at least one ElementQuickFilter, which should minimize the number of Elements that are expanded.
This filter is a slow filter. Slow filters require that the Element be obtained and expanded in memory first. Thus it is preferable to couple this filter with at least one ElementQuickFilter, which should minimize the number of Elements that are expanded.
Inheritance Hierarchy:
System.Object
Autodesk.Revit.DB.ElementFilter
Autodesk.Revit.DB.ElementSlowFilter
Autodesk.Revit.DB.ElementParameterFilter
System.Object
Autodesk.Revit.DB.ElementFilter
Autodesk.Revit.DB.ElementSlowFilter
Autodesk.Revit.DB.ElementParameterFilter
public class ElementParameterFilter : ElementSlowFilter
// Creates an ElementParameter filter to find rooms whose area is
// greater than specified value
// Create filter by provider and evaluator
// provider
ParameterValueProvider pvp = new ParameterValueProvider(new ElementId(BuiltInParameter.ROOM_AREA));
// evaluator
FilterNumericRuleEvaluator fnrv = new FilterNumericGreater();
// rule value
double ruleValue = 100.0f; // filter room whose area is greater than 100 SF
// rule
FilterRule fRule = new FilterDoubleRule(pvp, fnrv, ruleValue, 1E-6);
// Create an ElementParameter filter
ElementParameterFilter filter = new ElementParameterFilter(fRule);
// Apply the filter to the elements in the active document
FilteredElementCollector collector = new FilteredElementCollector(document);
IList<Element> rooms = collector.WherePasses(filter).ToElements();
// Find rooms whose area is less than or equal to 100:
// Use inverted filter to match elements
ElementParameterFilter lessOrEqualFilter = new ElementParameterFilter(fRule, true);
collector = new FilteredElementCollector(document);
IList<Element> lessOrEqualFounds = collector.WherePasses(lessOrEqualFilter).ToElements();
| Name | Return Type | Description | Inherited From |
|---|---|---|---|
| ElementParameterFilter(FilterRule) | None | Constructs a new instance of an ElementParameterFilter from a single rule. | |
| ElementParameterFilter(FilterRule, Boolean) | None | Constructs a new instance of an ElementParameterFilter, with the option to match all elements not passing a given filter rule. | |
| ElementParameterFilter(IList<FilterRule>) | None | Constructs a new instance of an ElementParameterFilter from a set of rules. | |
| ElementParameterFilter(IList<FilterRule>, Boolean) | None | Constructs a new instance of an ElementParameterFilter, with the option to match all elements not passing the given filter rules. |
| Name | Return Type | Description | Inherited From |
|---|---|---|---|
| GetRules() | IList<FilterRule> | Returns the set of rules contained in this filter. | |
| Dispose() | None | Releases all resources used by the | ElementFilter |
| PassesFilter(Document, ElementId) | bool | Applies the filter to a given element. | ElementFilter |
| PassesFilter(Element) | bool | Applies the filter to a given element. | ElementFilter |
| Name | Return Type | Description | Inherited From |
|---|---|---|---|
| Inverted | bool | True if the results of the filter are inverted; elements that would normally be accepted by this filter will be rejected, and elements that would normally be rejected will be accepted. | ElementFilter |
| IsValidObject | bool | Specifies whether the .NET object represents a valid Revit entity. | ElementFilter |