sde

ArcEngine 导出图层(shp)

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/Good_liu_simalb/archive/2010/07/21/5752967.aspx

private void shpToolStripMenuItem_Click(object sender, EventArgs e)         {             SaveFileDialog dlg = new SaveFileDialog();             if (DialogResult.OK == dlg.ShowDialog())             {                 string file = dlg.FileName.Substring(0, dlg.FileName.LastIndexOf('\\'));                 if (!System.IO.Directory.Exists(file))                 {                     System.IO.Directory.CreateDirectory(file);                 }                 try                 {                     ILayer pLayer = axMapControl1.Map.get_Layer(0);                     if (pLayer != null)                     {                         IFeatureLayer pFeatureLayer = pLayer as IFeatureLayer;                         if (pFeatureLayer.Visible)                         {                             ExportFeature(pFeatureLayer.FeatureClass,dlg.FileName);                         }                     }                     MessageBox.Show("导出成功");                 }                 catch                 {                     MessageBox.Show("导出失败!");                 }             }         }

        private void ExportShp()         {             SaveFileDialog dlg = new SaveFileDialog();             if (DialogResult.OK == dlg.ShowDialog())             {                 string file = dlg.FileName.Substring(0, dlg.FileName.LastIndexOf('\\'));                 if (!System.IO.Directory.Exists(file))                 {                     System.IO.Directory.CreateDirectory(file);                 }                 try                 {                     ILayer pLayer = axMapControl1.Map.get_Layer(1);                     if (pLayer != null)                     {                         IFeatureLayer pFeatureLayer = pLayer as IFeatureLayer;                         if (pFeatureLayer.Visible)                         {                             ExportFeature(pFeatureLayer.FeatureClass, dlg.FileName);                         }                     }                     MessageBox.Show("导出成功");                 }                 catch                 {                     MessageBox.Show("导出失败!");                 }             }         }

        public void ExportFeature(IFeatureClass pInFeatureClass,string pPath)         {             // create a new Access workspace factory                    IWorkspaceFactory pWorkspaceFactory = new ShapefileWorkspaceFactoryClass();             string parentPath=pPath.Substring(0, pPath.LastIndexOf('\\'));             string fileName= pPath.Substring(pPath.LastIndexOf('\\') + 1, pPath.Length - pPath.LastIndexOf('\\') - 1);             IWorkspaceName pWorkspaceName = pWorkspaceFactory.Create(parentPath,fileName, null, 0);             // Cast for IName                    IName name = (IName)pWorkspaceName;             //Open a reference to the access workspace through the name object                    IWorkspace pOutWorkspace = (IWorkspace)name.Open();

            IDataset pInDataset = pInFeatureClass as IDataset;             IFeatureClassName pInFCName = pInDataset.FullName as IFeatureClassName;             IWorkspace pInWorkspace = pInDataset.Workspace;             IDataset pOutDataset = pOutWorkspace as IDataset;             IWorkspaceName pOutWorkspaceName = pOutDataset.FullName as IWorkspaceName;             IFeatureClassName pOutFCName = new FeatureClassNameClass();             IDatasetName pDatasetName = pOutFCName as IDatasetName;             pDatasetName.WorkspaceName = pOutWorkspaceName;             pDatasetName.Name = pInFeatureClass.AliasName;             IFieldChecker pFieldChecker = new FieldCheckerClass();             pFieldChecker.InputWorkspace = pInWorkspace;             pFieldChecker.ValidateWorkspace = pOutWorkspace;             IFields pFields = pInFeatureClass.Fields;             IFields pOutFields;             IEnumFieldError pEnumFieldError;             pFieldChecker.Validate(pFields, out pEnumFieldError, out pOutFields);             IFeatureDataConverter pFeatureDataConverter = new FeatureDataConverterClass(); pFeatureDataConverter.ConvertFeatureClass(pInFCName, null, null, pOutFCName, null, pOutFields, "", 100, 0);         }

转载于:https://www.cnblogs.com/cuizhiyuan/p/4599612.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值