ArcGIS Engine:实现Shp/Mxd数据的加载、图层的简单查询

本博客参考:BiliBili UP主 <羊羊旸> : Arcgis Engine学习

目录

01 加载控件以及控件的基本信息等调整

02 编写 <菜单-地图控件> 中各个子工具的代码 

2.1 加载Shapefile数据-代码

2.2 加载地图文档数据-代码

2.3 获取图层数量-代码

2.4 获取图层名称-代码

2.5 获取图层索引-代码

2.6 完整代码

03 简单演示


01 加载控件以及控件的基本信息等调整

下面是整个软件的布局:

02 编写 <菜单-地图控件> 中各个子工具的代码 

2.1 加载Shapefile数据-代码

双击进入<加载Shapefile数据>的点击事件中(实际上就是点击了该工具会发生什么事情,这一部分事情放在一个函数中让你自由发挥)

using System.IO;  // 与路径的处理相关(在本程序中), 为了使用其中的Path类(其是静态的)

 使用下面中的Path类需要添加上述引用: 

private void 加载Shapefile数据ToolStripMenuItem_Click(object sender, EventArgs e)
{// 创建一个文件对话框实例获取用户选择的Shp文件OpenFileDialog openFileDialog = new OpenFileDialog();openFileDialog.Title = "加载Shapefile数据";  // 文件对话框的标题openFileDialog.Filter = "Shapefile(*.shp)|*.shp|asa|*.*";  // |前面为描述性信息, 后面为通配符openFileDialog.Multiselect = false;  // 不允许选择多个文件if (openFileDialog.ShowDialog() == DialogResult.OK)  // 其中openFileDialog.ShowDialog()执行打开文件对话框并返回相关值, 这里判断是否为{string shapefile_path = openFileDialog.FileName;try{string shapefile_dir = Path.GetDirectoryName(shapefile_path);string shapefile_name = Path.GetFileName(shapefile_path);MainMapControl.AddShapeFile(shapefile_dir, shapefile_name);// 上面分别传入Shp文件所在文件夹的目录和Shp文件的文件名.MessageBox.Show(string.Format("加载Shapefile数据成功:\n {0}", shapefile_name), "加载成功", MessageBoxButtons.OK, MessageBoxIcon.Information);}catch (Exception ex){//MessageBox.Show($"加载Shapefile数据成失败: {ex.Message}", "");MessageBox.Show(string.Format("加载Shapefile数据失败:\n {0}", ex.Message), "加载失败", MessageBoxButtons.OK, MessageBoxIcon.Error);}}
}

前面都比较常规, 首先先实例化一个OpenFileDialog类用于创建一个文件对话窗口,类似下面这种 :

这样用户才可以选择想要的文件,但是这个不需要我们自己从头去弄,调用人家写好的就好了。

发现了一个这个MessageBox.Show:
传入四个参数(也可以就传入一个字符串,其他都不管等等也可行,看重载方法有没有写)

分别是弹出窗口的内容、弹出窗口标题或者说是窗口的说明性描述性信息、弹出窗口的按钮(我加入了一个OK按钮)、弹出窗口的图标(我这里是如果正常加载就是普通信息的图标,否则是错误的图标),如下:

2.2 加载地图文档数据-代码

private void 加载地图文档数据ToolStripMenuItem_Click(object sender, EventArgs e)
{OpenFileDialog openFileDialog = new OpenFileDialog();  // 实例化一个文件对话框对象openFileDialog.Title = "加载地图文档";  // 文件对话框的标题openFileDialog.Filter = "地图文档(.mxd)|*.mxd";  // 前面为描述性信息, 后面为通配符if (openFileDialog.ShowDialog() == DialogResult.OK)  // 文件对话框打开, 并判断文件对话框是否已经选择了文件(==OK){string mxd_path = openFileDialog.FileName;  // 获取文件对话框所选择的文件的名称try{string mxd_name = Path.GetFileName(mxd_path);MainMapControl.LoadMxFile(mxd_path);MessageBox.Show(string.Format("加载地图文档成功:\n {0}", mxd_name), "加载成功", MessageBoxButtons.OK, MessageBoxIcon.Information);// 在这里调用获取图层数量的函数获取图层数量ToolStripMenuItem_Click(sender, e);}catch (Exception ex){MessageBox.Show(string.Format("加载地图文档失败:\n {0}", ex.Message), "加载失败", MessageBoxButtons.OK, MessageBoxIcon.Error);}}
}

与前面类似,这里不再详细描述,对于其中的

// 在这里调用获取图层数量的函数
获取图层数量ToolStripMenuItem_Click(sender, e);

请看后续代码中该函数的编写.

2.3 获取图层数量-代码

