推荐net开发cad入门阅读代码片段

转载自  Cad人生  的博客

链接:http://www.cnblogs.com/cadlife/articles/2668158.html

内容粘贴如下,小伙伴们可以看看哦。

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Text;
  4 using Autodesk.AutoCAD.EditorInput ;
  5 using Autodesk.AutoCAD.Runtime ;
  6 using Autodesk.AutoCAD.ApplicationServices;
  7 using Autodesk.AutoCAD.DatabaseServices ;
  8 namespace CH02
  9 {
 10     public class Class1
 11     {
 12         //--------------------------------------------------------------
 13         // 功能:获取用户输入
 14         // 作者: 
 15         // 日期:2007-7-20
 16         // 说明:
 17         //   
 18         //----------------------------------------------------------------
 19         [CommandMethod("GetData")]
 20         public void GetData()
 21         {
 22             //获取Editor对象
 23             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 24             //获取整型数据
 25             PromptIntegerOptions intOp = new PromptIntegerOptions("请输入多边形的边数:");
 26             PromptIntegerResult intRes;
 27             intRes = ed.GetInteger(intOp);
 28             //判断用户输入
 29             if (intRes.Status == PromptStatus.OK)
 30             {
 31                 int nSides = intRes.Value;
 32                 ed.WriteMessage("多边形的边数为:" + nSides);
 33             } if (intRes.Status == PromptStatus.Cancel)
 34             {
 35                 ed.WriteMessage("用户按了取消ESC键/n" );
 36             }
 37         }
 38         //--------------------------------------------------------------
 39         // 功能:要求用户输入点
 40         // 作者: 
 41         // 日期:2007-7-20
 42         // 说明:
 43         //   
 44         //----------------------------------------------------------------
 45    [CommandMethod("PickPoint")]
 46         static public void PickPoint() 
 47    {
 48                 //获取Editor对象
 49                Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 50        PromptPointOptions promptPtOp = new PromptPointOptions("选择一个点:");
 51                 //指定的基点,如果指定了该点,则在选择的时候绘制一条橡皮线。
 52                 promptPtOp.BasePoint = new Autodesk.AutoCAD.Geometry.Point3d(0, 0, 0);
 53        PromptPointResult resPt; 
 54        resPt = ed.GetPoint(promptPtOp); 
 55        if (resPt.Status == PromptStatus.OK) 
 56        {
 57                     ed.WriteMessage("选择的点为:" + resPt.Value.ToString());
 58        } 
 59             }
 60 
 61             //--------------------------------------------------------------
 62             // 功能:获取选择集
 63             // 作者: 
 64             // 日期:2007-7-20
 65             // 说明:
 66             //   
 67             //----------------------------------------------------------------
 68    [CommandMethod("SelectEnt")]
 69         static public void SelectEnt() 
 70    {
 71                 //获取Editor对象
 72                Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 73                PromptSelectionOptions selectionOp = new PromptSelectionOptions();
 74                PromptSelectionResult ssRes = ed.GetSelection(selectionOp);
 75                if (ssRes.Status == PromptStatus.OK)
 76                {
 77                    SelectionSet SS = ssRes.Value;
 78                    int nCount = SS.Count;
 79                    ed.WriteMessage("选择了{0}个实体"  , nCount);
 80                }      
 81             }
 82             //--------------------------------------------------------------
 83             // 功能:获取选择集(带过滤)
 84             // 作者: 
 85             // 日期:2007-7-20
 86             // 说明:
 87             //   
 88             //----------------------------------------------------------------
 89           [CommandMethod("SelectEnt2")]
 90         static public void SelectEnt2() 
 91    {
 92                 //获取Editor对象
 93                Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 94                 // 定义选择集选项
 95                PromptSelectionOptions selectionOp = new PromptSelectionOptions();
 96                  //创建选择集过滤器,只选择块对象
 97                 TypedValue[] filList = new TypedValue[1];
 98                 filList[0] = new TypedValue((int)DxfCode.Start, "INSERT");
 99                SelectionFilter filter = new SelectionFilter(filList);
100                PromptSelectionResult ssRes = ed.GetSelection(selectionOp, filter);
101                if (ssRes.Status == PromptStatus.OK)
102                {
103                    SelectionSet SS = ssRes.Value;
104                    int nCount = SS.Count;
105                    ed.WriteMessage("选择了{0}个块"  , nCount);
106                }     
107             }
108        }
109  
110   }

 

