基于arcpro3.0.2的删除图层中与掩码图层不相交的要素功能

2024-06-13 14:28

本文主要是介绍基于arcpro3.0.2的删除图层中与掩码图层不相交的要素功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于arcpro3.0.2的删除图层中与掩码图层不相交的要素功能在这里插入图片描述

其代码如下所示:

//开始删除功能
private void btnRun_Click(object sender, EventArgs e)
{ProcessWindow pw = null;try{//获取图层var delFeatsLayer = this.cb_DeleteFeatures.SelectedItem as FeatureLayer;if (delFeatsLayer == null){MessageBox.Show("请先选择一个要删除要素的图层", "提示");return;}var maskLayer = this.cb_MaskLayer.SelectedItem as FeatureLayer;if (maskLayer == null){MessageBox.Show("请先选择一个掩码图层", "提示");return;}pw = appTool.getNewProcessWindow("删除进度...");pw.Show();QueuedTask.Run(() =>{pw.setMinValue(0);pw.setMaxValue(10);pw.setValue(0);//FeatureClass delFc = delFeatsLayer.GetFeatureClass();FeatureClass maskFc = maskLayer.GetFeatureClass();long fIndex = 0;long fCount = delFc.GetCount();pw.setMaxValue(fCount);using (RowCursor rowCursor =delFc.Search(null)){   using(RowCursor maskCursor=maskFc.Search(null)){//合并几何对象pw.addMessageTime("正在准备合并掩码几何对象");Geometry maskGeo = null;while(maskCursor.MoveNext()){using(Feature maskFeat =maskCursor.Current as Feature){if(maskFeat != null && maskFeat.GetShape()!=null){if(maskGeo==null){maskGeo = maskFeat.GetShape();}else{maskGeo = GeometryEngine.Instance.Union(maskGeo, maskFeat.GetShape());}}}}pw.addMessageTime("合并掩码几何对象完毕");pw.addMessageTime("准备删除与掩码图层不相交的要素...");//判断并删除要素List<long> idList = new List<long>();while (rowCursor.MoveNext()){using (Feature delFeat = rowCursor.Current as Feature){fIndex += 1;if (delFeat != null){if (GeometryEngine.Instance.Intersects(delFeat.GetShape(),maskGeo)==false){    //不相交的要素,则删除之                                            idList.Add(delFeat.GetObjectID());}}if (fIndex % 5000 == 0){pw.addMessageTime("正在处理要素:    " + fIndex + "/" + fCount);}}}pw.setMaxValue(idList.Count);Table table = delFeatsLayer.GetTable();                            //for (int i=0;i<idList.Count; i++){                                long oid = idList[i];EditOperation delFeats = new EditOperation();delFeats.Delete(table, oid);if (delFeats.IsEmpty == false){delFeats.Execute();                                    }if (i % 5000 == 0){pw.addMessageTime("正在删除要素:    " + i + "/" + idList.Count);}}pw.addMessageTime("处理要素个数 " + fCount + "/" + fCount);}                        }                    pw.addMessageTime("处理完毕");//});}catch (Exception ex){MessageBox.Show(ex.ToString());}finally{}}

本blog地址:https://blog.csdn.net/hsg77

这篇关于基于arcpro3.0.2的删除图层中与掩码图层不相交的要素功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

电脑桌面文件删除了怎么找回来?别急,快速恢复攻略在此

在日常使用电脑的过程中,我们经常会遇到这样的情况:一不小心,桌面上的某个重要文件被删除了。这时,大多数人可能会感到惊慌失措,不知所措。 其实,不必过于担心,因为有很多方法可以帮助我们找回被删除的桌面文件。下面,就让我们一起来了解一下这些恢复桌面文件的方法吧。 一、使用撤销操作 如果我们刚刚删除了桌面上的文件,并且还没有进行其他操作,那么可以尝试使用撤销操作来恢复文件。在键盘上同时按下“C

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

poj 1127 线段相交的判定

题意: 有n根木棍,每根的端点坐标分别是 px, py, qx, qy。 判断每对木棍是否相连,当他们之间有公共点时,就认为他们相连。 并且通过相连的木棍相连的木棍也是相连的。 解析: 线段相交的判定。 首先,模板中的线段相交是不判端点的,所以要加一个端点在直线上的判定; 然后,端点在直线上的判定这个函数是不判定两个端点是同一个端点的情况的,所以要加是否端点相等的判断。 最后

zoj 1721 判断2条线段(完全)相交

给出起点,终点,与一些障碍线段。 求起点到终点的最短路。 枚举2点的距离,然后最短路。 2点可达条件:没有线段与这2点所构成的线段(完全)相交。 const double eps = 1e-8 ;double add(double x , double y){if(fabs(x+y) < eps*(fabs(x) + fabs(y))) return 0 ;return x + y ;

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring+MyBatis+jeasyui 功能树列表

java代码@EnablePaging@RequestMapping(value = "/queryFunctionList.html")@ResponseBodypublic Map<String, Object> queryFunctionList() {String parentId = "";List<FunctionDisplay> tables = query(parent

PostgreSQL核心功能特性与使用领域及场景分析

PostgreSQL有什么优点? 开源和免费 PostgreSQL是一个开源的数据库管理系统,可以免费使用和修改。这降低了企业的成本,并为开发者提供了一个活跃的社区和丰富的资源。 高度兼容 PostgreSQL支持多种操作系统(如Linux、Windows、macOS等)和编程语言(如C、C++、Java、Python、Ruby等),并提供了多种接口(如JDBC、ODBC、ADO.NET等