GIS中栅格数据转换矢量数据算法
发布时间: 2014-02-21
所属分类: 地理信息系统(GIS)原理
在上一篇文章GIS中将矢量数据转换删格数据算法中提到了矢量数据转换删格数据的方法;同样,在GIS中删格数据转换为矢量数据也是同样重要的操作,在本文中将介绍GIS系统中把删格数据转换为矢量数据的具体算法。下面是操作步骤:
1.二值化
由于扫描后的图像是以不同灰度级存储的,为了进行栅格数据矢量化的转换,需压缩为两级(0和1),称为二值化。
2、二值图像的预处理
对于扫描输入的图幅,由于原稿不干净等原因,总是会出现一些飞白、污点、线划边缘凹凸不平等。
3.细化(剥皮法、骨架法)
所谓细化就是将二值图像象元阵列逐步剥除轮廓边缘的点,使之成为线划宽度只有一个象元的骨架图形。细化后的图形骨架既保留了原图形的绝大部分特征,又便于下一步的跟踪处理。
细化的基本过程是:
- 确定需细化的象元集合;
- 移去不是骨架的象元;
- 重复,直到仅剩骨架象元。
如果是对扫描后的地图图像进行细化处理,应符合下列基本要求:
- 保持原线划的连续性;
- 线宽只为一个象元;
- 细划后的骨架应是原线划的中心线;
- 保持图形的原有特征。
4、追踪
细化后的二值图像形成了骨架图,追踪就是把骨架转换为矢量图形的坐标序列。其基本步骤为:
- 从左向右,从上向下搜索线划起始点,并记下坐标。
- 朝该点的8个方向追踪点,若没有,则本条线的追踪结束,转(1)进行下条线的追踪;否则记下坐标。
- 把搜索点移到新取的点上,转(2)
注意的是,已追踪点应作标记,防止重复追踪。
5.拓扑化
为了进行拓扑化,需找出线的端点和结点,以及孤立点。
- 孤立点:8邻城中没有为1的象元。如图(1)。
- 端点:8邻城中只有一个为1的象元。如图(2)。
- 结点:8邻城中有三个或三个以上为1的象元。如图(3)。
相关阅读
声明
1.本文所分享的所有需要用户下载使用的内容(包括但不限于软件、数据、图片)来自于网络或者麻辣GIS粉丝自行分享,版权归该下载资源的合法拥有者所有,如有侵权请第一时间联系本站删除。
2.下载内容仅限个人学习使用,请切勿用作商用等其他用途,否则后果自负。
手机阅读
公众号关注
知识星球
手机阅读
最新GIS干货
私享圈子
下一篇:GIS中的空间认知三层模型
具体是要如何操作呢?
看不懂 555