MySQL抽稀_ArcGIS制图之Sub Points点抽稀

简介

Sub Points工具是 Esri 中国自主开发的一个插件,该工具优先考虑点在空间分布上的均匀合理性,并结合点数据中包含的 "优先级" 属性进行筛选。通过获取每个点在一定范围内拥有的相邻点的数目信息,得到地图中点密度的分布状况。抽稀时在若干相临近的点中首先比较优先级,保留优先级高的;优先级相同时比较 NAME 字段,保留 NAME 长度短的;两者都相同时随机选择。使用 Sub Points 进行点抽稀的数据,必须包含"优先级"和"name"两个字段。其中优先级用来设置数据的重要性,在抽稀过程中综合考虑数据的优先级别。

修改程序

原始版本是基于10.0开发的,在10.1及以上版本需要修改两处:

一是SubPointsFunctionFactory.cs文件中CreateGPFunctionNames方法的MinimumProduct属性修改为:

functionName.MinimumProduct = esriProductCode.esriProductCodeBasic;

二是SubPointsFunction.cs文件中IsLicensed()函数修改为:

IAoInitialize myAoInitialize = new AoInitializeClass();ILicenseInformation myLic = (ILicenseInformation)myAoInitialize;string myLic= myLic.GetLicenseProductName(myAoInitialize.InitializedProduct());if (myLic == "Advanced") return true;else return false;

如果这两处不修改将会出现许可报错的问题:

457792e6359a9bf0d71b8bdffc9d4b1a.png

三是SubPointsFunction.cs字段名称的修改。在10.0的版本中字段名称是小写,从10.1起字段名称为大写(本来arcgis不区分大小写,但程序代码中的判断语句区分了大小写,没有使用大小写转换函数)。

int iInputFID = pPDTable.FindField("INPUT_FID");int iNearFID = pPDTable.FindField("NEAR_FID");int iDistance = pPDTable.FindField("DISTANCE");

除此之外,我还修改了界面的语言为中文。

使用方法

第一步,注册文件。将GPSubPoints.dll拷到arcgis安装目录下(如C:Program Files (x86)ArcGISDesktop10.1in),在dll上右键,选择打开方式为ESRIRegAsm.exe (浏览到C:Program Files (x86)Common FilesArcGISinESRIRegAsm.exe),一般情况下会注册成功,并弹出提示消息。(如果安装360等,请将它加入白名单)

7433d6556a8b4d54f24d8b18eb59618b.png

第二步,添加工具。打开ArcMap,在我的工具箱(非系统工具箱)上添加工具箱,然后添加工具,选择sub points.

a73847b13365f10d5980e7ca133a6962.png

第三步,生成邻近表。使用点距离工具生成邻近表,输入和邻近要素都为需要进行抽稀的点数据,搜索半径为抽稀后任意两个点的最大距离。

60157de561cf560c2b75ae45f8d3b7a3.png

第四步,新建字段。在需要抽稀的点数据属性表中新建名称"NAME"和"优先级"( short)的字段,并给"优先级"字段赋值。其中优先级用来设置数据的重要性,在抽稀过程中综合考虑数据的优先级别。如果没有相应的字段将会报错或警告。

310b84c3c513c7cc80f797d6e03435cb.png

第五步,执行抽稀工具。输入邻近表和要进行抽稀的要素,执行抽稀。

05e7441852fc7c34e3b9c58fab7bd6b1.png

第六步,定义查询。结果并未生成新数据、也未删除原来的点,只是增加了标记字段status. 对于 status > -99 的值,表示要保留显示的要素; 对于 status = -99 的值,表示要删除或者不在地图上显示的要素。可通过定义查询操作来控制地图显示内容,如下图所示。也可以直接删除不显示的要素。

a770adcc1a5b409f36ce62e61b11904e.png

结果

抽稀效果如下:对于本来就稀疏的位置,并没有进行抽稀。对于原来密集的地区(小于最小邻近距离)抽稀效果比较良好。

c84cd305ce0f6fd45e0c40a56a16c1b5.png

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值