- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第5章 创建基本图形对象
第5章 创建基本图形对象 主讲人:李恒凯 联系电话电子邮件:giskai@126.com QQ 1 直线 说明 思路 步骤 效果 小结 说明 创建基本图形对象,从创建直线开始。 本节程序运行的结果是在AutoCAD 2008中创建两条直线。 通过这个程序,我们将要开始了解AutoCAD数据库的基本结构,掌握各种图形对象的创建方法。 思路 .NET的操作机理是完全不同于VBA的,但和传统的ObjectARX却很相似。 表。表是数据库的组成单位,一个数据库至少包含一个表。 ·记录。记录是表的组成单位,一个表可能包含多条记录,也可能不包含任何记录。 具体思路 步骤 [CommandMethod(FirstLine)] public void TestLine() { Database db = HostApplicationServices.WorkingDatabase; Point3d pt1 = new Point3d(300, 100, 0); Point3d pt2 = new Point3d(900, 500, 0); Line lineEnt = new Line(pt1, pt2); 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); btr.AppendEntity(lineEnt); trans.AddNewlyCreatedDBObject(lineEnt, true); trans.Commit(); } } 步骤 在.NET中,有关数据库的操作都是通过事务处理进行的。 在内存中创建直线后,在图形窗口并不能显示出来,只有把直线加到图形数据库中,才能看到。 事务处理Transaction类的GetObject函数的作用是获取驻留在AutoCAD数据库中的对象,因为这些对象是不能直接访问的。 步骤 启动AutoCAD后,其块表中会自动生成三条记录,分别表示模型空间和两个布局。 为提高代码的重用性,可以把代码重新组织,封装成函数。 改进后代码 public static ObjectId AddLine(Point3d pt1, Point3d pt2) { Line et = new Line(pt1, pt2); ObjectId etID = AppendEntity(et); return etID; } public static ObjectId AppendEntity(Entity et) { Database db = HostApplicationServices.WorkingDatabase; ObjectId etID; 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); etID = btr.AppendEntity(et);
文档评论(0)