首页 > 其他分享 >ArcEngine|使用GP工具实现缓冲区分析与叠置分析

ArcEngine|使用GP工具实现缓冲区分析与叠置分析

时间:2023-04-18 14:24:44浏览次数:41  
标签:GP Text private pMap 缓冲区 null Click ArcEngine

ArcEngine|使用GP工具实现缓冲区分析与叠置分析

GP工具简介

地理处理是ArcGIS 的一个重要概念,其目的是便于用户自动执行GIS的空间分析和建模任务。地理处理工具是将GIS中常用、可重复的操作,如提取与叠加数据、更改地图投影等封装成一个具有参数输人输出的交互式图形界面。地理处理通过脚本将一系列的工具按照一定的操作顺序结合在一起,共同完成一项地理处理任务。其工具都储存在工具箱中,ArcGIS提供了数百种工具,并根据功能将它们分别放到了十余个工具箱中。ArcToolbox是所有工具的集合, 提供工具运行的环境。在ArcGIS Engine编程过程中,可以通过调用GP工具来实现某些常用的功能。

调用GP工具主要应用了Geoprocessor类,这个类也可以调用人们自定义的工具。在使用Geoprocessor 类时,需要首先定义一个Geoprocessor 对象, Geoprocessor是简化调用Geoprocessing工具任务的主要对象。这个对象是执行ArcGIS 中任何Geoprocessing 工具的唯一访问点,它是一个粗粒度对象, 包含了许多属性和方法,在设置完相关的参数后,则通过Geoprocessor 的Excute函数来执行,Excute方法中需要一个操作对象作为参数,如lntersect、Clip 等,具体包含哪些操作类,可通过ArcToolBox和Esri的帮助文档查找。

缓冲区分析

(1)建立【缓冲区分析】窗体

该窗体用于显示及设置输入图层、缓冲半径、融合类型、输出路径以及执行缓冲区分析功能的按钮等,其界面入下图所示:

image-20230413234538280

(2)功能实现的核心代码

public partial class BufferAnalysisTool : Form
{
    public IMap pMap { get; set; }
    public AxMapControl mapControl { get; set; }
    public BufferAnalysisTool()
    {
        InitializeComponent();
    }

    private void BufferAnalysisTool_Load(object sender, EventArgs e)
    {
        pMap = mapControl.Map;
        //向图层comboBox1中预置噪音来源
        if (pMap.LayerCount > 0)
        {
            for (int i = 0; i < pMap.LayerCount; i++)
            {
                ILayer pLayer = pMap.get_Layer(i);
                if (pLayer != null)
                {
                    if (pLayer is IFeatureLayer)
                    {
                        comboBox_InputDataset.Items.Add(pLayer.Name);
                    }
                }
            }
            comboBox_InputDataset.SelectedIndex = 0;

            DistanceTextBox.Text = "500";
            this.comboBox1.Items.Add("NONE");//选择项1
            this.comboBox1.Items.Add("ALL");
            comboBox1.SelectedIndex = 0;
            textEdit_Output.Text = System.Environment.CurrentDirectory + "buffer.shp";
        }
        else return;
    }

    private void button3_Click(object sender, EventArgs e)
    {
        this.Close();
    }

    private void button1_Click(object sender, EventArgs e)
    {
        SaveFileDialog flg = new SaveFileDialog();
        flg.Title = "保存路径";
        flg.Filter = "ShpFile(*shp)|*.shp";
        flg.ShowDialog();

        textEdit_Output.Text = flg.FileName;
    }

    private ILayer GetLayerByName(IMap pMap, string layerName)
    {
        ILayer pLayer = null;
        ILayer tempLayer = null;
        try
        {
            for (int i = 0; i < pMap.LayerCount; i++)
            {
                tempLayer = pMap.Layer[i];
                if (tempLayer.Name.ToUpper() == layerName.ToUpper())      //判断名字大写是否一致
                {
                    pLayer = tempLayer;
                    break;
                }
            }
        }
        catch (Exception ex)
        {

            MessageBox.Show(ex.Message);
        }
        return pLayer;
    }

