Civil 3D 二次开发 创建Civil 3D 对象—— 01 —— 创建几何空间点
这一小节,我们创建派生于CivilCreateEntityDemo的类CivilCreateCogoPoint,来创建几何空间点。
1 创建类并添加字段及方法
首先在项目资源管理器中向本项目中添加类,名称为CivilCreateCogoPoint,转到文本编辑器,先为类添加几个字段:
01 static int PointNumber = 1;
02 static string PointName = "CogoPoint";
03 static string PointDesc = "手动创建的几何空间点";
04 CogoPointCollection cps;
这里需要注意的是关键字static,表示这几个字段为静态字段,关于静态字段的您可以查询C#相关书籍获取更多资料。在声明静态字段的同时为其赋值初始化。
接下来添加构造函数,可以在文本编辑器中直接键入构造函数,也可以通过以下方式进行添加:查看该类的类图,鼠标右键菜单中添加→构造函数。如下图:
5‑8 添加构造函数
返回文本编辑器,添加基类。在类名称后面添加:“冒号 基类名称”,之后看起来应该像下面这样:
class CivilCreateCogoPoint : CivilCreateEntityDemo
鼠标悬停在基类名称处,出现 图标后单击或直接采用快捷键Shift+Alt+Q弹出如下窗口:
5‑9 实现虚方法
单击Implement Virtual Methods,出现如下对话框,并按下图进行勾选:
5‑10 选择要实现的虚方法
现在文本编辑器中的的代码应该与下面类似:
class CivilCreateCogoPoint : CivilCreateEntityDemo { static long PointNumber = ; static string PointName = "CogoPoint"; static string PointDesc = "手动创建的几何空间点"; CogoPointCollection cps; public CivilCreateCogoPoint() //构造函数 { throw new System.NotImplementedException(); } override public void CivilCreateEntity() //重写基类方法 { throw new NotImplementedException(); } }
1 实现方法
这里需要注意的是第11行代码中的关键字override,这表示该方法将重写基类中的方法。接下来我们完成这两个方法:
首先是构造函数,有时派生类的构造函数需要调用基类的构造函数,可在派生类构造函数后面输入“冒号 base(相应的参数列表)”,本例中基类构造函数只有一个,所以只需添加“: base()”。在构造函数中添加以下代码:
01 public CivilCreateCogoPoint() : base()
02 {
03 GetString("\n输入几何空间点名称前缀", ref PointName);
04 GetString("\n输入几何空间点描述", ref PointDesc);
05 cps = civilDoc.CogoPoints;
06 }
代码第3、4行用于在类初始化过程中从命令行获取几何空间点名称前缀及描述文本。第5行,是Civil 3D二次开发中经常要用到的方法——从Civil 3D文档中获取特定的集合。下面先来看一下civilDoc这个字段,这个字段是基类的字段,为了使派生类能够访问,使用了protected关键字来修饰。其值是什么?我们可以回到基类的构造函数看一看:
civilDoc = CivilApplication.ActiveDocument;
有关更详细的信息可以回到Civil 3D对象层次结构相关章节进行再此进行消化。
字段CogoPointCollection cps为几何空间点集,我们可以直接从civilDoc中使用属性CogoPoints来获取。这是Civil 3D中各种几何获取的常用方法,在后续文章中曲面等对象集合,也是通过类似方法获取的,您要注意分析总结。
接下来我们看一看本节的核心内容,方法CivilCreateEntity,在此方法中,我们将通过在屏幕上拾取点,来创建几何空间点。
01 override public void CivilCreateEntity() 02 { 03 PromptPointOptions ppo = new PromptPointOptions("\n拾取点:"); 04 PromptPointResult ppr = ed.GetPoint(ppo); 05 if (ppr.Status != PromptStatus.OK) return; 06 Point3d pt = ppr.Value; 07 ObjectId pointId = cps.Add(pt, false); 08 using (Transaction tr = db.TransactionManager.StartTransaction()) 09 { 10 CogoPoint cp = pointId.GetObject(OpenMode.ForWrite) as CogoPoint; 11 cp.PointName = PointName + PointNumber; 12 cp.RawDescription = PointDesc; 13 tr.Commit(); 14 } 15 PointNumber++; 16 CivilCreateEntity(); 17 }
第3-6行代码之前章节多次出现,从屏幕上获取点,不再解释。
第7行代码,是Civil 3D创建对象的常用方法——很多对象的创建都是通过向其集合中添加新对象的方式来实现的。该方法返回值为创建对象的ObjectId。
第8-14行,对新创建的几何空间点的属性进行了设置,在设置前,需要开启事务将其打开,因为这个几何空间点已经添加到数据库中了。
第15行,对点号进行了递增,这个点编号与Civil 3D的点编号不同,这里只是为了演示类的静态字段如何工作,可能会引起混淆。程序加载后,用这个程序创建了多少个几何空间点,将由这个静态字段来统计。
第16行,调用自己——递归,重复执行操作,以便连续创建多个点。在拾取点的过程中,按下Esc键将退出。
完成命令,转到MyCommands类中,添加方法如下:
01 [CommandMethod("MyGroup", "CCCP", CommandFlags.Modal)]
02 public void CivilCreateCogoPoint()
03 {
04 CivilCreateEntityDemo cced = new CivilCreateCogoPoint();
05 cced.CivilCreateEntity();
06 }
注意代码的第4行,等号左侧变量类型为基类CivilCreateEntityDemo,而等号右侧却是新建的派生类CivilCreateCogoPoint。
编译加载,输入命令CCCP,输入点名称及描述,拾取点、拾取点……按下ESC。
我第一次执行命令过程中没有改变点名称及描述,在第二次执行时修改了这两个值,如果第三次执行该命令,这两个值是什么呢?您可以试验一下,然后体会静态字段的用处。命令执行完后,在工具空间中找到点编组→所有点,查看一下刚创建的几个点。
现在再次回忆一下创建几何空间点的步骤:获取CivilDocument,获取CogoPoints,然后Add。就这么简单,在MyCommands类中添加如下方法:
01 [CommandMethod("MyGroup", "Test", CommandFlags.Modal)]
02 public void Test()
03 {
04 CivilApplication.ActiveDocument.CogoPoints.Add(new Point3d(),false);
05 }
编译加载,输入命令,test,看能否在原点创建一个几何空间点。方法中的代码是不是只有一行?
文档→集合→Add,记住了吗?
对比一下AutoCAD对象的创建过程,Civil 3D对象的创建是不是很简单呢?
有没有更多的方法创建几何空间点呢?来让我们查看一下Civil 3D .NET API Reference,能够找到如下信息,这里有6种重载的方法,我们可以根据不同的情况选择适合的方法,具体的用法查看API Reference,以后类似情况将不再介绍。
5‑12 CogoPointCollection.Add重载方法
问题:有哪些对象的创建方法与创建几何空间点类似?
Civil 3D 二次开发 创建Civil 3D 对象—— 01 —— 创建几何空间点的更多相关文章
- 学习 Civil 3D二次开发从哪儿开始?
1.1 从哪儿开始 对于多数的工程设计人员,不完全具备上节所述的各种条件.对于Civil 3D的应用可能比较熟悉:但对于计算机语言,只限于上学时所学的一点基础知识,步入工作岗位后与计算机语言基本无缘: ...
- Civil 3D 二次开发 创建Civil 3D 对象—— 00 ——
本节中我们通过创建几何空间点.曲面和采样线了解Civil 3D对象的创建方法.因Civil 3D对象的创建方法相比AutoCAD对象创建要简单的多,比如创建一个几何空间点,最简单的情况采用一行代码(没 ...
- Civil 3D 二次开发 创建AutoCAD对象—— 00 ——
不积跬步无以至千里,不积小流无以成江海.虽然创建一条直线.添加一个图层这样的小程序没有什么实际意义(内部命令很简单就可以完成),但对于初学二次开发的您来说,这可是一大步,这一步跨出去,您就跨进了二次开 ...
- Civil 3D 二次开发 事务
事务,一般是指要做的或所做的事情.在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit). 对于初学者来说,从字面上难以理解什么是事务.下面我试着通过讲述事务的作用及特性来帮 ...
- Java开发学习教程之对象的创建与使用
java面向对象中的对象创建与使用.类是对象的抽象,为对象定义了属性和行为,但类本身既不带任何数据,也不存在于内存空间中.而对象是类的一个具体存在,既拥有独立的内存空间,也存在独特的属性和行为,属性还 ...
- Civil 3D 二次开发 创建AutoCAD对象—— 01 —— 创建直线
在方法CreateLine内完成以下代码: 01 public void CreateLine() 02 { 03 PromptPointOptions ppo = new PromptPointOp ...
- Civil 3D 二次开发 名称模板不能正常工作
using Autodesk.AECC.Interop.Land; using Autodesk.AECC.Interop.UiLand; using Autodesk.AutoCAD.Applica ...
- Civil 3D 二次开发 新建CLR项目出现错误C2143
新建CLR项目出现错误C2143 按照Objectarx Training创建.net混合项目,编译时出现一下错误: 原因不明: 解决方法: 在Stdafx.h文件中添加: #define WIN32 ...
- Civil 3D 二次开发 翻转曲面高程分析颜色
不解释,直接上代码及截图. [CommandMethod("RvsSEA")] public void ReverseSurfaceElevationAnalysis() { Ci ...
随机推荐
- Android so注入(inject)和Hook技术学习(二)——Got表hook之导入表hook
全局符号表(GOT表)hook实际是通过解析SO文件,将待hook函数在got表的地址替换为自己函数的入口地址,这样目标进程每次调用待hook函数时,实际上是执行了我们自己的函数. GOT表其实包含了 ...
- 【转】MySQL中的行级锁,表级锁,页级锁
在计算机科学中,锁是在执行多线程时用于强行限制资源访问的同步机制,即用于在并发控制中保证对互斥要求的满足. 在数据库的锁机制中介绍过,在DBMS中,可以按照锁的粒度把数据库锁分为行级锁(INNODB引 ...
- java OOM还在看log日志,兄弟你错的的很严重,正确方式是分析dump文件
目录 OOM异常--intsmaze 正确姿势dump文件分析--intsmaze 正确的姿势--intsmaze dump丢失打印--intsmaze 哪些内存溢出会产生dump文件--intsma ...
- Appium-超过60s的应用场景如何处理
前言: 最近在搞appium自动化项目,遇到超过60s的应用场景时,总是报错报错.如何解决呢?见下文. 报错信息: 2018-05-21 14:03:42:253 - [HTTP] <-- PO ...
- Docker镜像的修改和自定义
一.docker镜像的更新 (1)启动镜像,写入一些文件或者更新软件 docker run -it 3afd47092a0e[root@44652ba46352 /]# ls (2)更新镜像 dock ...
- [LeetCode] Rank Scores -- 数据库知识(mysql)
Write a SQL query to rank scores. If there is a tie between two scores, both should have the same ra ...
- H5 59-浮动元素的脱标
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- hibernate在写cfg配置文件自动创建表时报错org.hibernate.MappingException: Could not get constructor for org.hibernate.persister.entity.SingleTableEntityPersister
在用hibernate框架时,写cfg文件,想自动生成表时,一般写<property name="hibernate.hbm2ddl.auto">create</ ...
- iOS NSDictionary JSON 相互转换
/*! * @brief 把格式化的JSON格式的字符串转换成字典 * @param jsonString JSON格式的字符串 * @return 返回字典 */ + (NSDictionary * ...
- Solrcloud(Solr集群)
Solrcloud(Solr集群) Solrcloud介绍: SolrCloud(solr集群)是Solr提供的分布式搜索方案. 当你需要大规模,容错,分布式索引和检索能力时使用SolrCloud. ...