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

news2024/11/14 18:35:47

在国土空间规划中,用地用海分类采用三级分类体系,共设置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_field
            cb.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文件直接安装。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/440423.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

研读Rust圣经解析——Rust learn-3(变量与可变性,数据类型)

研读Rust圣经解析——Rust learn-3(变量与可变性,数据类型) 变量|常量与可变性变量声明案例为什么不可变变量可变(mut关键字)变量可变(覆盖) 常量声明 数据类型标量类型整型整型字面值整型溢出问…

ECShop开源商城与COS互通:降低本地存储负载、提升访问体验

ECShop简介 ECShop是一款开源电子商务平台,具有简单易用、安全稳定、模块化设计等特点。它提供了完整的电子商务解决方案,包括商品管理、订单管理、支付管理、配送管理、会员管理、促销管理、数据统计等功能。ECShop支持多语言、多货币、多种支付方式和配…

防火墙做网关双链路接入不同ISP

USG作为校园或大型企业出口网关可以实现内网用户通过两个运营商访问Internet可以实现外网用户访问内网服务器,并保护内网不受网络攻击。 组网需求: 某学校网络通过USG连接到Internet,校内组网情况如下: 校内用户主要分布在教学…

【Java|golang】2409. 统计共同度过的日子数---golang中全局变量带来的坑

Alice 和 Bob 计划分别去罗马开会。 给你四个字符串 arriveAlice ,leaveAlice ,arriveBob 和 leaveBob 。Alice 会在日期 arriveAlice 到 leaveAlice 之间在城市里(日期为闭区间),而 Bob 在日期 arriveBob 到 leaveBo…

CTFWIKI-PWN-ret2libc

目录 1.libc 2.plt 和got 3.调用system 4.flat函数 5.libc泄露 例题1 checksec ida 计算偏移量 查找system.plt 查找/bin/sh 1.ida 2.ROPgadget exp 例题2 checksec ida 思路 给出流程图 查看bss是否可以写入 exp 例题3 checksec ida 偏移量 找puts的go…

投屏市场的挑战与发展趋势

投屏的定义 投屏是指将手机、平板、电脑等设备的屏幕内容无线传输到电视、投影仪等大屏幕上的技术,也称为无线投屏、屏幕镜像、屏幕共享等。投屏技术可以实现多屏互动、内容共享、远程协作等功能,为用户提供更丰富的视听体验和更便捷的工作方式。 投屏市…

Jupyter Notebook小知识

目录 1 快捷键1.1 常用快捷键1.2 魔法函数 2 常用快捷键2.1 模式切换2.2 命令模式快捷键2.3 编辑模式快捷键3 Matplotlib绘图 4 小技巧4.1 文件默认目录的查看以及更改4.2 更改主题颜色 5 其它5.1 python中 r, b, u, f 的含义5.2 f/format():格式化操作 6 常见问题6.1 查看模块…

25K测试老鸟6年经验的面试心得,四种公司、四种问题…

这里总结了下自己今年的面试情况 先说一下自己的个人情况,普通二本计算机专业毕业,懂python,会写脚本,会selenium,会性能。趁着金三银四跳槽季,面试字节跳动测试岗技术面都已经过了,本来以为是…

基于OC端的Bridge-API组件化应用

前言 在移动应用开发中,组件化可以提高代码的模块化和重用性,降低耦合度。当下大部分APP都至少包含一到两种Hybrid框架,H5基本是必要的,还可能叠加React Natvie、Weex或Flutter。 对于Hybird来说,Native的很多能力是…

Ae:自动定向

Ae 菜单:图层/变换/自动定向 Auto-Orient 快捷键:Ctrl Alt O 自动定向 Auto-Orient是 Ae 图层中的一个附加的、隐藏实现(不会在时间轴面板上更改属性的值)的功能,它可以使得图层自动旋转或改变方向以朝向指定的运动路…

HIVE相关操作

HIVE有两种启动方式 方式1: bin/hive 即Hive的Shell客户端,可以直接写SQL方式2: bin/hive --service hiveserver2 后台执行脚本:nohup bin/hive --service hiveserver2 >> logs/hiveserver2.log 2>&1 & bin/hiv…

Vue.js列表渲染指令v-for

目录 一、原理概述 二、基本用法 (1)v-for循环普通数组 (2)v-for循环对象 (3)v-for循环对象数组 (4)v-for迭代整数 一、原理概述 v-for指令时在模板编译的代码生成阶段实现的…

6.java程序员必知必会类库之pdf处理库

前言 Pdf作为我们办公文件中的一种常用文件格式,很多业务中会涉及到一个功能,是将系统中的某些数据,按照要求的格式生成Pdf文件。比如常见的征信报告,合同文件等等,为此通过java代码,处理PDF格式的文件&am…

Vulnhub项目:Earth

靶机地址:The Planets: Earth ~ VulnHub 渗透过程: 首先查看靶机描述,需要获取2个flag 老样子,确定靶机ip,具体的就不详细写了,看图即可 探测靶机开放端口 如果不进行dns绑定,就会出现下面的…

带你玩转状态机(论点:概念、相关图示、示例代码、适用场景、相关文档)

概念 状态机(State Machine)是一种用于描述系统在不同状态下的行为及状态之间转换的数学模型。状态机主要由三个部分组成:状态(State)、事件(Event)和转换(Transition)。…

Vue2-黑马(九)

0目录: (1)router-动态菜单 (2)vuex-入门 (3)vuex-mapState (1)router-动态菜单 我们点击按钮跳转到主页面,主页在制作动态菜单,路由的跳转方…

【PWN】刷题——CTFHub之 简单的 ret2text

萌新第一阶段自然是了解做题的套路、流程,简单题要多做滴 目录 前言 一、checksec查看 二、IDA反汇编 三、exp编写 前言 经典的ret2text流程 一、checksec查看 64位程序,什么保护都没有,No canary found——可以栈溢出控制返回 二、IDA反汇…

SpringBoot整合Redis、以及缓存穿透、缓存雪崩、缓存击穿的理解、如何添加锁解决缓存击穿问题?分布式情况下如何添加分布式锁

文章目录 1、步骤2、具体过程1、引入pom依赖2、修改配置文件3、单元测试4、测试结果 3、redis运行情况4、项目中实际应用5、加锁解决缓存击穿问题代码一(存在问题)代码二(问题解决) 6、新问题7、分布式锁 1、步骤 前提条件&#…

FFmpeg 编译静态库

1. 使用工具 1.1 FFmpeg 官网: 1.2 FFmpeg macOS 官方安装教程: 1.3 Homebreaw 安装网站: 2. Homebreaw 介绍 2.1 简称 brew,在 Mac 平台终端上管理软件包,安装,更新,卸载等软件 2.2 安装 brew,终端执行指令(内部安装…

HTTP协议详解(一)

目录 1.什么是HTTP协议? 2.HTTP的协议格式 使用fiddler抓包工具 理解代理 查看请求内容 3.HTTP请求(Request) 认识URL URL encode 认识method GET方法 POST方法 经典面试题:POST和GET之间的典型区别 其它方法 认识请求 "报头" (header) Host Conte…