ArcGIS中生成蜂窝多边形算法解析
近来有不少同学。都有问我关于蜂窝多边形的问题。也就是正六边形,也就是以下这个东东:
一般的问答模式例如以下:
亲们问:ArcGIS里面那个工具能够做这个东东?
虾神答:额,没有原生的工具。
亲们问:那我看非常多人都做了啊,这个东东怎么做?
虾神答:嗯,算法非常easy……巴拉巴拉巴拉……
亲们:
虾神:……
好吧,既然有如此,今天我们就用一篇文章来简单说说在ArcGIS里面怎样做蜂窝六边形的方法。
话说我们做样方分析的时候,最简单的当然是採用矩形。样方样方……里面这个方字用得那是极好的。可是非常多精益求
精的同学,认为方形太图样图森破了,我们怎么能用这么简单的东西呢?我们要用正六边形!
实际上,六边形得几何描写叙述确实要例如形完美得多,对照一下就知道了:
首先在几何里面有“平面镶嵌”这个概念(无间隙且不重叠地覆盖平面),正六边形是边数最多的平面镶嵌图形。(边
越多,越接近理论上的完美图形——圆)
然后正六边形延伸距离都是一样的。
当然,还有很多其它的优点,我就不列举了。
以下进入正题。我们来说说,怎样在ArcGIS里面做出正六边形来。
做法例如以下:
1、首先用ArcGIS里面的渔网工具生成渔网网格:
注意,渔网生成工具,在10.4之前,位置在:
ArcToolbox ——Data Management Tools —— Feature Class工具箱以下
可是在10.4之后,位置移动到了:
ArcToolbox ——Data Management Tools ——Sampling 工具箱以下
在生成渔网的时候。一定要注意一个细节问题:
也就是高度宽度比,一定是1.5:1。假设不这样设置,那么你的六边形就会变成四边形了……切记切记。
另外我们使用的是Label Point(也就是渔网的中心点)。
生成完毕之后。将这个渔网的中心点复制一份,例如以下:
然后把label2移动到label1的对角中心位置上去,能够用渔网的交点进行參考校正。例如以下:
移动完毕之后,变成了以下这个样子:
接下去,把这个两个点图层合并起来,合并的工具用Merge或者append都能够,自选,合并完毕之后。把这个合并完毕的点图层。作为泰森多边形的中心点,生成太泰森多边形。例如以下:
泰森多边形工具在
ArcToolbox —— Analysis Tools —— Proximity —— Create Thiessen Polygons
生成完毕之后。例如以下:
然后把周边多余的部分裁掉:
蜂窝多边形到此完毕……
这一系列过程,能够通过脚本来实现,工具都已经给出了,有兴趣的同学能够自己写脚本来做。
有下面几个地方须要注意:
1、生成渔网得时候。须要大于你要覆盖的区域。依据80/20原则,你生成的渔网得extent最好大于你区域的20%左右。
2、渔网的高度和宽度比,大约在1:1.5左右,这个比例依据空间參考的不同。能够适当的微调。
3、最好用投影坐标系。
4、假设格网窗体太小。那么生成的渔网太多,会非常慢非常慢。
当然,里面还挖了一个坑……就是泰森多边形的算法,这个东东是我见过的最简单粗暴的算法……灰常灰常简单,有空
我们再说了。
蜂窝多边形的脚本工具,有须要的能够给我发邮件:allenlu2008@163.com。
ArcGIS中生成蜂窝多边形算法解析的更多相关文章
- Android逆向之旅---Android中锁屏密码算法解析以及破解方案
一.前言 最近玩王者荣耀,下载了一个辅助样本,结果被锁机了,当然破解它很简单,这个后面会详细分析这个样本,但是因为这个样本引发出的欲望就是解析Android中锁屏密码算法,然后用一种高效的方式制作锁机 ...
- libevent中最小堆实现算法解析
libevent,一个非常好的c的网络库,最近开始学习并分析下,做个记录.源码选用的1.4版本.因为感觉这版的代码比较精简,也没有太多宏定义,个人感觉适合学习原理. 从哪里开始呢,我选择从一些最简单的 ...
- ArcGIS中实现指定面积蜂窝(正六边形)方法
本篇博文为博主(whgiser)原创,转载请注明. 空间聚集研究中,地理尺度大多数都是基于格网构建的,只需fishnet下就行了.也常有使用社区.交通小区(TZ)作为研究单元的.直到发现蜂窝网络做出的 ...
- arcgis中DEM如何生成等高线
地形图指比例尺大于1∶100万的着重表示地形的普通地图(根据经纬度进行分幅,常用有1:100万,1:50万,1比25万,1:15万,1:10万,1:5万等等).由于制图的区域范围比较小,因此能比较精确 ...
- JAVA中生成、解析二维码图片的方法
JAVA中生成.解析二维码的方法并不复杂,使用google的zxing包就可以实现.下面的方法包含了生成二维码.在中间附加logo.添加文字功能,并有解析二维码的方法. 一.下载zxing的架包,并导 ...
- 转:JS中生成和解析JSON
原文地址:JS中生成和解析JSON 1.JS中生成JSON对象的方法: var json = []; var row1 = {}; row1.id= "1"; row1.name ...
- JS中生成和解析JSON
1.JS中生成JSON对象的方法: var json = []; var row1 = {}; row1.id= "1"; row1.name = "jyy"; ...
- Java中使用DOM4J来生成xml文件和解析xml文件
一.前言 现在有不少需求,是需要我们解析xml文件中的数据,然后导入到数据库中,当然解析xml文件也有好多种方法,小编觉得还是DOM4J用的最多最广泛也最好理解的吧.小编也是最近需求里遇到了,就来整理 ...
- arcgis中栅格矢量计算技巧收藏
编辑 一.计算面积 ( 可以帮我们计算小班面积 )添加 AREA 字段,然后右键点击字段列,然后点击 CALCULATE VALUES; ---> 选择 ADVANCED -->把下 ...
随机推荐
- java_lock锁
lock锁是一个接口,jdk5.0新增的接口: 在线程中创建一个他的实现类对象Reentrantlock,默认为fals可以改为true,改为true后是有序的 把操作共享资源的代码放入try中,在t ...
- 【数据库】DML-增删改查-SQL实现
一.数据插入-Insert 1. 插入单条记录 insert into 表名(字段名,字段名,字段名) //当插入所有字段时,字段名可以省略 values('值1','值2','值3'); 2. 插入 ...
- mybatis返回map类型数据空值字段不显示(三种解决方法)
转http://blog.csdn.net/lulidaitian/article/details/70941769 一.查询sql添加每个字段的判断空 IFNULL(rate,'') as rate ...
- popup介绍
一.作用 用于使浏览器自动生成弹窗 二.示例 1.新建Django项目,新建APP:app01, 项目根目录下新建文件夹static 2.静态文件配置,在settings.py中配置static: 3 ...
- HDU 2647 逆向拓扑排序
令每一个员工都有一个自己的等级level[i] , 员工等级越高,那么工资越高,为了使发的钱尽可能少,所以每一级只增加一单位的钱 输入a b表示a等级高于b,那么我们反向添加边,令b—>a那么i ...
- codeforces 361B
#include<stdio.h> int a[100100]; int main() { int n,i,k; while(scanf("%d%d",&n,& ...
- Bzoj3060 [Poi2012]Tour de Byteotia
3060: [Poi2012]Tour de Byteotia Time Limit: 30 Sec Memory Limit: 256 MBSubmit: 251 Solved: 161 Des ...
- hdu - 1151 Air Raid(有向无环图的最小路径覆盖)
http://acm.hdu.edu.cn/showproblem.php?pid=1151 在一个城市里有n个地点和k条道路,道路都是单向的,并且不存在环.(DAG) 现在伞兵需要去n个地点视察,伞 ...
- transaction transaction transaction 最大费用最大流转化到SPFA最长路
//当时比赛的时候没有想到可以用SPFA做,TLE! Problem Description Kelukin is a businessman. Every day, he travels aroun ...
- [bzoj1895][Pku3580]supermemo_非旋转Treap
supermemo bzoj-1895 Pku-3580 题目大意:给定一个n个数的序列,需支持:区间加,区间翻转,区间平移,单点插入,单点删除,查询区间最小值. 注释:$1\le n\le 6.1\ ...