2021 Class
Changes 0
C

ElementIntersectsSolidFilter

Description:
A filter to find elements that intersect the given solid geometry.
Remarks:

The input solid used for this filter can be obtained from an existing element, created from scratch using the routines in GeometryCreationUtilities or builder classes, or the generated from the result of a secondary operation such as a Boolean operation. Similar to the ElementIntersectsElementFilter, this filter will not detect as intersecting elements which lack solid geometry, such as Rebar.

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.ElementIntersectsFilter
        Autodesk.Revit.DB.ElementIntersectsSolidFilter
// Find intersections between family instances and a selected element
Reference reference = uidoc.Selection.PickObject(ObjectType.Element, "Select element that will be checked for intersection with all family instances");
Element element = doc.GetElement(reference);
GeometryElement geomElement = element.get_Geometry(new Options());
Solid solid = null;
foreach (GeometryObject geomObj in geomElement)
{
    solid = geomObj as Solid;
    if (solid != null) break;
}

FilteredElementCollector collector = new FilteredElementCollector(doc);
collector.OfClass(typeof(FamilyInstance));
collector.WherePasses(new ElementIntersectsSolidFilter(solid)); // Apply intersection filter to find matches

TaskDialog.Show("Revit", collector.Count() + " family instances intersect with the selected element (" + element.Category.Name + " id:" + element.Id.ToString() + ")");
Name Return Type Description Inherited From
C ElementIntersectsSolidFilter(Solid) None Constructs a filter to match elements which intersect the given element.
C ElementIntersectsSolidFilter(Solid, Boolean) None Constructs a filter to match elements which intersect the given element, with the option to match all elements not intersecting the given element.
Name Return Type Description Inherited From
M GetSolid() The solid geometry. Gets the target solid geometry.
M Dispose() None Releases all resources used by the ElementFilter
M PassesFilter(Document, ElementId) bool Applies the filter to a given element. ElementFilter
M PassesFilter(Element) bool Applies the filter to a given element. ElementFilter
M IsCategorySupported(Element) bool Identifies if the input element is of a category supported by element intersection filters. ElementIntersectsFilter
M IsElementSupported(Element) bool Identifies if the input element is supported by element intersection filters. ElementIntersectsFilter
Name Return Type Description Inherited From
P 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
P IsValidObject bool Specifies whether the .NET object represents a valid Revit entity. ElementFilter