【ArcGIS Pro二次开发】(22):生成分级用地编码和名称

2024-01-09 20:59

本文主要是介绍【ArcGIS Pro二次开发】(22):生成分级用地编码和名称,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在国土空间规划中,用地用海分类采用三级分类体系,共设置24种一级类、106种二级类及39 种三级类。在某些场景中,需要按等级归类并汇总统计。

这个小工具的作用就是通过用地编码生成三级地类,作为后续统计的基础。


一、要实现的功能

如上图所示,右键点击地图中的要素图层,点击【生成分级用地用海】按钮,打开工具框,选择图层的用地编码字段、分级类型和是否生成名称,点击运行即可。

其中分级类型中,如果选【大类】,会生成新字段【大类编码】;选【中类】,则会生成新字段【大类编码、中类编码】,以此类推。

如果勾选【是否生成用地用海名称】,则会根据编码字段,生成名称字段。

例如,你选择【中类】,并勾选【是否生成用地用海名称】,要素图层会新生成【大类编码、大类名称、中类编码、中类名称】4个字段,并分别计算它们的字段值。

运行结果如下图:


二、实现流程

1、创建ProWindow工具框并设置参数框的内容

创建一个ProWindow工具框,具体做法参看之前的文章:

【ArcGIS Pro二次开发】(13):ProWindow的用法

将当前选择的要素图层加入参数框:

// 获取当前选择的要素图层
FeatureLayer initlayer = MapView.Active.GetSelectedLayers().FirstOrDefault() as FeatureLayer;
// combox_fc框中添加当前选择的要素图层
combox_fc.Items.Add(initlayer);
combox_fc.SelectedIndex = 0;

将当前选择要素图层的所有字段添加到combox中,以用于手动选择字段:

            // 清空combox_fieldcb.Items.Clear();await QueuedTask.Run(async () =>{// 获取所选图层的所有字段var fields = initlayer.GetFieldDescriptions();foreach (var field in fields){await QueuedTask.Run(() =>{// 在UI线程上执行添加item的操作Application.Current.Dispatcher.Invoke(() =>{// 将所有字段名添加到combox_field中cb.Items.Add(field.Name);});});}});

用地用海分级中加入3种模式,并将其中1种设为默认:

// combox_model框中添加3种模式,默认【大类】
combox_model.Items.Add("大类");
combox_model.Items.Add("中类");
combox_model.Items.Add("小类");
combox_model.SelectedIndex = 0;

2、主要流程代码

这里我把工作的主要流程整理了一下,将其中部分会重复使用的代码写成方法,这样看上去流程会更加清晰:

            // 参数获取string fcPath = combox_fc.Text;string bmField = combox_field.Text;// 模式转换int model = 1;if (combox_model.Text == "中类") { model = 2; }else if (combox_model.Text == "小类") { model = 3; }// 根据需求生成三级用地编码和名称if (model >= 1){AddField(fcPath, "大类编码", "TEXT");     // 添加大类编码GetBM1(fcPath, bmField, "大类编码");                // 计算大类编码if (checkbox_isMC.IsChecked == true){AddField(fcPath, "大类名称", "TEXT");     // 添加大类名称YDYHChange(fcPath, "大类编码", "大类名称");    // 编码转名称}}if (model >= 2){AddField(fcPath, "中类编码", "TEXT");     // 添加中类编码GetBM2(fcPath, bmField, "中类编码");                // 计算中类编码if (checkbox_isMC.IsChecked == true){AddField(fcPath, "中类名称", "TEXT");     // 添加中类名称YDYHChange(fcPath, "中类编码", "中类名称");    // 编码转名称}}if (model >= 3){AddField(fcPath, "小类编码", "TEXT");     // 添加小类编码GetBM3(fcPath, bmField, "小类编码");                // 计算小类编码if (checkbox_isMC.IsChecked == true){AddField(fcPath, "小类名称", "TEXT");     // 添加小类名称YDYHChange(fcPath, "小类编码", "小类名称");    // 编码转名称}}

流程比较清晰(只是水平有限,这多重if确实挺难看的),根据【分级类型】和【是否生成用地用海名称】来判断生成的新字段,并进行计算。

在此之前,将分级类型转成整型方便判断。

整合的方法包括【添加字段、计算各级用地编码字段、通过用地用海转换实现编码转名称】。

3、【添加字段】

添加字段比较简单,调用一下GP工具就可以了:

var par_AddField = Geoprocessing.MakeValueArray(fcPath, fieldName, fieldType, null, null, fieldLength, fieldAlias, null, null, null);
await QueuedTask.Run(() => Geoprocessing.ExecuteToolAsync("management.AddField", par_AddField, null, null, null, executeFlags));

4、【计算各级用地编码字段】

计算字段主要通过打开要素图层的属性表并进行编辑来实现,之前有写过这方面的内容,可以复习一下:

【ArcGIS Pro二次开发】(10):属性表字段(field)的修改

