C#自定义数据详细介绍
2010-09-24 14:52
218 查看
C#语言有很多值得学习的地方,这里我们主要介绍C#自定义数据,包括介绍每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典等方面。
我们将创建一个新的字典对象,它用来表示我们雇员就职的 ‘Acme 公司‘(呵呵,当然是虚构的一家公司)的部门。这个“部门”字典对象将包含一个表示部门经理的记录。我们还会加入代码到雇员创建过程,这个过程会加入一个索引到雇员工作的部门。
我们要说明的是如何在DWG文件中创建C#自定义数据,包括“每个图形”的C#自定义数据和“每个实体”的C#自定义数据。“每个图形”的C#自定义数据是指只在整个图形中加入一次的数据,它表示对象可以引用的单一类型或特性。“每个实体”的C#自定义数据是指是为特定的对象或数据库中的实体加入的数据。
在下面的示例中,我们将加入“每个图形”的C#自定义数据到命名对象字典(简称NOD)。NOD存在于每一个DWG文件中。“每个实体”的C#自定义数据加入到一个名为“扩展字典”的字典(可选)中,它表示每一个雇员。每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典。而在我们的示例中将包含这种C#自定义数据如名字、薪水和部门。
因此这一章的重点是字典对象和扩展记录(XRecord),它们是我们用来表示C#自定义数据的容器。
首先让我们来创建表示公司的条目。在本章的前几个步骤中,我们将创建如下所示的部门层次结构:
◆NOD-命名对象字典
◆ACME_DIVISION-自定义公司字典
◆销售(Sales) -部门字典
◆部门经理-部门条目
请打开Lab4文件夹下的Lab4工程,或接着Lab3的代码。
< !--[if !supportLists]-->1) < !--[endif]-->我们首先要做的是定义一个新的函数,它用来在命名对象字典(NOD)中创建公司字典对象。为这个函数取名为 CreateDivision(),,并使用命令属性来定义CREATEDIVISION命令。
下面是这个函数的代码,它的形式非常简单,只是用来在NOD中创建一个ACME_DIVISION(用来表示公司)
[CommandMethod("CreateDivision")] public void CreateDivision() { Database db = HostApplicationServices.WorkingDatabase; Transaction trans = db.TransactionManager.StartTransaction(); try { //首先,获取NOD…… DBDictionary NOD = (DBDictionary)trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForWrite); //定义一个公司级别的字典 DBDictionary acmeDict; try { //如果ACME_DIVISION不存在,则转到catch块,这里什么也不做 acmeDict = (DBDictionary)trans.GetObject(NOD.GetAt("ACME_DIVISION"), OpenMode.ForRead); } catch { //如果ACME_DIVISION不存在,则创建它并把它加入到NOD中…… acmeDict = new DBDictionary(); NOD.SetAt("ACME_DIVISION", acmeDict); trans.AddNewlyCreatedDBObject(acmeDict, true); } trans.Commit(); } finally { trans.Dispose(); } }
C#语言有很多值得学习的地方,这里我们主要介绍C#自定义数据,包括介绍每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典等方面。
我们将创建一个新的字典对象,它用来表示我们雇员就职的 ‘Acme 公司‘(呵呵,当然是虚构的一家公司)的部门。这个“部门”字典对象将包含一个表示部门经理的记录。我们还会加入代码到雇员创建过程,这个过程会加入一个索引到雇员工作的部门。
我们要说明的是如何在DWG文件中创建C#自定义数据,包括“每个图形”的C#自定义数据和“每个实体”的C#自定义数据。“每个图形”的C#自定义数据是指只在整个图形中加入一次的数据,它表示对象可以引用的单一类型或特性。“每个实体”的C#自定义数据是指是为特定的对象或数据库中的实体加入的数据。
在下面的示例中,我们将加入“每个图形”的C#自定义数据到命名对象字典(简称NOD)。NOD存在于每一个DWG文件中。“每个实体”的C#自定义数据加入到一个名为“扩展字典”的字典(可选)中,它表示每一个雇员。每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典。而在我们的示例中将包含这种C#自定义数据如名字、薪水和部门。
因此这一章的重点是字典对象和扩展记录(XRecord),它们是我们用来表示C#自定义数据的容器。
首先让我们来创建表示公司的条目。在本章的前几个步骤中,我们将创建如下所示的部门层次结构:
◆NOD-命名对象字典
◆ACME_DIVISION-自定义公司字典
◆销售(Sales) -部门字典
◆部门经理-部门条目
请打开Lab4文件夹下的Lab4工程,或接着Lab3的代码。
< !--[if !supportLists]-->1) < !--[endif]-->我们首先要做的是定义一个新的函数,它用来在命名对象字典(NOD)中创建公司字典对象。为这个函数取名为 CreateDivision(),,并使用命令属性来定义CREATEDIVISION命令。
下面是这个函数的代码,它的形式非常简单,只是用来在NOD中创建一个ACME_DIVISION(用来表示公司)
[CommandMethod("CreateDivision")] public void CreateDivision() { Database db = HostApplicationServices.WorkingDatabase; Transaction trans = db.TransactionManager.StartTransaction(); try { //首先,获取NOD…… DBDictionary NOD = (DBDictionary)trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForWrite); //定义一个公司级别的字典 DBDictionary acmeDict; try { //如果ACME_DIVISION不存在,则转到catch块,这里什么也不做 acmeDict = (DBDictionary)trans.GetObject(NOD.GetAt("ACME_DIVISION"), OpenMode.ForRead); } catch { //如果ACME_DIVISION不存在,则创建它并把它加入到NOD中…… acmeDict = new DBDictionary(); NOD.SetAt("ACME_DIVISION", acmeDict); trans.AddNewlyCreatedDBObject(acmeDict, true); } trans.Commit(); } finally { trans.Dispose(); } }
我们将创建一个新的字典对象,它用来表示我们雇员就职的 ‘Acme 公司‘(呵呵,当然是虚构的一家公司)的部门。这个“部门”字典对象将包含一个表示部门经理的记录。我们还会加入代码到雇员创建过程,这个过程会加入一个索引到雇员工作的部门。
我们要说明的是如何在DWG文件中创建C#自定义数据,包括“每个图形”的C#自定义数据和“每个实体”的C#自定义数据。“每个图形”的C#自定义数据是指只在整个图形中加入一次的数据,它表示对象可以引用的单一类型或特性。“每个实体”的C#自定义数据是指是为特定的对象或数据库中的实体加入的数据。
在下面的示例中,我们将加入“每个图形”的C#自定义数据到命名对象字典(简称NOD)。NOD存在于每一个DWG文件中。“每个实体”的C#自定义数据加入到一个名为“扩展字典”的字典(可选)中,它表示每一个雇员。每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典。而在我们的示例中将包含这种C#自定义数据如名字、薪水和部门。
因此这一章的重点是字典对象和扩展记录(XRecord),它们是我们用来表示C#自定义数据的容器。
首先让我们来创建表示公司的条目。在本章的前几个步骤中,我们将创建如下所示的部门层次结构:
◆NOD-命名对象字典
◆ACME_DIVISION-自定义公司字典
◆销售(Sales) -部门字典
◆部门经理-部门条目
请打开Lab4文件夹下的Lab4工程,或接着Lab3的代码。
< !--[if !supportLists]-->1) < !--[endif]-->我们首先要做的是定义一个新的函数,它用来在命名对象字典(NOD)中创建公司字典对象。为这个函数取名为 CreateDivision(),,并使用命令属性来定义CREATEDIVISION命令。
下面是这个函数的代码,它的形式非常简单,只是用来在NOD中创建一个ACME_DIVISION(用来表示公司)
[CommandMethod("CreateDivision")] public void CreateDivision() { Database db = HostApplicationServices.WorkingDatabase; Transaction trans = db.TransactionManager.StartTransaction(); try { //首先,获取NOD…… DBDictionary NOD = (DBDictionary)trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForWrite); //定义一个公司级别的字典 DBDictionary acmeDict; try { //如果ACME_DIVISION不存在,则转到catch块,这里什么也不做 acmeDict = (DBDictionary)trans.GetObject(NOD.GetAt("ACME_DIVISION"), OpenMode.ForRead); } catch { //如果ACME_DIVISION不存在,则创建它并把它加入到NOD中…… acmeDict = new DBDictionary(); NOD.SetAt("ACME_DIVISION", acmeDict); trans.AddNewlyCreatedDBObject(acmeDict, true); } trans.Commit(); } finally { trans.Dispose(); } }
C#语言有很多值得学习的地方,这里我们主要介绍C#自定义数据,包括介绍每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典等方面。
我们将创建一个新的字典对象,它用来表示我们雇员就职的 ‘Acme 公司‘(呵呵,当然是虚构的一家公司)的部门。这个“部门”字典对象将包含一个表示部门经理的记录。我们还会加入代码到雇员创建过程,这个过程会加入一个索引到雇员工作的部门。
我们要说明的是如何在DWG文件中创建C#自定义数据,包括“每个图形”的C#自定义数据和“每个实体”的C#自定义数据。“每个图形”的C#自定义数据是指只在整个图形中加入一次的数据,它表示对象可以引用的单一类型或特性。“每个实体”的C#自定义数据是指是为特定的对象或数据库中的实体加入的数据。
在下面的示例中,我们将加入“每个图形”的C#自定义数据到命名对象字典(简称NOD)。NOD存在于每一个DWG文件中。“每个实体”的C#自定义数据加入到一个名为“扩展字典”的字典(可选)中,它表示每一个雇员。每一个由DBObject派生的对象都拥有存储C#自定义数据的扩展字典。而在我们的示例中将包含这种C#自定义数据如名字、薪水和部门。
因此这一章的重点是字典对象和扩展记录(XRecord),它们是我们用来表示C#自定义数据的容器。
首先让我们来创建表示公司的条目。在本章的前几个步骤中,我们将创建如下所示的部门层次结构:
◆NOD-命名对象字典
◆ACME_DIVISION-自定义公司字典
◆销售(Sales) -部门字典
◆部门经理-部门条目
请打开Lab4文件夹下的Lab4工程,或接着Lab3的代码。
< !--[if !supportLists]-->1) < !--[endif]-->我们首先要做的是定义一个新的函数,它用来在命名对象字典(NOD)中创建公司字典对象。为这个函数取名为 CreateDivision(),,并使用命令属性来定义CREATEDIVISION命令。
下面是这个函数的代码,它的形式非常简单,只是用来在NOD中创建一个ACME_DIVISION(用来表示公司)
[CommandMethod("CreateDivision")] public void CreateDivision() { Database db = HostApplicationServices.WorkingDatabase; Transaction trans = db.TransactionManager.StartTransaction(); try { //首先,获取NOD…… DBDictionary NOD = (DBDictionary)trans.GetObject(db.NamedObjectsDictionaryId, OpenMode.ForWrite); //定义一个公司级别的字典 DBDictionary acmeDict; try { //如果ACME_DIVISION不存在,则转到catch块,这里什么也不做 acmeDict = (DBDictionary)trans.GetObject(NOD.GetAt("ACME_DIVISION"), OpenMode.ForRead); } catch { //如果ACME_DIVISION不存在,则创建它并把它加入到NOD中…… acmeDict = new DBDictionary(); NOD.SetAt("ACME_DIVISION", acmeDict); trans.AddNewlyCreatedDBObject(acmeDict, true); } trans.Commit(); } finally { trans.Dispose(); } }
相关文章推荐
- Docker 数据卷,数据卷容器详细介绍
- Xceed WinForm数据表格控件Xceed Grid For .NET详细介绍
- [转]详细介绍ASP.NET页面间数据传递的方法
- Delphi数据类型详细介绍
- 操作系统大型实验进展(5)-----C/C++语言中time_t数据类型详细介绍
- 今日内容介绍 1、自定义类型的定义及使用 2、自定义类的内存图 3、ArrayList集合的基本功能 4、随机点名器案例及库存案例代码优化 ###01引用数据类型_类 * A: 数据类型
- 详细介绍ASP.NET中WebClient方法示例下载远程数据
- android 自定义控件 自定义属性详细介绍
- ORACLE中的各种数据类型详细的介绍
- fputc,fgetc,fputs,fgets,fwrite,fread写入或读取数据文件详细介绍
- Python基本数据类型详细介绍
- 数据泵导入导出详细介绍
- 一是关于怎样找出和去除重复数据,这在另一个帖子利已有详细介绍。二是关于找出某一列里最大或最小的前几个,或是大于或小于某一个值(最大值或平均值)的数据
- ORACLE中的各种数据类型详细的介绍
- C语言中time_t数据类型详细介绍
- 【抓包工具】Wireshark(详细介绍与TCP三次握手数据分析)
- HTML5的自定义属性data-*详细介绍和JS操作实例
- 编写Smarty插件在模板中直接加载数据的详细介绍
- JSP第四篇【EL表达式介绍、获取各类数据、11个内置对象、执行运算、回显数据、自定义函数、fn方法库】
- 通用存取不同数据库数据dotConnect Universal 控件详细介绍