    private void button2_Click(object sender, EventArgs e)
    {
        try
        {
            ILayer inputDataset = GetLayerByName(pMap, comboBox_InputDataset.Text.Trim());
            IFeatureLayer inputLayer = inputDataset as IFeatureLayer;
            //缓冲区分析-GP工具调用
            Geoprocessor gp = new Geoprocessor();
            gp.OverwriteOutput = true;
            ESRI.ArcGIS.AnalysisTools.Buffer pBuffer = new ESRI.ArcGIS.AnalysisTools.Buffer();
            pBuffer.in_features = inputLayer;
            //设置生成结果存储路径
            pBuffer.out_feature_class = textEdit_Output.Text;
            //设置缓冲区距离
            string buffer_distance = DistanceTextBox.Text + " Meters";
            pBuffer.buffer_distance_or_field = buffer_distance;
            pBuffer.dissolve_option = comboBox1.Text;
            //执行缓冲区分析
            gp.Execute(pBuffer, null);
            //将生成结果添加到地图中
            string pPath = System.IO.Path.GetDirectoryName(textEdit_Output.Text); //获取文件路径
            string pName = System.IO.Path.GetFileName(textEdit_Output.Text); //获取文件名
            this.mapControl.AddShapeFile(pPath, pName);
            this.mapControl.MoveLayerTo(1, 0);
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message);
        }
    }
}

(3)在 menuStrip 中添加一个geoProcessing选项,并在其子选项中BufferTool选项,为其绑定 Click 事件。在 Click 事件处理方法中添加代码,显示【裁剪】窗体。

private void bufferToolToolStripMenuItem_Click(object sender, EventArgs e)
{
    GeoProcessing.BufferAnalysisTool BF = new GeoProcessing.BufferAnalysisTool();
    BF.mapControl = this.axMapControl1;
    BF.ShowDialog();
}

叠置分析

(1)建立叠置分析窗体

该窗体用于显示及设置与参与裁剪的数据、裁剪后输出的数据路径以及执行裁剪功能的按钮等,其界面入下图所示:

image-20230414002040336

(2)在叠置分析窗体中完成裁剪功能的代码如下:

public partial class OverlayAnalysisTool : Form
{
    public OverlayAnalysisTool()
    {
        InitializeComponent();
    }

    //定义全局变量
    public IMap pMap { get; set; }
    public AxMapControl mapControl { get; set; }

    private void OverlayAnalysisTool_Load(object sender, EventArgs e)
    {
        try
        {
            pMap = mapControl.Map;
            if (pMap == null)
                return;
            //清空combobox
            comboBox_InputDataset.Items.Clear();
            comboBox_ClipDataset.Items.Clear();

            string layerName;   //用于储存图层名字

            for (int i = 0; i < pMap.LayerCount; i++)
            {
                layerName = pMap.Layer[i].Name;
                comboBox_InputDataset.Items.Add(layerName);
                comboBox_ClipDataset.Items.Add(layerName);
            }

        }
        catch (Exception ex)
        {

            MessageBox.Show(ex.Message);
        }
    }

