ArcEngine创建内存FeatureClass

28 篇文章 0 订阅
21 篇文章 0 订阅
public static IFeatureClass CreateMemoryFeatureClass(
            ISpatialReference spatialReference, esriGeometryType geometryType, string name = "Temp")
        {
            // 创建内存工作空间
            IWorkspaceFactory pWSF = new InMemoryWorkspaceFactoryClass();
            IWorkspaceName pWSName = pWSF.Create("", "Temp", null, 0);
            IName pName = (IName)pWSName;
            IWorkspace memoryWS = (IWorkspace)pName.Open();

            IField field = new FieldClass();
            IFields fields = new FieldsClass();
            IFieldsEdit fieldsEdit = fields as IFieldsEdit;
            IFieldEdit fieldEdit = field as IFieldEdit;


            fieldEdit.Name_2 = "OBJECTID";
            fieldEdit.Type_2 = esriFieldType.esriFieldTypeOID;
            fieldEdit.IsNullable_2 = false;
            fieldEdit.Required_2 = false;
            fieldsEdit.AddField(field);

            field = new FieldClass();
            fieldEdit = field as IFieldEdit;
            IGeometryDef geoDef = new GeometryDefClass();
            IGeometryDefEdit geoDefEdit = (IGeometryDefEdit)geoDef;
            geoDefEdit.AvgNumPoints_2 = 5;
            geoDefEdit.GeometryType_2 = geometryType;
            geoDefEdit.GridCount_2 = 1;
            geoDefEdit.HasM_2 = false;
            geoDefEdit.HasZ_2 = false;
            geoDefEdit.SpatialReference_2 = spatialReference;
            fieldEdit.Name_2 = "SHAPE";
            fieldEdit.Type_2 = esriFieldType.esriFieldTypeGeometry;
            fieldEdit.GeometryDef_2 = geoDef;
            fieldEdit.IsNullable_2 = true;
            fieldEdit.Required_2 = true;
            fieldsEdit.AddField(field);

            field = new FieldClass();
            fieldEdit = field as IFieldEdit;
            fieldEdit.Name_2 = "Code";
            fieldEdit.Type_2 = esriFieldType.esriFieldTypeSmallInteger;
            fieldEdit.IsNullable_2 = true;
            fieldsEdit.AddField(field);

            //创建要素类
            IFeatureWorkspace featureWorkspace = (IFeatureWorkspace)memoryWS;
            IFeatureClass featureClass = featureWorkspace.CreateFeatureClass(
                name, fields, null, null, esriFeatureType.esriFTSimple, "SHAPE", "");

            return featureClass;
        }

ArcEngine 是一个用于开发和部署空间分析应用程序的软件开发工具包。FeatureClassArcEngine 中用于存储和管理地理要素的数据结构。叠加分析是一种空间分析方法,用于确定两个或多个地理要素之间的相互关系。 在使用 ArcEngine 进行 FeatureClass 的叠加分析时,首先需要加载要处理的地理数据,包括待叠加的 FeatureClass 和用于叠加的参考数据。然后,通过使用空间查询语言(Spatial Query Language)或 ArcEngine 提供的空间查询函数,可以根据不同的空间关系(如相交、包含、接触等)筛选出符合条件的地理要素。 然后可以根据需要进行叠加操作,常见的叠加操作包括求交、求并、求异等。可以利用 ArcEngine 提供的叠加函数,或者通过自定义算法实现叠加操作。在进行叠加操作时,需要注意数据的投影、坐标系统等因素,确保数据的一致性。 叠加分析的结果可以生成新的 FeatureClass,其中包含了叠加后的地理要素。可以根据需求,对新生成的 FeatureClass 进行后续的分析、可视化、导出等操作。 总结来说,ArcEngine 提供了丰富的工具和函数,可以通过 FeatureClass 进行叠加分析。通过加载待处理的地理数据,使用空间查询语言或空间查询函数筛选出符合条件的地理要素,然后进行叠加操作,最终生成新的 FeatureClass。这样可以方便地进行空间关系分析、数据集成等操作,帮助用户更好地理解和利用地理数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值