GDB中创建要素数据集

简介:

转自 在geodatabase中创建要素集

 

复制代码
//在数据集中创建要素

private void menuItem25_Click(object sender, System.EventArgs e)

{

CreateFClassInPDB(@"C:\ArcGIS\ArcTutor\BuildingaGeodatabase\Montgomery.mdb");

}

public static void CreateFClassInPDB(string filePath){

string shapeFieldName="shape";

IFeatureWorkspace pFWS;

try

{

pFWS=openPDB(filePath);

//IEnumDataset pDatasets;

//pDatasets=pWS.get_Datasets(esriDatasetType.esriDTFeatureDataset);

IFeatureDataset pFeatureDataset=pFWS.OpenFeatureDataset("Water");

//MessageBox.Show(pFeatureDataset.Name);

// IDataset pDataset=pDatasets.Next();

// IFeatureDataset pFeatureDataset=pDataset as IFeatureDataset;

IGeoDataset pGeoDataset=pFeatureDataset as IGeoDataset;

IFields pFields = null;

IFieldsEdit pFieldsEdit = null;

pFields = new FieldsClass();

pFieldsEdit=pFields as IFieldsEdit;

pFieldsEdit.FieldCount_2=2;

IField pField = null;

IFieldEdit pFieldEdit = null;

//Make the shape field it will need a geometry definition, with a spatial reference

pField=new FieldClass();

pFieldEdit=pField as IFieldEdit;

pFieldEdit.Name_2=shapeFieldName;

pFieldEdit.Type_2=esriFieldType.esriFieldTypeGeometry;

IGeometryDef pGeomDef = null;

IGeometryDefEdit pGeomDefEdit = null;

pGeomDef = new GeometryDefClass();

pGeomDefEdit =pGeomDef as IGeometryDefEdit;

pGeomDefEdit.GeometryType_2=esriGeometryType.esriGeometryPolygon;

pGeomDefEdit.SpatialReference_2=pGeoDataset.SpatialReference;//get the spatial reference

pFieldEdit.GeometryDef_2=pGeomDefEdit;

//pFieldsEdit.AddField(pField);

pFieldsEdit.set_Field(0,pField);

//Add another miscellaneous text field

pField = new FieldClass();

pFieldEdit = pField as IFieldEdit;

pFieldEdit.Length_2=30;

pFieldEdit.Name_2="TextField";

pFieldEdit.Type_2=esriFieldType.esriFieldTypeString;

//pFieldsEdit.AddField(pField);

pFieldsEdit.set_Field(1,pField);

//pFeatureDataset.CreateFeatureClass("test",pFields,null,null,esriFeatureType.esriFTSimple,"Shape","");

UID pUID;

pUID = new UIDClass();

pUID.Value="esriGeoDatabase.Feature";

//pFeatureDataset.CreateFeatureClass("test",pFields,pUID,null,esriFeatureType.esriFTSimple,"Shape","");

pFeatureDataset.CreateFeatureClass("test",pFields,pUID,null,esriFeatureType.esriFTSimple,"Shape","");

MessageBox.Show("创建成功");

}

catch(Exception e){

MessageBox.Show(e.Message);

}

}

//创建shapefile文件