    private void button2_OK_Click(object sender, EventArgs e)
    {

        if (pMap == null)
            return;
        //获取数据集
        ILayer inputDataset = GetLayerByName(pMap, comboBox_InputDataset.Text.Trim());
        ILayer clipDataset = GetLayerByName(pMap, comboBox_ClipDataset.Text.Trim());

        if (inputDataset != null && clipDataset != null)
        {
            IFeatureLayer inputLayer = inputDataset as IFeatureLayer;
            IFeatureLayer clipLayer = clipDataset as IFeatureLayer;
            //利用裁剪方法来进行叠加分析
            IBasicGeoprocessor bGP = new BasicGeoprocessorClass();
            bGP.SpatialReference = pMap.SpatialReference;   //设置空间参考
            //创建FeatureClassNameClass对象,用于获取输入数据集的一些基本信息
            IFeatureClassName pOutput = new FeatureClassName() as IFeatureClassName;   
            pOutput.FeatureType = inputLayer.FeatureClass.FeatureType;
            pOutput.ShapeFieldName = inputLayer.FeatureClass.ShapeFieldName;
            pOutput.ShapeType = inputLayer.FeatureClass.ShapeType;

            //利用IDataset获得IWorkspaceName
            string fileDirectory = System.IO.Path.GetDirectoryName(textEdit_Output.Text.Trim());
            string fileName = System.IO.Path.GetFileName(textEdit_Output.Text.Trim());

            IWorkspaceFactory pWsFc = new ShapefileWorkspaceFactory();
            IWorkspace pWs = pWsFc.OpenFromFile(fileDirectory, 0);	//创建一个工作空间对象
            IDataset pDataset = pWs as IDataset;
            IWorkspaceName pWsN = pDataset.FullName as IWorkspaceName;	//获取工作空间的信息(获取输出路径)

            IDatasetName pDatasetName = pOutput as IDatasetName;	//获取或设置数据集中成员的名称信息
            pDatasetName.Name = fileName;	//设置数据集中的数据成员的名字
            pDatasetName.WorkspaceName = pWsN;	//设置输出的工作空间(输出路径)

            IFeatureClass featureClass = bGP.Clip(inputLayer.FeatureClass as ITable, false, clipLayer.FeatureClass as ITable, false, 0.01, pOutput);

            if (featureClass != null)
            {
                IFeatureLayer featLayer = new FeatureLayerClass();
                featLayer.FeatureClass = featureClass;
                featLayer.Name = featureClass.AliasName;
                //将结果添加到控件中
                mapControl.AddLayer(featLayer);
                mapControl.Refresh();
            }
        }
    }

    private void simpleButton_Cancel_Click(object sender, EventArgs e)
    {
        this.Close();
    }

    private ILayer GetLayerByName(IMap pMap, string layerName)
    {
        ILayer pLayer = null;
        ILayer tempLayer = null;
        try
        {
            for (int i = 0; i < pMap.LayerCount; i++)
            {
                tempLayer = pMap.Layer[i];
                if (tempLayer.Name.ToUpper() == layerName.ToUpper())      //判断名字大写是否一致
                {
                    pLayer = tempLayer;
                    break;
                }
            }
        }
        catch (Exception ex)
        {

            MessageBox.Show(ex.Message);
        }
        return pLayer;
    }

    private void simpleButton_Output_Click(object sender, EventArgs e)
    {
        SaveFileDialog flg = new SaveFileDialog();
        flg.Title = "保存路径";
        flg.Filter = "ShpFile(*shp)|*.shp";
        flg.ShowDialog();

        textEdit_Output.Text = flg.FileName;
    }
}

(3)在主窗体调用叠置分析窗口

在 menuStrip 中添加一个geoProcessing选项,并在其子选项中添加overlapTool选项,为其绑定 Click 事件。在 Click 事件处理方法中添加代码,显示【裁剪】窗体。

private void overlapToolToolStripMenuItem_Click(object sender, EventArgs e)
{
    GeoProcessing.OverlayAnalysisTool oA = new GeoProcessing.OverlayAnalysisTool();
    oA.mapControl = this.axMapControl1;
    oA.ShowDialog();
}

结果

缓冲区分析功能

导入数据

image-20230414083711165

打开缓冲区分析工具

image-20230414003648819

设置参数

image-20230414003956807

选择输出路径

image-20230414083908144

缓冲区分析结果

image-20230414084028205

叠置分析-裁剪功能

导入数据

image-20230414004434860

打开叠置分析工具

image-20230414004525895

设置参数

image-20230414005008003

选择输出路径

image-20230414005418736

叠置分析结果

image-20230414005405511

标签:GP,Text,private,pMap,缓冲区,null,Click,ArcEngine
From: https://www.cnblogs.com/tangjielin/p/17317196.html