using System;
using System.Collections.Generic;
using System.Text;
using Autodesk.AutoCAD.EditorInput;
using Autodesk.AutoCAD.Runtime;
using Autodesk.AutoCAD.ApplicationServices;
using Autodesk.AutoCAD.DatabaseServices;
using Autodesk.AutoCAD.Geometry;
namespace CH03
{
    public class Class1
    {
        //--------------------------------------------------------------
        // 功能:创建一个新层
        // 作者: 
        // 日期:2007-7-20
        // 说明:
        //
        //----------------------------------------------------------------
        [CommandMethod("CreateLayer")]
        public void CreateLayer()
        {
            ObjectId layerId;
            Database db = HostApplicationServices.WorkingDatabase;
            //开始一个事务
            Transaction trans = db.TransactionManager.StartTransaction();
            try
            {
                //首先取得层表
                LayerTable lt = (LayerTable)trans.GetObject(db.LayerTableId, OpenMode.ForWrite);
                //检查MyLayer层是否存在
                if (lt.Has("MyLayer"))
                {
                    layerId = lt["MyLayer"];
                }
                else
                {
                    //如果MyLayer层不存在,就创建它
                    LayerTableRecord ltr = new LayerTableRecord();
                    ltr.Name = "MyLayer"; //设置层的名字
                    layerId = lt.Add(ltr);
                    trans.AddNewlyCreatedDBObject(ltr, true);
                }
                //提交事务
                trans.Commit();
            }
            catch (Autodesk.AutoCAD.Runtime.Exception e)
            {
                //放弃事务
                trans.Abort();
            }
            finally
            {
                // 显式地释放
                trans.Dispose();
            }
        }
        //--------------------------------------------------------------
        // 功能:创建一个圆
        // 作者: 
        // 日期:2007-7-20
        // 说明:
        //
        //----------------------------------------------------------------
        [CommandMethod("CreateCircle")]
        public void  CreateCircle()
        {
            Database db = HostApplicationServices.WorkingDatabase;
            // 使用 "using" ,结束是自动调用事务的 "Dispose" 
            using (Transaction trans = db.TransactionManager.StartTransaction())
            {
                //获取块表和模型空间
                BlockTable bt = (BlockTable)(trans.GetObject(db.BlockTableId, OpenMode.ForRead));
                BlockTableRecord btr = (BlockTableRecord)trans.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite);
                //创建一个圆并添加到块表记录(模型空间)
                Point3d center = new Point3d(10, 10, 0);
                Circle circle = new Circle(center, Vector3d.ZAxis, 10.0);
                circle.ColorIndex = 1;
                btr.AppendEntity(circle);
                trans.AddNewlyCreatedDBObject(circle, true);
                trans.Commit();
            }
        }
        //--------------------------------------------------------------
        // 功能:创建一个块定义(块表记录)
        // 作者: 
        // 日期:2007-7-20
        // 说明:
        //   
        //----------------------------------------------------------------
        public ObjectId CreateBlkDef()
        {
            //定义函数的返回值ObjectId
            ObjectId blkObjId = new ObjectId(); 
            Database db = HostApplicationServices.WorkingDatabase;
            // 使用 "using"关键字指定事务的边界
            using (Transaction trans = db.TransactionManager.StartTransaction())
            {
                //获取块表
                BlockTable bt = (BlockTable)trans.GetObject(db.BlockTableId, OpenMode.ForWrite);
                //通过块名myBlkName判断块表中是否包含块表记录
                if ((bt.Has("myBlkName")))
                {
                    blkObjId = bt["myBlkName"];//如果已经存在,通过块名获取块对应的ObjectId
                }
                else
                {
                    //创建一个圆
                    Point3d center = new Point3d(10, 10, 0); 
                    Circle circle = new Circle(center, Vector3d.ZAxis, 2);
                    circle.ColorIndex = 1;      
                    //创建文本Text:
                    MText text = new MText();
                    text.Contents = " ";
                    text.Location = center;
                    text.ColorIndex = 2;
                    //创建新的块表记录 myBlkName
                    BlockTableRecord newBtr = new BlockTableRecord();
                    newBtr.Name = "myBlkName";
                    newBtr.Origin = center;
                    //保存块表记录到块表
                    blkObjId = bt.Add(newBtr); // 返回块对应的ObjectId
                    trans.AddNewlyCreatedDBObject(newBtr, true); //Let the transaction know about any object/entity you add to the database!
                   
                    //保存新创建的实体到块表记录
                    newBtr.AppendEntity(circle); 
                    newBtr.AppendEntity(text);
                    // 通知事务新创建了对象
                    trans.AddNewlyCreatedDBObject(circle, true);
                    trans.AddNewlyCreatedDBObject(text, true);
                }
                trans.Commit(); //提交事务
            }
            return blkObjId;
        }