public static void createShapeFile(String folderName,String shapeName){

if(folderName==""||shapeName=="") return;

string shapeFieldName="shape";

try

{

IFeatureWorkspace pFWS = null;

IWorkspaceFactory pWorkspaceFactory = null;

pWorkspaceFactory = new Shapef

ileWorkspaceFactoryClass();

//if(pWorkspaceFactory.IsWorkspace(folderName)==false) return;

pFWS=pWorkspaceFactory.OpenFromFile(folderName,0) as IFeatureWorkspace;

IFields pFields = null;

IFieldsEdit pFieldsEdit = null;

pFields = new FieldsClass();

pFieldsEdit=pFields as IFieldsEdit;

IField pField = null;

IFieldEdit pFieldEdit = null;

//Make the shape field it will need a geometry definition, with a spatial reference

pField=new FieldClass();

pFieldEdit=pField as IFieldEdit;

pFieldEdit.Name_2=shapeFieldName;

pFieldEdit.Type_2=esriFieldType.esriFieldTypeGeometry;

IGeometryDef pGeomDef = null;

IGeometryDefEdit pGeomDefEdit = null;

pGeomDef = new GeometryDefClass();

pGeomDefEdit =pGeomDef as IGeometryDefEdit;

pGeomDefEdit.GeometryType_2=esriGeometryType.esriGeometryPolygon;

pGeomDefEdit.SpatialReference_2=new UnknownCoordinateSystemClass();

pFieldEdit.GeometryDef_2=pGeomDefEdit;

pFieldsEdit.AddField(pField);

//Add another miscellaneous text field

pField = new FieldClass();

pFieldEdit = pField as IFieldEdit;

pFieldEdit.Length_2=30;

pFieldEdit.Name_2="TextField";

pFieldEdit.Type_2=esriFieldType.esriFieldTypeString;

pFieldsEdit.AddField(pField);

IFeatureClass pFeatClass = null;

pFeatClass = pFWS.CreateFeatureClass(shapeName, pFields, null, null,esriFeatureType.esriFTSimple, shapeFieldName, "");

MessageBox.Show("名为"+shapeName+"的shape文件创建成功");

}

catch(Exception e){

MessageBox.Show(e.Message);

}

} 
复制代码

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。




    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/6655669.html ,如需转载请自行联系原作者


相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
Prometheus 监控 Kubernetes
深入理解Prometheus: Kubernetes环境中的监控实践
Kubernetes简介 在深入Prometheus与Kubernetes的集成之前,首先简要回顾一下Kubernetes的核心概念。Kubernetes是一个开源的容器编排平台,用于自动化容器的部署、扩展和管理。它提供了高度的可扩展性和灵活性,使得它成为微服务和云原生应用的理想选择。 核心组件 • 控制平面(Control Plane):集群管理相关的组件,如API服务器、调度器等。 • 工作节点(Nodes):运行应用容器的机器。 • Pods:Kubernetes的基本运行单位,可以容纳一个或多个容器。
227 1
|
消息中间件 存储 Java
如何在Java中实现消息队列?
如何在Java中实现消息队列?
|
人工智能
【蓝桥】蓝桥小白入门赛8
A、签到 B、结论性排序 C、找规律+暴力 D、找规律+递推+贪心 E、找规律+贪心 F、dp
158 11
|
Java Unix 测试技术
全面解析 Apache JMeter 的使用方法
Apache JMeter 是一款开源的性能测试工具,可以用于测试 Web 应用程序、FTP 服务器、数据库等各种类型的服务器。本文将以 JMeter 5.5 为例介绍 JMeter 的使用方法。
全面解析 Apache JMeter 的使用方法
|
缓存 前端开发 JavaScript
单页应用如何提高加载速度?
提高单页应用(Single Page Application,SPA)的加载速度可以从以下几个方面入手:
164 1
|
数据可视化 算法 小程序
BI系统概述(下)--BI功能规划及设计
本文为《浅谈BI系统设计》第2篇原创文章。 在上篇《BI系统概述(上)——BI价值及核心能力》我们对BI建设的必要性有所了解。 那么如何着手建设自助式BI系统呢? 接下来将从这三个方面阐述需求调研、功能规划、产品设计。
988 2
Qsort函数实现对各类型数组中元素的排序(思路简单)
Qsort函数实现对各类型数组中元素的排序(思路简单)
|
编解码 数据可视化 vr&ar
干货! 2023 VR/AR行业全貌深度剖析!
干货! 2023 VR/AR行业全貌深度剖析!
|
设计模式 算法 Java
策略模式【Java设计模式】
策略模式【Java设计模式】
127 0
算法强化每日一题--删除公共字符
算法强化每日一题--删除公共字符