private void 获取图层数量ToolStripMenuItem_Click(object sender, EventArgs e)
{int layers_amount = MainMapControl.LayerCount;  // 获取当前显示在Mapcontrol中的所有要素数量textBox.Text = string.Format("当前图层数量: {0}", layers_amount);
}

2.4 获取图层名称-代码

此处使用ILayer类需要添加引用:

using ESRI.ArcGIS.Carto;  // 用于地图和图层操作,此处为使用其中的ILayer类
private void 获取图层名称ToolStripMenuItem_Click(object sender, EventArgs e)
{//if (int.TryParse(textBox.Text, out int layer_ix))int layer_ix;if (int.TryParse(textBox.Text, out layer_ix)){ILayer layer = MainMapControl.get_Layer(layer_ix);textBox.Text = string.Format("索引为{0}的图层名称为: {1}", layer_ix, layer.Name);}else{MessageBox.Show(string.Format("不存在索引为: <{0}>\n 请重新输入", textBox.Text));textBox.Text = "";}}

2.5 获取图层索引-代码

private void 获取图层索引ToolStripMenuItem_Click(object sender, EventArgs e)
{bool layer_exist = false;for (int ix = 0; ix < MainMapControl.LayerCount; ix++){string layer_name = MainMapControl.get_Layer(ix).Name;if (layer_name == textBox.Text){textBox.Text = string.Format("当前图层 <{0}> 的索引为: {1}", layer_name, ix);layer_exist = true;break;}}if (!layer_exist){MessageBox.Show("当前图层 <{0}> 不存在, 请重新输入", textBox.Text);textBox.Text = "";}}

2.6 完整代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;using System.IO;  // 与路径的处理相关(在本程序中), 为了使用其中的Path类(其是静态的)
using ESRI.ArcGIS.Carto;  // 为了使用其中的ILayer类namespace BasicBStation
{   public partial class Form1 : Form{public Form1(){ESRI.ArcGIS.RuntimeManager.Bind(ESRI.ArcGIS.ProductCode.EngineOrDesktop);  // 确保ArcGIS版本清晰, 否则报错.InitializeComponent();}private void 加载Shapefile数据ToolStripMenuItem_Click(object sender, EventArgs e){// 创建一个文件对话框实例获取用户选择的Shp文件OpenFileDialog openFileDialog = new OpenFileDialog();openFileDialog.Title = "加载Shapefile数据";  // 文件对话框的标题openFileDialog.Filter = "Shapefile(*.shp)|*.shp|asa|*.*";  // |前面为描述性信息, 后面为通配符openFileDialog.Multiselect = false;  // 不允许选择多个文件if (openFileDialog.ShowDialog() == DialogResult.OK)  // 其中openFileDialog.ShowDialog()执行打开文件对话框并返回相关值, 这里判断是否为{string shapefile_path = openFileDialog.FileName;try{string shapefile_dir = Path.GetDirectoryName(shapefile_path);string shapefile_name = Path.GetFileName(shapefile_path);MainMapControl.AddShapeFile(shapefile_dir, shapefile_name);// 上面分别传入Shp文件所在文件夹的目录和Shp文件的文件名.MessageBox.Show(string.Format("加载Shapefile数据成功:\n {0}", shapefile_name), "加载成功", MessageBoxButtons.OK, MessageBoxIcon.Information);}catch (Exception ex){//MessageBox.Show($"加载Shapefile数据成失败: {ex.Message}", "");MessageBox.Show(string.Format("加载Shapefile数据失败:\n {0}", ex.Message), "加载失败", MessageBoxButtons.OK, MessageBoxIcon.Error);}}}private void 加载地图文档数据ToolStripMenuItem_Click(object sender, EventArgs e){OpenFileDialog openFileDialog = new OpenFileDialog();  // 实例化一个文件对话框对象openFileDialog.Title = "加载地图文档";  // 文件对话框的标题openFileDialog.Filter = "地图文档(.mxd)|*.mxd";  // 前面为描述性信息, 后面为通配符if (openFileDialog.ShowDialog() == DialogResult.OK)  // 文件对话框打开, 并判断文件对话框是否已经选择了文件(==OK){string mxd_path = openFileDialog.FileName;  // 获取文件对话框所选择的文件的名称try{string mxd_name = Path.GetFileName(mxd_path);MainMapControl.LoadMxFile(mxd_path);MessageBox.Show(string.Format("加载地图文档成功:\n {0}", mxd_name), "加载成功", MessageBoxButtons.OK, MessageBoxIcon.Information);// 在这里调用获取图层数量的函数获取图层数量ToolStripMenuItem_Click(sender, e);}catch (Exception ex){MessageBox.Show(string.Format("加载地图文档失败:\n {0}", ex.Message), "加载失败", MessageBoxButtons.OK, MessageBoxIcon.Error);}}}private void 获取图层数量ToolStripMenuItem_Click(object sender, EventArgs e){int layers_amount = MainMapControl.LayerCount;  // 获取当前显示在Mapcontrol中的所有要素数量textBox.Text = string.Format("当前图层数量: {0}", layers_amount);}private void 获取图层名称ToolStripMenuItem_Click(object sender, EventArgs e){//if (int.TryParse(textBox.Text, out int layer_ix))int layer_ix;if (int.TryParse(textBox.Text, out layer_ix)){ILayer layer = MainMapControl.get_Layer(layer_ix);textBox.Text = string.Format("索引为{0}的图层名称为: {1}", layer_ix, layer.Name);}else{MessageBox.Show(string.Format("不存在索引为: <{0}>\n 请重新输入", textBox.Text));textBox.Text = "";}}private void 获取图层索引ToolStripMenuItem_Click(object sender, EventArgs e){bool layer_exist = false;for (int ix = 0; ix < MainMapControl.LayerCount; ix++){string layer_name = MainMapControl.get_Layer(ix).Name;if (layer_name == textBox.Text){textBox.Text = string.Format("当前图层 <{0}> 的索引为: {1}", layer_name, ix);layer_exist = true;break;}}if (!layer_exist){MessageBox.Show("当前图层 <{0}> 不存在, 请重新输入", textBox.Text);textBox.Text = "";}}}
}

由于时间问题,实在没有精力一一说明代码的详情,可以多看视频(视频和本博客代码稍有出入) 。

03 简单演示

时间精力有限,其他功能不再一一演示。

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

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

相关文章

vue3 +elementplus | vue2+elementui 动态地通过验证规则子新增或删除单个表单字段

效果图 点击 ‘’ 新增一行&#xff0c;点击‘-’ 删除一行 vue3elementplus写法 template <el-dialog v-model"dialogFormVisible" :title"title"><el-form ref"ruleFormRef" :model"form" :inline"true" lab…

【算法|动态规划No.8】leetcode面试题 17.16. 按摩师

个人主页&#xff1a;兜里有颗棉花糖 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【LeetCode】 &#x1f354;本专栏旨在提高自己算法能力的同时&#xff0c;记录一下自己的学习过程&#xff0c;希望…

对图像中边、线、点的检测(支持平面/鱼眼/球面相机)附源码

前言 图像的线段检测是计算机视觉和遥感技术中的一个基本问题,可广泛应用于三维重建和 SLAM 。虽然许多先进方法在线段检测方面表现出了良好的性能,但对未去畸变原始图像的线 段检测仍然是一个具有挑战性的问题。此外,对于畸变和无畸变的图像都缺乏统一的…

1.2.C++项目:仿muduo库实现并发服务器之时间轮的设计

文章目录 一、为什么要设计时间轮&#xff1f;&#xff08;一&#xff09;简单的秒级定时任务实现&#xff1a;&#xff08;二&#xff09;Linux提供给我们的定时器&#xff1a;1.原型2.例子 二、时间轮&#xff08;一&#xff09;思想&#xff08;一&#xff09;代码 一、为什…

云原生数据库TDSQL-C

数据库系统核心模块 云原生数据库要解决什么问题&#xff1f; HTAP 云数据库VS云原生数据库

mysql双主互从通过KeepAlived虚拟IP实现高可用

mysql双主互从通过KeepAlived虚拟IP实现高可用 在mysql 双主互从的基础上&#xff0c; 架构图&#xff1a; Keepalived有两个主要的功能&#xff1a; 提供虚拟IP&#xff0c;实现双机热备通过LVS&#xff0c;实现负载均衡 安装 # 安装 yum -y install keepalived # 卸载 …

Polygon Miden交易模型:Actor模式 + ZKP => 并行 + 隐私

1. 引言 前序博客&#xff1a; Polygon Miden&#xff1a;扩展以太坊功能集的ZK-optimized rollupPolygon Miden zkRollup中的UTXO账户混合状态模型 Polygon Miden为&#xff1a; ZK-optimized rollup由客户端生成证明完善Polygon ZK系列解决方案&#xff0c;致力于成为网络…

【C语言经典100例题-68】有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数

方法一 将原数组拆成两部分&#xff0c;前面n-m个数和后面m个数。首先将前面n-m个数逆序&#xff0c;然后将后面的m个数逆序。最后将整个数组逆序即可。 #include <stdio.h>void reverse(int arr[], int start, int end) {for (int i start, j end; i < (start en…

学过的汇编指令整合

1.数据搬移指令 <opcode>{<cond>}{s} <Rd>, <shifter_operand> 解释&#xff1a; <opcode>&#xff1a;指令码 {<cond>}&#xff1a;条件码 {s}&#xff1a;状态位&#xff0c;如果在指令后面加上s&#xff0c;则运算的结果会影响CPSR的条…

傅里叶系列 P2 的定价选项

系列上文&#xff1a;傅里叶系列 P1 的定价选项_无水先生的博客 一、说明 通过本文&#xff0c;您可以了解&#xff1a; 如何从知道什么是傅里叶级数到能够在黑色下为期权定价。 如果您想了解更多关于傅里叶级数基础知识的信息&#xff0c;请查看第 1 部分。随附笔记本&#…

objective-c 基础学习

目录 第一节&#xff1a;OC 介绍 ​​第二节&#xff1a;Fundation 框架 ​第三节&#xff1a;NSLog 相对于print 的增强 ​第四节&#xff1a;NSString ​第五节&#xff1a;oc新增数据类型 第六节&#xff1a; 类和对象 ​类的方法的声明与实现 ​第七节&#xff1a;类…

智慧公厕整体解决方案,厕所革命实施方案的范本

随着城市化进程的不断加快&#xff0c;智慧城市应用正成为未来城市发展的重要方向。其中&#xff0c;智慧公厕作为城市基础设施的重要组成部分&#xff0c;其建设范本已经成为各建设中的智慧城市不可或缺的重要内容。那么&#xff0c;如何打造智慧公厕整体解决方案&#xff1f;…

将数组和减半的最少操作【贪心2】

题目&#xff1a;将数组和减半的最少操作 贪心思路&#xff1a;每次挑选最大的数来减半。 解法&#xff1a;贪心大根堆 class Solution { public:int halveArray(vector<int>& nums) {priority_queue<double> heap;double sum 0.0;for(int& x : nums){hea…

(四)激光线扫描-光平面标定

在上一章节,已经实现了对激光线条的中心线提取,并且在最开始已经实现了对相机的标定,那么相机标定的作用是什么呢? 就是将图像二维点和空间三维点之间进行互相转换。 1. 什么是光平面 激光发射器投射出一条线,形成的一个扇形区域平面就是光平面,也叫光刀面,与物体相交…

Android etc1tool之png图片转换pkm 和 zipalign简介

关于作者&#xff1a;CSDN内容合伙人、技术专家&#xff0c; 从零开始做日活千万级APP。 专注于分享各领域原创系列文章 &#xff0c;擅长java后端、移动开发、商业变现、人工智能等&#xff0c;希望大家多多支持。 目录 一、导读二、etc1tool2.1、用法 三、zipalign3.1 使用 四…

电脑右键新建记事本不见了--设置恢复篇(无需操作注册表)

电脑右键新建记事本不见了–设置恢复篇&#xff08;无需修改注册表&#xff09; 电脑不知怎么想右键新建记事本结果竟然不见了&#xff0c;搜寻网上的都是什么修改注册表&#xff0c;粘贴代码修复&#xff08;感觉太复杂了&#xff09;&#xff0c;这里介绍通过设置内重新对记…

北京开发APP需要多少钱

北京开发一个移动应用&#xff08;APP&#xff09;的费用因多种因素而异&#xff0c;包括项目的规模、复杂性、所需功能、设计要求、技术选择、开发团队的经验和地理位置等。一般来说&#xff0c;北京的APP开发费用通常较高&#xff0c;因为这是中国的主要技术和创新中心之一&a…

5.5线程同步机制类封装及线程池实现

文章目录 5.5线程同步机制类封装及线程池实现线程池线程同步机制类封装线程池实现 5.5线程同步机制类封装及线程池实现 线程池 线程池是由服务器预先创建的一组子线程&#xff0c;线程池中的线程数据应该与CPU数据差不多。线程池中的所有子线程都运行着相同的代码。当有新的任…

QT 之数据库 QSqlQuery CURD 实战

零、参考文档 https://doc.qt.io/archives/qt-6.0/qsqldatabase.html 一、开发环境 Ubuntu 20.04 QT6.0 Microsoft SQL Server 2022 Developer Edition (64-bit) 先修改 /etc/odbc.ini 的数据源配置&#xff0c;指定连接数据库 vdb&#xff0c; sudo vim /etc/odbc.ini[mss…

IDEA Rogstry中找不到compiler.automake.allow.when.app.running问题解决

网上大部分人教我们 先 File > Settings 然后 勾选 Build 下的 Compiler中的 Build project automatically 这些步骤都不会有问题 然后就会让我们 ctrl shift alt / 点 Rogstry 打开后 我人就麻了 根本没有什么 compiler.automake.allow.when.app.running 也不用慌 我们…