Elements in Revit are very common. Retrieving the elements that you want from Revit is necessary before using the API for any Element command. There are several ways to retrieve elements with the Revit API:
Each of these methods of element retrieval is discussed in more details in the following sections.
When the ElementId of the desired element is known, use the Document.Element property to get the element.
The most common way to get elements in the document is to use filtering to retrieve a collection of elements. The Revit API provides the FilteredElementCollector class, and supporting classes, to create filtered collections of element which can then be iterated. See Filtering for more information.
Rather than getting a filtered collection of all of the elements in the model, you can access just the elements that have been selected. You can get the selected objects from the current active document using the UIDocument.Selection.Elements property. For more information on using the active selection, see Selection.
In addition to using the general way to access Elements, the Revit Platform API has properties in the Document class to get the specified Elements from the current active document without iterating all Elements. The specified Elements you can retrieve are listed in the following table.
Table 11: Retrieving Elements from document properties
Element |
Access in property of Document |
ProjectInfo |
Document.ProjectInformation |
ProjectLocation |
Document.ProjectLocations Document.ActiveProjectLocation |
SiteLocation |
Document.SiteLocation |
Phase |
Document.Phases |
Material |
Document.Settings.Materials |
FamilySymbol relative to the deck profile of the layer within a structure |
Document.DeckProfiles |
FamilySymbol in the Title Block category |
Document.TitleBlocks |
All Element types |
Document.AnnotationSymbolTypes / BeamSystemTypes / ContFootingTypes / DimensionTypes / FloorTypes / GridTypes / LevelTypes / RebarBarTypes / RebarHookTypes / RoomTagTypes / SpotDimensionTypes / WallTypes / TextNoteTypes |