C#+ ArcEngine 调用GP工具示例

记得添加引用:
using ESRI.ArcGIS.Geoprocessing;
……
引用这部分少什么添加什么,很简单

相交

    public IFeatureClass Intersect2(IFeatureClass A,IFeatureClass B,string name)
    {
        Geoprocessor geoprocessor = new Geoprocessor();
        geoprocessor.OverwriteOutput = true;
        
        IGpValueTableObject gpValueTableObject = new GpValueTableObjectClass();//提供对分派值表对象的访问,理解为添加到表中
        gpValueTableObject.SetColumns(2);
        object o1 = A;//输入IFeatureClass 1 
        object o2 = B;//输入IFeatureClass 2 
        gpValueTableObject.AddRow(ref o1);
        gpValueTableObject.AddRow(ref o2);

        Intersect intersect = new Intersect();
        intersect.in_features = gpValueTableObject;
        intersect.out_feature_class = defaultpath + name;

        geoprocessor.Execute(intersect, null);

        //先保存再读取,还有其他的方法吗?欢迎留言
        Helper helper = new Helper();
        IFeatureClass AB = helper.ReadShpFromFile(defaultpath + name);

        return AB;
    }

按属性选择数据

        /// <summary>
        /// 因为项目需要,这里示意的是从shp图层中选出myclass字段值为field且Area字段值在low-upper范围内的要素,并保存在name文件(路径)中。
        /// </summary>
        /// <param name="shp"></param>
        /// <param name="field"></param>
        /// <param name="low"></param>
        /// <param name="upper"></param>
        /// <param name="name"></param>
        /// <returns></returns>
        public IFeatureClass SelectByFieldAndExplore(IFeatureClass shp,string field,double low,double upper,string name  )
        {
            Geoprocessor geoprocessor = new Geoprocessor();
            geoprocessor.OverwriteOutput = true;

            Select selected = new Select();
            selected.in_features = shp;
            selected.out_feature_class = defaultpath + name;
            selected.where_clause ="\"myclass\" = \'"+field + "\'AND \"Area\">= "+ low + "AND \"Area\"<= "+ upper;   

            //如果出错,try 的这部分将打印出错误到底在哪
             try
            {
                geoprocessor.Execute(selected, null);
            }
            catch (System.Runtime.InteropServices.COMException e)
            {
                string message = "";
                for (int i = 0; i < geoprocessor.MessageCount; i++)
                {
                    message += geoprocessor.GetMessage(i) + "\r\n";
                }
                MessageBox.Show(message + e.ToString());
            }

            //先保存再读取
            Helper helper = new Helper();
            IFeatureClass slt = helper.ReadShpFromFile(defaultpath + name);

            return slt;
        }

擦除

        public IFeatureClass Eraser(IFeatureClass A, IFeatureClass B,string name)
        {
            Geoprocessor geoprocessor = new Geoprocessor();
            geoprocessor.OverwriteOutput = true;

            Erase erase = new Erase();
            erase.in_features = A;
            erase.erase_features = B;
            erase.out_feature_class =defaultpath+name ;

            try
            {
                geoprocessor.Execute(erase, null);
            }
            catch (System.Runtime.InteropServices.COMException e)
            {
                string message = "";
                for (int i = 0; i < geoprocessor.MessageCount; i++)
                {
                    message += geoprocessor.GetMessage(i) + "\r\n";
                }
                MessageBox.Show(message + e.ToString());
            }
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这是16年5月份编辑的一份比较杂乱适合自己观看的学习记录文档,今天18年5月份再次想写文章,发现简书还为我保存起的...
    Jenaral阅读 2,859评论 2 9
  • ArcGIS是由Esri公司出品的一系列地理信息系统(GIS)软件的总称。是一个综合、集成的、可伸缩的产品系统,以...
    朱古力的简书阅读 2,367评论 0 0
  • 写在前面 WebGIS 开发基础之 Leaflet 1. GIS Web开发基本概念: GIS、Map、Layer...
    六小六的世界阅读 4,710评论 0 19
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,657评论 0 4
  • ArcGIS如何将图层转换为WGS84下的高斯克吕格投影? ArcGIS中的高斯克吕格投影是没有WGS1984这个...
    onepedalo阅读 4,573评论 0 1