Revit API Forum
Welcome to Autodesk’s Revit API Forums. Share your knowledge, ask questions, and explore popular Revit API topics.
cancel
Showing results for 
Show  only  | Search instead for 
Did you mean: 

Is it possible to access/write to an open Revit session from an externally running .exe?

5 REPLIES 5
Reply
Message 1 of 6
szhaoNAYVW
449 Views, 5 Replies

Is it possible to access/write to an open Revit session from an externally running .exe?

Let's say I have an app.exe that runs outside of Revit. Let's say this app generates a 3 x 3 array, and I want to import/draw this table in an active Revit session in a drafting view. 

 

I have created "commands" that start inside Revit that utilize the transaction method to draw lines and textboxes before. But is there any way to do this from an externally running .exe with the Revit API referenced in?

 

Any help would be greatly appreciated.

-Stephen

5 REPLIES 5
Message 2 of 6
joshua.lumley
in reply to: szhaoNAYVW

I don't think you can. However you can make an app that will work standalone as well as an addin (utilizing different constructors) meaning you can launch the thing from the task bar and the ribbon.  (I wrote one over Christmas).
But you can't perform a transaction to the project database outside of the Revit.exe process. Correct me if I'm wrong.

Message 3 of 6
szhaoNAYVW
in reply to: szhaoNAYVW

In that case I wonder if there's any way I can pass through some variables to the taskbar or ribbon function... That's too bad, it may require me to build the actual computational solution inside the ribbon function.

Message 4 of 6
RPTHOMAS108
in reply to: szhaoNAYVW

Numerous approaches exist. Do a search on this forum and elsewhere for 'interprocess communication' and 'driving Revit' and you may find some solution that meet your goals.

 

The key is having an insider raising an ExternalEvent to deal with an external request i.e. you have to have an addin that responds to an external action and raises the ExternalEvent. Since objects can be serialised in various forms json, xml; dropped by one process and picked up by the other the possibilities aren't that limited.

 

What could an insider addin look for:

Windows messages, file system events...

 

 

Message 5 of 6
joshua.lumley
in reply to: RPTHOMAS108

PipeStream Class (System.IO.Pipes) provides interprocess communication without the need for seralization. Although it may be better to pass variable via xml to avoid the necessity to have both applications open at the same time.

Message 6 of 6
RPTHOMAS108
in reply to: joshua.lumley

Yes there is the possibility to use named or anonymous pipes for this.

 

I didn't find them to be the easiest thing to work with when I tried (keeping them open and at the same time not thread blocking) they at least require a separate thread from Revit. Pipes are more straightforward when you have complete control over the client and server sides. The examples seem simple enough (the console application type examples) but not so easy when factoring in Revit. Then in the end what do you send through the pipe?

 

I got them working for a separate progress bar executable once in the early days when we were looking for ways of doing away with DoEvents. Revit was sending information through and the executable progress bar was acting upon it (this was in other direction). Got a lag which was a strange situation for a pipe.

 

As you say other methods I found more appealing due to their simplicity.

Can't find what you're looking for? Ask the community or share your knowledge.

Post to forums  

Autodesk Design & Make Report