        //--------------------------------------------------------------
        // 功能:创建一个块引用
        // 作者: 
        // 日期:2007-7-20
        // 说明:
        //
        //----------------------------------------------------------------
        [CommandMethod("CreateBlk")]
        public void CreateBlkRef()
        {
            
             
            //获取块的插入点
            Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
            PromptPointOptions ptOps = new PromptPointOptions("选择块的插入点");
            PromptPointResult ptRes;
            ptRes = ed.GetPoint(ptOps);
            Point3d ptInsert;
            if (ptRes.Status == PromptStatus.OK)
            {
                ptInsert = ptRes.Value ;
            }
            else
            {
                ptInsert = new Point3d(0, 0, 0);
            }
            Database db = HostApplicationServices.WorkingDatabase;
            // 使用 "using"关键字指定事务的边界
            using (Transaction trans = db.TransactionManager.StartTransaction())
            {
                //获取块表和模型空间
                BlockTable bt = (BlockTable)(trans.GetObject(db.BlockTableId, OpenMode.ForWrite));
                BlockTableRecord btr = (BlockTableRecord)trans.GetObject(bt[BlockTableRecord.ModelSpace], OpenMode.ForWrite);
                
                //创建块引用
                BlockReference blkRef = new BlockReference(ptInsert,CreateBlkDef());// 指定插入点和所引用的块表记录
                blkRef.Rotation = 1.57;//指定旋转角,按弧度
                //保存新创建的块引用到模型空间    
                btr.AppendEntity(blkRef); 
                trans.AddNewlyCreatedDBObject(blkRef, true);    // 通知事务新创建了对象
                trans.Commit(); //提交事务
            }
  
        }
        //--------------------------------------------------------------
        // 功能:读取对象的属性
        // 作者: 
        // 日期:2007-7-20
        // 说明:
        //
        //----------------------------------------------------------------
        [CommandMethod("OpenEnt")]
        public void OpenEnt()
        {
            Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
            PromptEntityOptions entOps = new PromptEntityOptions("选择要打开的对象");
            PromptEntityResult entRes;
            entRes = ed.GetEntity(entOps);
            if (entRes.Status != PromptStatus.OK)
            {
                ed.WriteMessage("选择对象失败,退出");
                return;
            }
            ObjectId objId = entRes.ObjectId;
            Database db = HostApplicationServices.WorkingDatabase;
            using (Transaction trans = db.TransactionManager.StartTransaction())
            {
                Entity ent = (Entity)trans.GetObject(objId, OpenMode.ForWrite);
                ent.ColorIndex = 1;
                trans.Commit();
            }
        }
    }
}

 

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Text;
  4 using Autodesk.AutoCAD.EditorInput;
  5 using Autodesk.AutoCAD.Runtime;
  6 using Autodesk.AutoCAD.ApplicationServices;
  7 using Autodesk.AutoCAD.DatabaseServices;
  8 using Autodesk.AutoCAD.Geometry;
  9 namespace CH04
 10 {
 11     public class Class1
 12     {
 13 
 14         //--------------------------------------------------------------
 15         // 功能:通过ObjectId打开对象
 16         // 作者: 
 17         // 日期:2007-7-20
 18         // 说明:
 19         //
 20         //----------------------------------------------------------------
 21         [CommandMethod("OpenEnt")]
 22         public void OpenEnt()
 23         {
 24             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 25             ed.WriteMessage("通过ObjectId打开对象\n");
 26             PromptEntityOptions entOps = new PromptEntityOptions("选择要打开的对象\n");
 27             PromptEntityResult entRes;
 28             entRes = ed.GetEntity(entOps);
 29             if (entRes.Status != PromptStatus.OK)
 30             {
 31                 ed.WriteMessage("选择对象失败,退出");
 32                 return;
 33             }
 34             ObjectId objId = entRes.ObjectId;
 35             Database db = HostApplicationServices.WorkingDatabase;
 36             using (Transaction trans = db.TransactionManager.StartTransaction())
 37             {
 38                 Entity ent = trans.GetObject(objId, OpenMode.ForWrite) as Entity ;
 39                 ent.ColorIndex = 1;
 40                 trans.Commit();
 41             }
 42  
 43         }
 44         //--------------------------------------------------------------
 45         // 功能:类型识别和转换
 46         // 作者: 
 47         // 日期:2007-7-20
 48         // 说明:
 49         //
 50         //----------------------------------------------------------------
 51         [CommandMethod("GetType")]
 52         public void GetType()
 53         {
 54             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 55             ed.WriteMessage("数据库对象的类型识别和转换\n");
 56             PromptEntityOptions entOps = new PromptEntityOptions("选择要打开的对象");
 57             PromptEntityResult entRes;
 58             entRes = ed.GetEntity(entOps);
 59             if (entRes.Status != PromptStatus.OK)
 60             {
 61                 ed.WriteMessage("选择对象失败,退出");
 62                 return;
 63             }
 64             ObjectId objId = entRes.ObjectId;
 65             Database db = HostApplicationServices.WorkingDatabase;
 66             using (Transaction trans = db.TransactionManager.StartTransaction())
 67             {
 68                 Entity ent = trans.GetObject(objId, OpenMode.ForWrite) as Entity;
 69                 ed.WriteMessage("ent.GetRXClass().Name :" + ent.GetRXClass().Name + "\n");
 70                 if (ent is Line)
 71                 {
 72                     Line aLine = ent as Line;
 73                     aLine.ColorIndex = 1;
 74                 }
 75                 else if (ent.GetType() == typeof(Circle))
 76                 {
 77                     Circle cir = (Circle)ent;
 78                     cir.ColorIndex = 2;
 79                 }
 80                 trans.Commit();
 81             }
 82         }
 83         //--------------------------------------------------------------
 84         // 功能:实体对象的属性
 85         // 作者: 
 86         // 日期:2007-7-20
 87         // 说明:
 88         //
 89         //----------------------------------------------------------------
 90         [CommandMethod("EntPro")]
 91         public void EntPro()
 92         {
 93             
 94             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 95             ed.WriteMessage("实体对象的属性\n");
 96             PromptEntityOptions entOps = new PromptEntityOptions("选择要打开的对象\n");
 97             PromptEntityResult entRes;
 98             entRes = ed.GetEntity(entOps);
 99             if (entRes.Status != PromptStatus.OK)
100             {
101                 ed.WriteMessage("选择对象失败,退出\n");
102                 return;
103             }
104             ObjectId objId = entRes.ObjectId;
105             Database db = HostApplicationServices.WorkingDatabase;
106             using (Transaction trans = db.TransactionManager.StartTransaction())
107             {
108                 Entity ent = trans.GetObject(objId, OpenMode.ForWrite) as Entity;
109                 ed.WriteMessage("获取或设置实体的线型\n");
110                 ed.WriteMessage("实体的原先的线型为 :" + ent.Linetype + "\n");
111                 // 获取线型表记录
112                 LinetypeTable lineTypeTbl = trans.GetObject(db.LinetypeTableId, OpenMode.ForRead) as LinetypeTable;
113                 // 确保DOT线型名已经加载到当前数据库
114                 LinetypeTableRecord lineTypeTblRec = trans.GetObject(lineTypeTbl["DOT"], OpenMode.ForRead) as LinetypeTableRecord;
115                 // 设置实体的线型
116                 ent.LinetypeId = lineTypeTblRec.ObjectId;
117                 // 设置实体的线型比例
118                 ed.WriteMessage("设置实体的线型比例为2.0\n");
119                 ent.LinetypeScale = 2.0;
120                 //设置实体的可见性
121                 ent.Visible = true;
122                  //设置实体所在的层
123                 ed.WriteMessage("实体的原先所在的层为 :" + ent.Layer + "\n");
124                 ent.Layer = "layer0";
125                 trans.Commit();
126             }
127         }
128     }
129 }

 

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Text;
  4 using System.Collections;
  5 using Autodesk.AutoCAD.EditorInput;
  6 using Autodesk.AutoCAD.Runtime;
  7 using Autodesk.AutoCAD.ApplicationServices;
  8 using Autodesk.AutoCAD.DatabaseServices;
  9 using Autodesk.AutoCAD.Geometry;
 10 namespace CH05
 11 {
 12     public class Class1
 13     {
 14          //--------------------------------------------------------------
 15         // 功能:添加扩展数据XDATA
 16         // 作者: 
 17         // 日期:2007-7-20
 18         // 说明:
 19         //
 20         //----------------------------------------------------------------
 21         [CommandMethod("AddXData")]
 22         public void AddXData()
 23         {
 24             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 25             ed.WriteMessage("添加扩充数据XDATA\n");
 26             PromptEntityOptions entOps = new PromptEntityOptions("选择要打开的对象\n");
 27             PromptEntityResult entRes;
 28             entRes = ed.GetEntity(entOps);
 29             if (entRes.Status != PromptStatus.OK)
 30             {
 31                 ed.WriteMessage("选择对象失败,退出");
 32                 return;
 33             }
 34             ObjectId objId = entRes.ObjectId;
 35             Database db = HostApplicationServices.WorkingDatabase;
 36             using (Transaction trans = db.TransactionManager.StartTransaction())
 37             {
 38                 Entity ent = trans.GetObject(objId, OpenMode.ForWrite) as Entity ;
 39                 ent.ColorIndex = 1;
 40                 RegAppTable appTbl = trans.GetObject(db.RegAppTableId, OpenMode.ForWrite) as RegAppTable ;
 41                 if (!appTbl.Has("MyAppName"))
 42                 {
 43                     RegAppTableRecord appTblRcd = new RegAppTableRecord();
 44                     appTblRcd.Name = "MyAppName";
 45                     appTbl.Add(appTblRcd);
 46                     trans.AddNewlyCreatedDBObject(appTblRcd, true);
 47                 }
 48                 ResultBuffer resBuf = new ResultBuffer();//new TypedValue(1001, "MyAppName"), new TypedValue(1000, "开发部门"));
 49                 resBuf.Add(new TypedValue(1001, "MyAppName"));//注册程序名称
 50                 resBuf.Add(new TypedValue(1000 , " 张三"));//姓名
 51                 resBuf.Add(new TypedValue(1000 , " 工程部"));//部门
 52                 resBuf.Add(new TypedValue(1040, 2000.0));//薪水
 53                 ent.XData =  resBuf;
 54                 trans.Commit();
 55             }
 56  
 57         }
 58 
 59         //--------------------------------------------------------------
 60         // 功能:获取扩展数据XDATA
 61         // 作者: 
 62         // 日期:2007-7-20
 63         // 说明:
 64         //
 65         //------------------------------------------------------------
 66         [CommandMethod("GETXDATA")]
 67         public void GETXDATA()
 68         {
 69             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
 70             ed.WriteMessage("获取扩充数据XDATA\n");
 71             PromptEntityOptions entOps = new PromptEntityOptions("选择带扩展数据的对象");
 72             PromptEntityResult entRes = ed.GetEntity(entOps);
 73             if (entRes.Status != PromptStatus.OK)
 74             {
 75                 ed.WriteMessage("选择对象失败,退出");
 76                 return;
 77             }
 78             Database db = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Database;
 79             using (Transaction trans = db.TransactionManager.StartTransaction())
 80             {
 81                 Entity ent = (Entity)trans.GetObject(entRes.ObjectId, OpenMode.ForRead);
 82                 ResultBuffer resBuf = ent.XData;
 83                 if (resBuf != null)
 84                 {
 85                     //
 86                     IEnumerator iter = resBuf.GetEnumerator();
 87                     while (iter.MoveNext())
 88                     {
 89                         TypedValue tmpVal = (TypedValue)iter.Current;
 90                         ed.WriteMessage(tmpVal.TypeCode.ToString() + ":");
 91                         ed.WriteMessage(tmpVal.Value.ToString() + "\n");
 92                     }
 93                 }
 94             }
 95         }
 96         //--------------------------------------------------------------
 97         // 功能:在命名对象词典中添加数据
 98         // 作者: 
 99         // 日期:2007-7-20
100         // 说明:
101         //
102         //------------------------------------------------------------
103         [CommandMethod("AddInNOD")]
104         public void AddInNOD()
105         {
106             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
107             ed.WriteMessage("在命名对象词典中添加数据\n");
108             Database db = HostApplicationServices.WorkingDatabase;
109             using (Transaction trans = db.TransactionManager.StartTransaction())
110             {
111                 //获取命名对象词典(NOD)
112                 DBDictionary NOD =trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForWrite) as DBDictionary ;
113                 // 声明一个新的词典
114                 DBDictionary copyrightDict;
115                 // 判断是否存在COPYRIGHT词典,没有则创建
116                 try
117                 {
118                     // 获取COPYRIGHT词典
119                     copyrightDict = (DBDictionary)trans.GetObject(NOD.GetAt("COPYRIGHT"), OpenMode.ForRead);
120                 }
121                 catch
122                 {
123                     //在NOD下创建COPYRIGHT词典
124                     copyrightDict = new DBDictionary();
125                     NOD.SetAt("COPYRIGHT", copyrightDict);
126                     trans.AddNewlyCreatedDBObject(copyrightDict, true);
127                 }
128                 // 在copyrightDict中,获取或创建 "author" 词典
129                 DBDictionary authorDict;
130                 try
131                 {
132                     authorDict = (DBDictionary)trans.GetObject(copyrightDict.GetAt("Author"), OpenMode.ForWrite);
133                 }
134                 catch
135                 {
136                     authorDict = new DBDictionary();
137                     //"author" doesn't exist, create one
138                     copyrightDict.UpgradeOpen();
139                     copyrightDict.SetAt("Author", authorDict);
140                     trans.AddNewlyCreatedDBObject(authorDict, true);
141                 }
142                 // 通过Xrecord和ResultBuffer添加扩展数据
143                 Xrecord authorRec;
144                 try
145                 {
146                     authorRec = (Xrecord)trans.GetObject(authorDict.GetAt("AuthorInfo"), OpenMode.ForWrite);
147                 }
148                 catch
149                 {
150                     authorRec = new Xrecord();
151                     authorRec.Data = new ResultBuffer(new TypedValue((int)DxfCode.Text, "张三"));
152                     authorDict.SetAt("AuthorInfo", authorRec);
153                     trans.AddNewlyCreatedDBObject(authorRec, true);
154                 }
155                 trans.Commit();
156             }
157         }
158         //--------------------------------------------------------------
159         // 功能:获取命名对象词典中的数据
160         // 作者: 
161         // 日期:2007-7-20
162         // 说明:
163         //
164         //------------------------------------------------------------
165         [CommandMethod("GetInNOD")]
166         public void GetInNod()
167         {
168             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
169             ed.WriteMessage("获取命名对象词典中数据\n");
170             Database db = HostApplicationServices.WorkingDatabase;
171             using (Transaction trans = db.TransactionManager.StartTransaction())
172             {
173                 // 获取NOD 
174                 DBDictionary NOD = (DBDictionary)trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForRead, false);
175                 // 获取COPYRIGHT词典
176                 DBDictionary copyrightDict = (DBDictionary)trans.GetObject(NOD.GetAt("COPYRIGHT"), OpenMode.ForRead);
177                 // 获取Author词典
178                 DBDictionary AuthorDict = (DBDictionary)trans.GetObject(copyrightDict.GetAt("Author"), OpenMode.ForRead);
179                 // 获取AuthorInfo扩展记录Xrecord
180                 Xrecord authorXRec = (Xrecord)trans.GetObject(AuthorDict.GetAt("AuthorInfo"), OpenMode.ForRead);
181                 ResultBuffer resBuf = authorXRec.Data;
182                 TypedValue val = resBuf.AsArray()[0];
183                 ed.WriteMessage("该图纸由{0}设计\n", val.Value);
184             }
185         }
186         //--------------------------------------------------------------
187         // 功能:添加数据到数据库对象的扩展词典中
188         // 作者: 
189         // 日期:2007-7-20
190         // 说明:
191         //
192         //------------------------------------------------------------
193         [CommandMethod("AddExtDict")]
194         public void AddExtDict()
195         {
196             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
197             ed.WriteMessage("创建对象扩展词典\n");
198             PromptEntityOptions entOps = new PromptEntityOptions("选择要添加扩展数据的块\n");
199             PromptEntityResult entRes = ed.GetEntity(entOps);
200             if (entRes.Status != PromptStatus.OK)
201             {
202                 ed.WriteMessage("选择对象失败,退出");
203                 return;
204             }
205             Database db = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Database;
206             using (Transaction trans = db.TransactionManager.StartTransaction())
207             {
208                 DBObject obj = trans.GetObject(entRes.ObjectId, OpenMode.ForWrite) as DBObject;
209                 BlockReference blkRef;
210                 if (obj is BlockReference)
211                 {
212                     blkRef = obj as BlockReference;
213                 }
214                 else
215                 {
216                     return;
217                 }
218                 // 创建对象的扩展词典
219                 blkRef.CreateExtensionDictionary();
220                 DBDictionary extensionDict = (DBDictionary)trans.GetObject(blkRef.ExtensionDictionary, OpenMode.ForWrite, false);
221                
222                 // 通过Xrecord准备附加属性数据
223                 Xrecord xRec = new Xrecord();
224                 xRec.Data = new ResultBuffer(
225                   new TypedValue((int)DxfCode.Text, "张三"),// 姓名
226                   new TypedValue((int)DxfCode.Real, 1200.0),//薪水
227                   new TypedValue((int)DxfCode.Text, "技术部"));// 部门         
228                // 在扩展词典中添加扩展记录
229                 extensionDict.SetAt("EmployeeInfomation", xRec); 
230                 trans.AddNewlyCreatedDBObject(xRec, true);
231                 trans.Commit();
232             }
233         }
234 
235         //--------------------------------------------------------------
236         // 功能:获取数据库对象的扩展词典中的数据
237         // 作者: 
238         // 日期:2007-7-20
239         // 说明:
240         //
241         //------------------------------------------------------------
242         [CommandMethod("GetExtDict")]
243         public void GetExtDict()
244         {
245             Editor ed = Application.DocumentManager.MdiActiveDocument.Editor;
246             ed.WriteMessage("获取对象扩展词典信息\n");
247             PromptEntityOptions entOps = new PromptEntityOptions("选择添加了扩展数据的块\n");
248             PromptEntityResult entRes = ed.GetEntity(entOps);
249             if (entRes.Status != PromptStatus.OK)
250             {
251                 ed.WriteMessage("选择对象失败,退出");
252                 return;
253             }
254             Database db = Autodesk.AutoCAD.ApplicationServices.Application.DocumentManager.MdiActiveDocument.Database;
255             using (Transaction trans = db.TransactionManager.StartTransaction())
256             {
257                 DBObject obj = trans.GetObject(entRes.ObjectId, OpenMode.ForWrite) as DBObject;
258                 BlockReference blkRef;
259                 if (obj is BlockReference)
260                 {
261                     blkRef = obj as BlockReference;
262                 }
263                 else
264                 {
265                     ed.WriteMessage("选择对象不是块,退出\n");
266                     return;
267                 }
268                 // 创建对象的扩展词典
269                 DBDictionary extensionDict = (DBDictionary)trans.GetObject(blkRef.ExtensionDictionary, OpenMode.ForWrite, false);
270                 // 获取AuthorInfo扩展记录Xrecord
271                 Xrecord EmpXRec = (Xrecord)trans.GetObject(extensionDict.GetAt("EmployeeInfomation"), OpenMode.ForRead);
272                 ResultBuffer resBuf = EmpXRec.Data;
273                 TypedValue val = resBuf.AsArray()[0];
274                 ed.WriteMessage("是员工姓名:{0}\n", val.Value);
275                 val = resBuf.AsArray()[1];
276                 ed.WriteMessage("该员工的薪水:{0}\n", val.Value);
277                 val = resBuf.AsArray()[2];
278                 ed.WriteMessage("该员工属于:{0}\n", val.Value);
279  
280                 trans.Commit();
281             }
282         }
283     }
284 }

 

posted @ 2018-03-29 23:39  沙漠骆驼whlkx  阅读(599)  评论(0编辑  收藏  举报