土木在线论坛 \ 建筑结构 \ SAP2000 \ SAP2000 API入门指南(二) OAPI插件开发

SAP2000 API入门指南(二) OAPI插件开发

发布于:2009-04-01 13:18:01 来自:建筑结构/SAP2000 [复制转发]
在入门指南(一)中,给大家介绍了从外部程序调用SAP2000进行自动建模、分析、输出的例子。本文介绍另外一种应用方法,可以在SAP2000的“Tools”菜单下增加一个菜单项,点击菜单项后可执行特定的功能,即所谓的“Plug in”。



每个插件实质上是一个dll。在C#中,用“类库”项目来生成此dll,公开一个cPlugin类,并在类中公开main方法,该方法的原型必须是:

public void Main(ref Sap2000.cSapModel SapModel, ref Sap2000.cSapPlugin ISapPlugin);



下面我们通过一个例子来说明如何开发插件。在这个例子中,我们实现一个显示所选的对象的数目的简单功能,即让用户首先在SAP2000中选择对象,然后点击插件所对应的菜单项,插件会报告用户已选择的对象的数量。



开发环境:

SAP2000 V12.0.2 正式版(学习版不具备API开发的功能)

Microsoft Visual Studio 2008, C#



开发步骤:

1. 建立项目。启动VS2008,建立一个Windows C# 类库项目,如下图:


1_project.png


2. 建立代码框架

VS自动生成了代码文件class1.cs,并创建了如下代码:

namespace ObjectCount
{
public class Class1
{
}
}



将类名“Class1”改为“cPlugin”,并添加main函数,修改后的全部代码如下:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows.Forms;

namespace ObjectCount
{
public class cPlugin
{
public void Main(ref Sap2000.cSapModel SapModel, ref Sap2000.cSapPlugin ISapPlugin)
{
int NumberItems = 0;
Array ObjectTypes = null;
Array ObjectNames = null;
SapModel.SelectObj.GetSelected(ref NumberItems, ref ObjectTypes, ref ObjectNames);
MessageBox.Show(string.Format("共选择了{0}个对象.", NumberItems));
ISapPlugin.Finish(0);
}
}
}


执行插件时,SAP2000会调用cPlugin类的Main函数,因此我们的类库必须要有cPlugin类和Main函数,并且Main函数的原型必须是这样的。



3. 引用SAP2000 API

以上代码是不能编译通过的,我们还要引用SAP2000 API。选菜单“项目/添加引用”,如下图:

2_addRef.png

在弹出的“添加引用”对话框中,选“浏览”标签,选中SAP2000目录下的SAP2000.exe文件,如下图。

3_addRefDialog.png

按“确定”按钮。VS2008生成了对SAP2000 API的引用。



4. 引用System.Windows.Forms

由于我们要显示一个结果对话框,需要引用DotNet的System.Windows.Forms. 操作方法是:选菜单“项目/添加引用”,选中“NET”标签,再选中System.Windows.Forms,如下图:

4_ref.png

按确定按钮。



5. 编译成COM组件

添加对SAP2000 API的引用和System.Windows.Forms的引用后,程序就可以编译通过了,但必须要编译成COM组件,才能真正成为SAP2000的插件。选菜单“项目/ObjectCount属性”,如下图所示。

5_property.png

在属性页面中选择“生成”标签,再勾选“为COM互操作注册”,如下图:

6_property_sheet.png

在VS2008的解决方案管理器中,打开项目的Properties节点下的AssemblyInfo.cs,如下图所示。

7_assemblyInfo.png

找到[assembly: ComVisible(false)]语句,将false改为true,这样就成为可见的COM组件了。



6. 生成

选菜单“生成/生成解决方案”,如下图所示:

8_build.png

VS2008将生成此dll,并自动将此COM组件注册。



7. 添加到SAP2000的菜单中

运行SAP2000,选菜单“Tools”->“Add/Show Plug Ins...”,如下图:

9_tools_menu.png

在弹出的“External Plug In Data”对话框中,在“Plug In Name”栏输入“ObjectCount”,在“Menu Text”栏输入“统计选择数量”,然后按“Add”按钮,如下图:

a_plugin.png

添加成功后,列表中会多一行,如下图所示:

b_addok.png

按“OK”按钮。再选菜单“Tools”,可以看到多了一个菜单项“统计选择数量”,如下图:

c_tools_menu_added.png



8. 运行插件

点选刚添加的菜单项“统计选择数量”,程序显示“Plug In Warning”对话框,如下图:

d_warning.png

按“Yes”按钮。程序显示结果对话框,如下图:

e_0.PNG



由于我们没有选择任何对象,所以输出结果为0. 在SAP2000中创建一些构件,然后选中这些构件,再执行此插件,就可以显示选中的构件的数量。



小结

SAP2000的插件开发非常灵活,为SAP2000的前后处理软件的开发提供了强大的支持。

[ 本帖最后由 ycf888 于 2009-4-1 13:29 编辑 ]

1_project.png


2_addRef.png


3_addRefDialog.png


4_ref.png


5_property.png


6_property_sheet.png


7_assemblyInfo.png


8_build.png


9_tools_menu.png


a_plugin.png


b_addok.png


c_tools_menu_added.png


d_warning.png


e_0.PNG

全部回复(7 )

只看楼主 我来说两句
  • suhong1984
    suhong1984 沙发
    好资料,谢谢,下载学习下
    2010-08-19 21:17:19

    回复 举报
    赞同0
  • faithlg
    faithlg 板凳
    楼主好人,再次感谢
    2010-07-28 18:09:28

    回复 举报
    赞同0
加载更多
这个家伙什么也没有留下。。。

SAP2000

返回版块

3.12 万条内容 · 162 人订阅

猜你喜欢

阅读下一篇

SAP2000 API入门指南(一)从外部程序调用

在SAP2000 12的安装目录下,有一个SAP2000_API_Documentation.chm文件,这个文件就是API的文档,里面有入门指南、函数参考手册、样例代码等。我是从“Example 3 (Visual C# 2005)”这个样例代码学起的。当时我用VS2005,现在用VS2008一样OK。需要特别注意的是,这个文档并没有及时更新,实际的函数接口可能跟文档里写得不一样,因此样例代码是在编译时会出错的。需要做一些更改才能正常运行。这些更改通常是大小写问题,估计CSI的人都用VB,对大小写不重视吧。还有一些是函数的参数个数或类型不符,但不太多,稍微修改一下就OK。

回帖成功

经验值 +10