以提取编码大类为例,通过Substring()方法提取前2位文字,主要代码如下:

            await QueuedTask.Run(() =>{// 打开要素图层的表格var table = initlayer.GetTable();// 定位到属性表的游标using (var tableCursor = table.Search(null, false)){while (tableCursor.MoveNext()){// 获取当前记录的值var row = tableCursor.Current;string currentValue = row[fieldBefore] as string;// 获取fieldBefore字段值的前两位string newValue = currentValue.Substring(0, 2);// 更新字段值row[fieldAfter] = newValue;row.Store();}}});

提取中类和小类则再复杂一点,加个if判断一下即可:

                        // 取值默认为空string newValue = "";// 如果原字段值超过4位,获取fieldBefore字段值的前4位if (currentValue.Length >= 4){newValue = currentValue.Substring(0, 4);}

5、【通过用地用海转换实现编码转名称】

这部分我已经专门发过文章,并且已经做成工具,直接使用即可:

【ArcGIS Pro二次开发】(15):用地用海名称和代码互转

简单就可实现用地编码转换为用地名称。

PS:综上,整个工具的代码量虽然算比较多,但其实大部分都在之前文章中写过,我把之前的一些方法都写到一个.cs文件中,基本就是引用即可。

因此本文中很多代码没有放出来,不过文章末尾会提供工程文件下载,可以自行查看全部代码。

如果你是新手,并且没看过我之前的相关文章,建议按上面的链接好好回看一下,不然可能会看得云里雾里。


三、工程文件分享

 最后,放上工程文件的链接:

CreateGdYDYHicon-default.png?t=N2N8https://pan.baidu.com/s/1BPvmCxWGCJqg_9UOnj30Pw?pwd=sz4b

PS:可以直接点击...bin\Debug\net6.0-windows\下的.esriAddinX文件直接安装。

这篇关于【ArcGIS Pro二次开发】(22):生成分级用地编码和名称的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588416

相关文章

Ubuntu 24.04 LTS怎么关闭 Ubuntu Pro 更新提示弹窗?

《Ubuntu24.04LTS怎么关闭UbuntuPro更新提示弹窗?》Ubuntu每次开机都会弹窗提示安全更新,设置里最多只能取消自动下载,自动更新,但无法做到直接让自动更新的弹窗不出现,... 如果你正在使用 Ubuntu 24.04 LTS,可能会注意到——在使用「软件更新器」或运行 APT 命令时,

最便宜的8口2.5G网管交换机! 水星SE109 Pro拆机测评

《最便宜的8口2.5G网管交换机!水星SE109Pro拆机测评》水星SE109Pro价格很便宜,水星SE109Pro,外观、接口,和SE109一样,区别Pro是网管型的,下面我们就来看看详细拆... 听说水星SE109 Pro开卖了,PDD卖 220元,于是买回来javascript拆机看看。推荐阅读:水

详解Java中如何使用JFreeChart生成甘特图

《详解Java中如何使用JFreeChart生成甘特图》甘特图是一种流行的项目管理工具,用于显示项目的进度和任务分配,在Java开发中,JFreeChart是一个强大的开源图表库,能够生成各种类型的图... 目录引言一、JFreeChart简介二、准备工作三、创建甘特图1. 定义数据集2. 创建甘特图3.

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

pdfmake生成pdf的使用

实际项目中有时会有根据填写的表单数据或者其他格式的数据,将数据自动填充到pdf文件中根据固定模板生成pdf文件的需求 文章目录 利用pdfmake生成pdf文件1.下载安装pdfmake第三方包2.封装生成pdf文件的共用配置3.生成pdf文件的文件模板内容4.调用方法生成pdf 利用pdfmake生成pdf文件 1.下载安装pdfmake第三方包 npm i pdfma

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

poj 1287 Networking(prim or kruscal最小生成树)

题意给你点与点间距离,求最小生成树。 注意点是,两点之间可能有不同的路,输入的时候选择最小的,和之前有道最短路WA的题目类似。 prim代码: #include<stdio.h>const int MaxN = 51;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int P;int prim(){bool vis[MaxN];

poj 2349 Arctic Network uva 10369(prim or kruscal最小生成树)

题目很麻烦,因为不熟悉最小生成树的算法调试了好久。 感觉网上的题目解释都没说得很清楚,不适合新手。自己写一个。 题意:给你点的坐标,然后两点间可以有两种方式来通信:第一种是卫星通信,第二种是无线电通信。 卫星通信:任何两个有卫星频道的点间都可以直接建立连接,与点间的距离无关; 无线电通信:两个点之间的距离不能超过D,无线电收发器的功率越大,D越大,越昂贵。 计算无线电收发器D

hdu 1102 uva 10397(最小生成树prim)

hdu 1102: 题意: 给一个邻接矩阵,给一些村庄间已经修的路,问最小生成树。 解析: 把已经修的路的权值改为0,套个prim()。 注意prim 最外层循坏为n-1。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstri

【生成模型系列(初级)】嵌入(Embedding)方程——自然语言处理的数学灵魂【通俗理解】

【通俗理解】嵌入(Embedding)方程——自然语言处理的数学灵魂 关键词提炼 #嵌入方程 #自然语言处理 #词向量 #机器学习 #神经网络 #向量空间模型 #Siri #Google翻译 #AlexNet 第一节:嵌入方程的类比与核心概念【尽可能通俗】 嵌入方程可以被看作是自然语言处理中的“翻译机”,它将文本中的单词或短语转换成计算机能够理解的数学形式,即向量。 正如翻译机将一种语言