相关文章

  • MATLAB2022b + win10 + cuda12.0 + matconvnet GPU编译
    我使用的是visualstudio2017 具体参考:https://blog.csdn.net/amyliu5200/article/details/120717854?spm=1001.2014.3001.5506但是其中我直接使用了: vl_compilenn('enableGpu',true)然后配置成功后:vl_testnn('gpu',true)则会出现:   ......
  • ChatGPT/大模型+零代码,给中小企业带来哪些机会?
    ChatGPT让2023年成了AI之年。正如iPhone在2007年开启了智能手机时代,我们现在正在进入人工智能时代。新形势下,零代码应如何借势发力?伙伴云“AI+零代码”给出了答案。作为零代码领域的头部平台,伙伴云全量发布【AI零代码应用搭建平台】,无需用户单独训练,无需额外投资,根据用户具体需求、......
  • GPIO初始化,及中断代码演示
    1#defineLED2572#defineLED1563#defineKEY2554#defineKEY15456#defineGPIO_DEVICE_IDXPAR_XGPIOPS_0_DEVICE_ID7XGpioPsGpio;89voidGpio_Init(void){10XGpioPs_Config*ConfigPtr;1112......
  • 虚拟机ubuntu22.4报错ok_update_request:I/oerror, dev fdo, sector 0 op OX0:(READ)tl
    ok_update_request:I/oerror,devfdo,sector0opOX0:(READ)tlags0x0phys_segprioclass0BufferI/oerrorondevfdo,logicalblock0,asyncpageread如下图 不管你用的HYPER-V创建虚拟机,还是VMVBOX等。只要找到这里: 把DVD/CD或者软驱修改为物理驱动器,即可。 ......
  • ChatGPT与AI智能助手Molly
    相信有关注科技圈的朋友一定听说过ChatGPT的大名吧,而Molly作为AI得贤招聘官开发的基于ChatGPT技术的智能AI助手,她能够对多种问题作出回答。当您向Molly提出问题时,Molly会先将问题分解成关键词和语义信息,然后利用NLP技术和机器学习算法对问题进行分析,从而确定问题的意图和最可能的答......
  • WINDOWS无法安装到这个磁盘。选中的磁盘采用GPT分区形式
    1.在系统提示无法安装的那一步,按住“shift+f10”,呼出“cmd”命令符2.输入:diskpart,回车进入diskpart3.输入:listdisk,回车显示磁盘信息4.输入:selectdisk0,回车选择第0个磁盘(电脑的硬盘编号是从0开始的)5.输入:clean,回车删除磁盘分区&格式化6.输入:convertmbr,回车将当前磁盘分区设置为M......
  • 如何获取ChatGPT的API keys
    首先,登录openai官网(https://openai.com/)然后,访问这个链接https://platform.openai.com/account/api-keys点击Createnewsecretkey创建key,就ok了箴言:因为这些东西是非常简单的。不要抱怨自己学不会,那是因为你没有足够用心。......
  • 《花雕学AI》21:脑筋急转弯---ChatGPT能够灵活运用逻辑推理和创造性思维吗?
    当我们谈到脑筋急转弯时,很多人都会感到兴趣和好奇。脑筋急转弯是一种智力游戏,可以锻炼我们的思维能力以及解决问题的能力。然而,对于许多人来说,脑筋急转弯也是一项相当具有挑战性的任务。在这个过程中,我们需要运用逻辑推理、上下文理解等能力才能解决问题。随着技术的发展,ChatGPT......
  • chatGPT对软件测试人员的冲击和影响
    目前大家都清楚类似chatGPT生成式人工智能的解决方案的大热,作为软件测试人员,或者相关行业的从业人员,需要思考的问题是,我们需要怎样持续学习来应对这种产业升级或者是类似新的技术迭代。据我的感觉类似chatGPT的人工智能已经对软件测试人员的工作方式和职责产生了重大影响。以下是一......
  • 如何使用ChatGPT竞争对手Claude
    像ChatGPT这样的许多网站旨在提供最智能的AI体验,但是,实际上,没有多少网站可以接近OpenAI的ChatGPT的体验。谷歌最近发布了它的BardAI聊天机器人,但在我们对ChatGPT和Bard的广泛比较中,我们发现BardAI相当平淡。好吧,如果你跟上AI新闻,Anthropic是另一家被吹捧为潜在OpenAI竞争对手之......