明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 8650|回复: 10

[原创] 在C#中使用ObjectDBX技术从未打开图形中获得图块的信息

  [复制链接]
发表于 2004-1-13 15:05 | 显示全部楼层 |阅读模式
在C#中使用ObjectDBX技术从未打开图形中获得图块的信息
                                           C#才鸟(QQ:2491785)   
从未打开图形中能获得图块的信息吗?明经通道的VBA版块已经介绍了VBA的实现方法,那在C#中能否做到呢?
回答是肯定的。下面就来说明具体的实现方法。
    要求:
       会用C#编程
       读过我写的“利用C#进行AutoCAD的二次开发“(在明经通道中有)
    开始:
        在visual studio.net中新建一C#控制台程序
               在引用选项卡中添加下列类库:
               interop.AutoCAD.dll
          AcadExample.dll
               ObjectDBX16(在“解决方案资源管理器”中右击“引用”标签,在弹出的菜单中选择“添加引用”,在“添加引用”对话框中选择“com"选项卡下的下拉列表框中的“AutoCAD/ObjectDBX Common 16.0 Type Library"项)
    然后键入以下代码:
1:  using System;
2:  using AutoCAD;
3:  using dbx = AXDBLib;
4:  using AcadExample;
5:
6:  namespace ConsoleApplication1
7:  {
8:      /// <summary>
9:      /// Summary description for Class1.
10:      /// </summary>
11:      class Class1
12:      {
13:          /// <summary>
14:          /// The main entry point for the application.
15:          /// </summary>
16:          [STAThread]
17:          static void Main(string[] args)
18:          {
19:              using (AutoCADConnector connector = new AutoCADConnector())
20:              {
21:                  string progid = "ObjectDBX.AxDbDocument.16"//注意,这是AutoCAD2004的写法,
                      // 若是AutoCAD2002和AutoCAD2000i则是”ObjectDBX.AxDbDocument.1“   
22:                  AcadApplication acadApp = connector.Application;
23:                  dbx.AxDbDocument dbxDoc;
24:                  dbxDoc = (dbx.AxDbDocument)acadApp.GetInterfaceObject(progid);
25:                  dbxDoc.Open(@"F:\Test.dwg");
26:                  foreach (dbx.AcadEntity entity in dbxDoc.ModelSpace)
27:                  {
28:                      if (entity.EntityName == "AcDbBlockReference")//判断实体是否是块参照
29:                      {
30:                          dbx.AcadBlockReference blkRef;     
31:                          blkRef = (dbx.AcadBlockReference)entity;  //将是块参照的实体强制转换为块参照类型
32:                          object[] atts = (object[])blkRef.GetAttributes();//获取块参照中的属性(为对象类型)
33:                          for (int i = 0; i < atts.Length; i++) //遍历块参照属性
34:                          {
35:                              dbx.AcadAttributeReference att;
36:                              att = (dbx.AcadAttributeReference)atts;//将块参照属性(对象类型)强制转换为块参照属性类型
37:                              Console.WriteLine("Tag: {0}\tValue: {1}\n",
38:                              att.TagString,
39:                              att.TextString);//显示块参照属性的Tag和Text的值
40:                          }
41:                      }
42:                  }
43:                  Console.ReadLine();
44:              }
45:          }
46:      }
47:  }
第一个要注意的是第三行,使用了一个别名。因为AutoCAD和ObjectDBX命名空间有许多相同的类名,因此,你必须使用全名,而不能使用简写的形式,但ObjectDBX写起来比较麻烦,所以用别名dbx来使输入方便一些。
程序前面部分的代码,你可以参考我写的“利用C#进行AutoCAD的二次开发“这篇文章。让我们来看第21行,程序定义了一个字符串progid,作为第24句的函数GetInterfaceObject的参数,该函数是用来产生一个AxDbDocument对象。但要注意, GetInterfaceObject函数返回的类型是object,所以你必须用强制转换把它变为AxDbDocument类。然后在第25行使用24行产生的AxDbDocument对象来”打开“一个.dwg文件(其实没有打开),需要注意的是这个文件的路径必须是正确的。这个文件就是我们要获得的块信息所在的文件。
由于ObjectDBX 没有选择集,所以只有通过遍历文件的模型空间来获得块的信息(26-28行)。
余下语句的说明我已经写在程序的注释中了。
你可以发现ObjectDBX的工作原理在C#中与VBA是类似的,只不过要进行必要的类型转换。

评分

参与人数 1威望 +1 金钱 +10 贡献 +10 激情 +15 收起 理由
mccad + 1 + 10 + 10 + 15 【好评】好程序

查看全部评分

发表于 2004-1-13 17:07 | 显示全部楼层
好的没得说啦,哈哈
发表于 2004-2-7 10:33 | 显示全部楼层
发表于 2005-11-30 17:14 | 显示全部楼层

学习

发表于 2006-4-8 22:52 | 显示全部楼层

ding

发表于 2007-1-13 23:23 | 显示全部楼层

这个不是C#,这个就是C#里面调用的VBA

发表于 2007-1-13 23:30 | 显示全部楼层

CAD2006以前,C#不具有C++的强大功能,速度也比VBA慢,而且功能只是和VBA一样

2006以后,C#运行比VBA快,但是只有C++的1/3,功能要强大一些,几乎达到C++能做到的东西的一半了。

发表于 2007-1-13 23:32 | 显示全部楼层

另外,ApDocument确实打开了文件,只不过是在后台打开了,并且由于AcadApplication对象运行在acad.exe中,实际上是通过进城外过程调用透过VBA访问的数据库。超慢无比。

发表于 2007-1-15 14:17 | 显示全部楼层

有在VC中实现的么?

发表于 2007-10-9 19:35 | 显示全部楼层
不明白 AutoCAD为啥非得搞这么多开发工具,又是C++,又是C#,又是VBA,LISP ... 就不能统一到一种工具?  功能强大\好学易用 ~
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-4-26 08:50 , Processed in 0.386036 second(s), 27 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表