-
Notifications
You must be signed in to change notification settings - Fork 15
Pull from Revit details
This chapter explains in detail the Pull action - it is recommended to read Revit Adapter details section first for the information about mechanics of the adapter itself.
As explained in Pull from Revit basics, there are two action-specific inputs that drive Pull:
-
Request of type deriving from
IRequest
explained in more detail in a dedicated section -
Action config of type
RevitPullConfig
They are specified as arguments of the Pull
method of RevitAdapter
. Depending on the thread on which the Pull
method is executed, they will be either sent via Sockets as a data package (if Pull
is executed outside of Revit thread) or passed directly to RevitUIAdapter
(if everything is run on a single Revit thread).
Next, RevitUIAdapter
triggers Pull action, which points directly to Read
CRUD method. Read
executes following tasks:
-
Collects ElementIds of Revit elements that meet requirements set by the Request (done in
BH.Revit.Engine.Core.Query.ElementIds
). -
Checks discipline enforced by:
- Request - this happens e.g. when the filter is
FilterRequest
withType
property equal toBH.oM.Structure.Elements.Bar
- pulling of elements of given type is possible only for structural discipline -
RevitPullConfig
- value carried byDiscipline
property
If discipline is not enforced by any of the two above,
Discipline.Physical
is used as default. Conflict between disciplines is not allowed: if both Request andRevitPullConfig
enforce a discipline (none of them is equal toDiscipline.Undefined
) and the disciplines enforced by each are not equal, the operation is cancelled with an error. - Request - this happens e.g. when the filter is
-
Retrieves the Revit elements under ElementIds from point 1. and converts them to BHoM for discipline determined in point 2. Conversion of all elements is being driven by
BH.Revit.Engine.Core.Convert.IFromRevit
dispatcher method combined withBH.Revit.Engine.Core.Query.IBHoMType
andBH.Revit.Engine.Core.Query.ConvertMethod
queries. To avoid converting any of the objects more than once, identifier of each object that has been converted in a given adapter action is being stored inrefObjects
dictionary together with the output of the convert.
The usual flow looks as in the picture below:
- If
PullGeometryConfig
contains instruction to pull geometry, it is extracted from the elements and attached to the output BHoM objects asRevitRepresentation
fragments. - If
PullRepresentationConfig
contains instruction to pull mesh representation, it is extracted from the elements and attached to the output BHoM objects asRevitRepresentation
fragments.
Finally, the converted BHoM objects are returned to RevitAdapter
(using a Sockets bypass if RevitAdapter
and RevitUIAdapter
do not run on the same thread).
The diagram below maps out the above workflow - it should be read as an action-specific variation of the Adapter action stage of the general Adapter flowchart.
-
Overview:
What is Revit_Toolkit for?
Code structure
Building from source and debugging
License
Sample scripts -
Adapter:
Basics
Revit <-> BHoM conversion
BHoM vs Revit identity
Handling of Parameters
Conventions
Setup in Revit
Setup in Grasshopper
Setup in Dynamo
Setup in Excel
Details -
Pull:
Basics
Requests and filtering
Pull of Geometry and Representation
Pull from Links
Pull in Grasshopper
Pull in Dynamo
Pull in Excel
Examples
Explicit family vs type mapping
Details -
Push:
Basics
Push modes
Updating Revit types
FamilyLibrary
Push in Grasshopper
Push in Dynamo
Push in Excel
Examples
Details -
Remove:
Basics
Remove in Grasshopper
Remove in Dynamo
Remove in Excel
Examples
Details -
References:
BHoM Wiki
BHoM Adapter