Yesterday, I was very busy again on the Revit API discussion forum.
Here are two interesting results to keep track of for posterity:
Geometry Basics
From the thread on finding geometry objects:
Question: I have little experience with GeometryObjects in Revit and most of my work has been based on filtering Elements.
I want to know if it is possible to find geometry objects in the database without prompting the user to select one?
Can I use PickObject to select all or individual curves or lines to get all references programmatically?
Answer: Good question.
The Revit database contains elements.
They are mainly defined parametrically.
This generates their geometry.
You can query an element for its geometry.
The geometry objects are therefore more or less a read-only view of the elements and their parameters.
Yes, you can retrieve geometry without prompting the user, e.g. traversing all elements or a subset via a filtered element collector and querying each for its geometry.
My most recent foray into this area was published yesterday, on creating a DirectShape from a selected face.
It demonstrates picking an element on the screen, retrieving the picked geometrical face, querying the same element for its geometry programmatically as well, then traversing that to find the picked face within it.
The Building Coder has discussed hundreds of other examples of geometry retrieval and analysis.
Some of the more interesting discussions are listed in various topic groups.
One related area is exporting element geometry in various ways.
The easiest way to do so nowadays is to use a custom exporter.
That hooks directly into the graphics pipeline and eliminates the need to query each individual element for its geometry.
A good source to get started and understand the Revit Geometry API in more depth is the Revit online help and its developer guide section on Geometry.
No Modifying Linked Files
From the thread on transaction problem with linked document:
Question:
My code is written to create a space inside a linked element. This is an error I get when using the NewSpace
method:
I call the method inside a transaction in the main document and it does nothing to the error.
UIApplication uiapp = commandData.Application; UIDocument uidoc = uiapp.ActiveUIDocument; Application app = uiapp.Application; Document doc = uidoc.Document; foreach (Document d in app.Documents) { using (Transaction t = new Transaction(doc)) { t.Start("New Space"); Space sp = d.Create.NewSpace( ... ); t.Commit(); } }
Could this error be due to the fact that I am calling NewSpace
in the Linked element but the transaction is in the primary one?
Revit does not seem to allow me to use transactions in anything but the primary document.
If anyone has any suggestions of how I might be able to edit the linked element successfully I would be very appreciative.
Answer: Yes, absolutely, a transaction is totally tied to a document.
If you have two separate documents to modify, you need two separate transactions for them.
If your subtransaction is in a different document B, it cannot be nested into a transaction tied to document A.
However, what is even more applicable in this particular case is the fact that linked documents are not modifiable – they cannot have any transactions at all.
In order to modify a linked document, one would have to close the link, open the document as a separate main document, make the changes there, save it, and link it back again in the original host.