文章来源:CSDN
Revit和RevitAPI
Revit是为建筑信息模型而设计的软件,为建筑不同专业提供BIM解决方案。
参数化:是指模型的所有元素之间的关系,这些关系可实现Revit提供的协调和变更管理功能。这些关系可以由软件自动创建,也可以由设计者在项目开发期间创建。
RevitAPI
RevitAPI可以做什么
访问模型的图形数据。
访问模型的参数数据。
创建、修改、删除模型元素。
创建插件UI进行增强。
创建插件完成对重复自有工作的自动化。
集成第三个程序。
执行一切种类的BIM分析。
自动创建项目文档。
1、第一个应用程序HelloWorld
1.anewproject
选择新建项目中的C#–类库,建立项目名称为“HelloWorld”。
2.AddReference
1)在Revit安装路径中添加RevitAPI.dll。
2)添加引用后,右键选择RevitAPI.dll属性,将复制本地种的true改为false。
3)RevitAPIUI.dll按以上步骤添加。RevitprojectsusereferencesofRevitAPI.dll,RevitAPIUI.dllandRevitAddInUtility.dll
3.AddCode
usingSystem;
usingSystem.Collections.Generic;
usingSystem.Linq;
usingSystem.Text;
usingSystem.Threading.Tasks;
usingAutodesk.Revit.UI;
usingAutodesk.Revit.DB;
namespaceHelloWorld
{ [Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.Manual)]
publicclassClass1: IExternalCommand
{
publicAutodesk.Revit.UI.Result Execute(ExternalCommandData revit,refstringmessage, ElementSet elements)
{
TaskDialog.Show("Revit","Hello World");
returnAutodesk.Revit.UI.Result.Succeeded;
}
}
}
4.BuildtheProgram
(1)a.addinmanifestfile
在C#中新建一个文本文件,将代码写入
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<RevitAddIns>
<Assembly>E:C#sampleHelloWorldHelloWorldinDebugHelloWorld.dll</Assembly>
<AddIn Type=”Command”>
//此处的HelloWorld.dll在项目生成后才会有,开始看不到
<AddInId>239BD853-36E4-461f-9171-C5ACEDA4E721</AddInId>
//此处的ID在解决方案管理器项目中Properties的AssemblyInfo.cs中可以查看
<FullClassName>HelloWorld.Class1</FullClassName>
//此处的HelloWorld为项目名,Class1为类名
<Text>HelloWorld</Text>
<VendorId>ADSK</VendorId>
<VendorDescription>Autodesk, www.autodesk.com</VendorDescription>
</AddIn>
</RevitAddIns>
1.将文本格式保存在.addin格式,并保存在C:ProgramDataAutodeskRevitAddins2018(2018为目前revit的版本)
注:C:ProgramData为隐藏文件,若要显示,步骤如下:
组织–文件夹和搜索选项–查看–显示隐藏的文件、文件夹和驱动器
2.DebugtheAdd-in
在解决方案资源管理器中,将项目的内容展示出来,点击其中的Properties,窗口会出现。
击其中的调试(Debug),选择启动外部程序,将revit.exe的路径写出来即可。
最后进行调试,调试时会自动开启revit软件,在添加外部工具中可找到helloworld。
2、外部命令和外部应用
RevitAPI.dll程序集包括了访问Revit中DB级别的Application、Document、Element、以及Parameter方法。RevitAPIUI.dll包括了所有操作和定制RevitUI的接口,包括了:IExternalCommand、IExternalApplication、ion、菜单RibbonPanel、RibbonItem、以及其子类。想通过API来访问或扩展Revit,需要用户在自己的插件中实现特殊的接口,就是IExternalCommand、IExternalApplication、IExternalDBApplication。
3、IExternalCommand外部命令
(1)基本原理:如果Revit没有其他命令在调用,或者是没有处于编辑模式,ExternalCommand会被激活。一旦插件被选中,外部命令对象就会被创建出来,并且执行Execute函数。执行完毕后,外部命令对象就被销毁。在两个命令之间数据不能保存在对象中,要通过其他方式来保存。
(2)IExternalCommand,用户通过外部命令来拓展功能的话,必须实现这个接口。重载Execute函数。作为外部命令的主函数来调用。
//
//摘要:
// An interface that should be implemented to provide the implementation for a Revit
// add-in External Command.
//
//备注:
// To add an external command to Autodesk Revit the developer should implement an
// object that supports the IExternalCommand interface.
publicinterfaceIExternalCommand
{
//
//摘要:
// Overload this method to implement and external command within Revit.
//
//参数:
// commandData:
// An ExternalCommandData object which contains reference to Application and View
// needed by external command.
//
// message:
// Error message can be returned by external command. This will be displayed only
// if the command status was "Failed". There is a limit of 1023 characters for this
// message; strings longer than this will be truncated.
//
// elements:
// Element set indicating problem elements to display in the failure dialog. This
// will be used only if the command status was "Failed".
//
//返回结果:
// The result indicates if the execution fails, succeeds, or was canceled by user.
// If it does not succeed, Revit will undo any changes made by the external command.
ResultExecute(ExternalCommandDatacommandData,refstringmessage,ElementSetelements);
}
(3)输入参数ExternalCommandData
包含了外部命令所需要的Application以及一些视图的引用。在外部命令中,所有的Revit的数据都可以通过这个参数直接或者间接的取到。
UIApplicationuiApplication=revit.Application;
Applicationapplication=uiApplication.Application;
UIDcumentuiDocument=uiApplication.ActiveUIDocument;
Documentdocument=uiDocument.Document;
(4)输出参数message
外部命令可以通过这个参数返回执行过程中的错误信息。这个参数作用于整个外部命令的执行过程,用户可以在外部命令执行过程中的任何时候给这个信息设值或者追加信息。当外部命令的Execute函数返回Autodesk.Revit.UI.Result.Failed或者Autodesk.Revit.UI.Result.Canceled,这个错误信息将被显示在UI上。
(5)输出参数elements(ElementSet)
当外部命令返回Autodesk.Revit.UI.Result.Failed或者Autodesk.Revit.UI.Result.Canceled并且message参数不为空的时候,错误或者警告对话框会弹出来,点击上面的显示按钮,elements参数中的元素将被高亮显示。
(6)Execute函数的返回值
表示外部命令的执行状态,有三种情况:Autodesk.Revit.UI.Result.Succeeded,Autodesk.Revit.UI.Result.Failed或者Autodesk.Revit.UI.Result.Canceled
如果返回不是Succeeded,那么Revit会把外部命令所做的所有操作和修改都撤销。
//摘要:
// Informs Autodesk Revit of the status of your application after execution.
publicenumResult
{
//
//摘要:
// The external application was unable to complete its task.
Failed = -1,
//
//摘要:
// The external application completed successfully. Autodesk Revit will keep this
// object during the entire Revit session.
Succeeded = 0,
//
//摘要:
// Signifies that the external application is cancelled.
Cancelled = 1
}
4、IExternalApplication外部应用
插件开发者同样可以通过IExternalApplication来添加自己的应用,Revit同样通过.addin文件来识别和加载IExternalApplication的外部插件。
IExternalApplication接口有两个抽象函数OnStartup和OnShutdown。用户可以通过在实现了IExternalApplication的外部应用中重载OnStartup和OnShutdown函数,在Revit启动和关闭的时候定制所需要的功能。
//
//摘要:
// An interface that supports addition of external applications to Revit.
//
//备注:
// External applications are permitted to customize the Revit UI, and to add events
// and rs to the session.
publicinterfaceIExternalApplication
{
//
//摘要:
// Implement this method to execute some tasks when Autodesk Revit shuts down.
//
//参数:
// application:
// A handle to the application being shut down.
//
//返回结果:
// Indicates if the external application completes its work successfully.
ResultOnShutdown(UIControlledApplicationapplication);
//
//摘要:
// Implement this method to execute some tasks when Autodesk Revit starts.
//
//参数:
// application:
// A handle to the application being started.
//
//返回结果:
// Indicates if the external application completes its work successfully.
ResultOnStartup(UIControlledApplicationapplication);
}
参数UIControlledApplication:提供了访问定制UI和注册事件的方法。
1.数据库DB级别的外部应用
数据库DB级别的外部应用:它用于一般事件的处理。
//
//摘要:
// An interface that supports addition of DB-level external applications to Revit,
// to subscribe to DB-level events and rs.
//
//备注:
// DB-level applications are permitted to add DB-level events and rs to the
// session. They cannot or modify UI.
publicinterfaceIExternalDBApplication
{
//
//摘要:
// Implement this method to execute some tasks when Autodesk Revit shuts down.
//
//参数:
// application:
// Handle to the Revit Application object.
//
//返回结果:
// Indicates if the external db application completes its work successfully.
ExternalDBApplicationResultOnShutdown(ControlledApplicationapplication);
//
//摘要:
// Implement this method to execute some tasks when Autodesk Revit starts.
//
//参数:
// application:
// Handle to the Revit Application object.
//
//返回结果:
// Indicates if the external db application completes its work successfully.
//
//备注:
// Typically, event handlers and rs are registered in this method.
ExternalDBApplicationResultOnStartup(ControlledApplicationapplication);
}
6、addin文件
(1)注册
windows7用户,如果希望所有登录用户都可以使用的话,要把.addin文件放在C:ProgramDataAutodeskRevitAddins2018,三种方式的插件它的addin文件是有区别的。
(2)外部命令的addin文件示例
*****放置我们的开发的插件.DLL的路径;
619fa21b-37c6-4efb-b886-91c24e30d13b从解决方案的AssemblyInfo.cs里面的[assembly:Guid("619fa21b-37c6-4efb-b886-91c24e30d13b")]获取。
<FullClassName>HelloWorld.Class1</FullClassName>类的全名:命名空间.类名。
一个.addin文件可以包含过个插件。
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<RevitAddIns>
<AddIn Type="Command">
<Assembly>C:RevitProjectHelloWorldHelloWorldinDebugHelloWorld.dll</Assembly>
<AddInId>619fa21b-37c6-4efb-b886-91c24e30d13b</AddInId>
<FullClassName>HelloWorld.Class1</FullClassName>
<Name>HelloWorld</Name>
<VendorId>ADSK</VendorId>
<VendorDescription>Autodesk, www.autodesk.com</VendorDescription>
</AddIn>
<AddIn Type="Command">
…….
</AddIn>
<AddIn Type="Command">
…….
</AddIn>
</RevitAddIns>
(3)外部应用类型的addin文件
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<RevitAddIns>
<AddIn Type="Application">
<Assembly>C:Program FilesAutodeskRevit 2018RevitLookup.dll</Assembly>
<ClientId>356CDA5A-E6C5-4c2f-A9EF-B3222116B8C8</ClientId>
<FullClassName>RevitLookup.App</FullClassName>
<Name>Revit Lookup</Name>
<VendorId>ADSK</VendorId>
<VendorDescription>Autodesk, www.autodesk.com</VendorDescription>
</AddIn>
</RevitAddIns>
(4)DB级别的外部应用
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<RevitAddIns>
<AddIn Type="DBApplication">
<Assembly>C:Program FilesAutodeskRevit 2018RevitLookup.dll</Assembly>
<ClientId>356CDA5A-E6C5-4c2f-A9EF-B3222116B8C8</ClientId>
<FullClassName>RevitLookup.App</FullClassName>
<Name>Revit Lookup</Name>
<VendorId>ADSK</VendorId>
<VendorDescription>Autodesk, www.autodesk.com</VendorDescription>
</AddIn>
</RevitAddIns>
7、Transaction
[Autodesk.Revit.Attributes.Transaction(Autodesk.Revit.Attributes.TransactionMode.Manual)]
TransactionMode,控制RevitAPI框架如何在调用外部命令时处理其中的事务。
publicenumTransactionMode
{
//
//摘要:
// The API framework will not a transaction (but will an outer group
// to roll back all changes if the external command returns a failure status). Instead,
// you may use combinations of transactions, sub-transactions, and groups. You will
// have to follow all rules regarding use of transactions and related classes. You
// will have to give your transactions names, which will then appear in the undo
// menu. Revit will check that all transactions (also groups and sub-transaction)
// are properly closed upon return from an external command. If not, it will discard
// all changes to the model.
Manual = 1,
//
//摘要:
// No transaction (nor group) will be d, and no transaction may be d
// for the lifetime of the command. The External command may use methods that only
// read from the model, but not methods that write anything to it. Exceptions will
// be thrown if the command either tries to start a transaction (or group) or attempts
// to write to the model.
//
//备注:
// A command with this transaction mode should not be associated to a command visible
// when there is no active document. The command will not be permitted to be started.
ReadOnly = 2
}
 
            
 BIM建筑网
BIM建筑网


 
			



 
			