创建空白ShapeFile文件

从目标要素集中复制其字段,(图形字段不复制),复制到新建的空白ShapeFile文件中


<strong>      </strong>  /// <summary>
        /// 创建空白的ShpFile文件
        /// </summary>
        /// <param name="pFeaClass">源要素集</param>
        /// <param name="sShpFilePath">文件夹路径</param>
        /// <param name="sShpName">文件名称</param>
        /// <returns></returns>
        private bool CreateShpFile(IFeatureClass pFeaClass, string sShpFilePath, string sShpName, bool bIsPoint)
        {
            bool bResult = false;
            const string sShapeFieldName = "SHAPE";

            try
            {
                 打开工作空间
                IWorkspaceFactory pWSF = new ShapefileWorkspaceFactoryClass();
                IFeatureWorkspace pWS = (IFeatureWorkspace)pWSF.OpenFromFile(sShpFilePath, 0);

                 设置字段集
                IFields pFields = new FieldsClass();
                IFieldsEdit pFieldsEdit = (IFieldsEdit)pFields;

                 设置字段
                IField pField = new FieldClass();
                IFieldEdit pFieldEdit = (IFieldEdit)pField;

                 创建几何类型字段
                pFieldEdit.Name_2 = sShapeFieldName;
                pFieldEdit.Type_2 = esriFieldType.esriFieldTypeGeometry;

                IGeometryDef pGeoDef = new GeometryDefClass();
                IGeometryDefEdit pGeoDefEdit = (IGeometryDefEdit)pGeoDef;

                if (bIsPoint)
                {
                    pGeoDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPoint;
                }
                else
                {
                    pGeoDefEdit.GeometryType_2 = esriGeometryType.esriGeometryPolyline;
                }
                 获得要素集的空间参考
                ISpatialReference pSpatialRef = (pFeaClass as IGeoDataset).SpatialReference;
                pGeoDefEdit.SpatialReference_2 = pSpatialRef;

                pFieldEdit.GeometryDef_2 = pGeoDef;
                pFieldsEdit.AddField(pField);

                 从源要素集中赋值字段到新的Shp文件
                for (int i = 0; i < pFeaClass.Fields.FieldCount; i++)
                {
                    IField pTempField = pFeaClass.Fields.get_Field(i);
                    if (!pTempField.Type.Equals(esriFieldType.esriFieldTypeGeometry))
                    {
                        pFieldsEdit.AddField(pTempField);
                    }
                }

                pWS.CreateFeatureClass(sShpName, pFields, null, null, esriFeatureType.esriFTSimple, sShapeFieldName, "");
                bResult = true;
            }
            catch (Exception ex)
            {
                GtMap.GxComHelper.LogWriter.WriteLog("创建空Shape文件失败", ex);
            }

            return bResult;
        }


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值