Qgs开发16-拓扑分析

Qgs开发-拓扑分析

[email protected]

2014年10月22日

1  概述

拓扑分析一般是指地理元素之间的相关关系。一般是以基本的空间关系为基础,进行综合运算,计算元素之间的复杂关系,如空洞检查、重叠检查等。

参考:http://en.wikipedia.org/wiki/Geospatial_topology

http://en.wikipedia.org/wiki/DE-9IM

http://help.arcgis.com/zh-cn/arcgisdesktop/10.0/help/index.html#//006200000003000000

http://docs.qgis.org/2.0/en/docs/user_manual/plugins/plugins_topology_checker.html

2 原理

针对特定的几何关系,综合运行基本空间关系,检测出特定的目标元素。

3 方法

3.1 空洞检测(gaps):检测一个多边形是否存在空洞

1)   首先获取多边形geo的外接多边形,并做一个缓冲区buff,目的是最外层的多边形是一个完整的多边形。

2)   然后将这个buff与geo做difference运算,获取在buff中,而不在geo中的多边形,此时会生成最外层的一个多边形(第一部中如果不做buff,这里会有很多的外部多边形,无法与内容空洞区别)和内部的空洞。

3)   删除最外层的多边层,剩余的多边形就是内部的空洞。

3.2 边界融合:将一个多边形的边界合并到另一个多边的公共边上,删除相交部分,填补空洞

1)   首先删除相交部分:geo2与geo1做difference,从geo2中删除与geo1相交的部分。

2)   然后将geo2与geo1合并(combine),检测合并后多边形的空洞(参见空洞检测(gaps):检测一个多边形是否存在空洞)。

3)   将空洞与第一步中的diff合并:将所有空洞添加到geo2中。

4 示例

4.1 空洞检测detectGaps

/**

*@briefQgsVectorAnalysis::detectGaps

*

*getgeometrygaps.

*@notefromtopoTest.cpp

*@parampGeo

*@returngapsgeometry

*@author[email protected]

*@date2014-10-2118:31:50

*/

QgsGeometry*QgsVectorAnalysis::detectGaps(QgsGeometry*pGeo)

{

//how:

//1.BufferConvexHull:buffertheconverxhull.

//2.Difference:getdifferencewithgeoandbuffer.

//3.DeleteOuterpoly:returngeowithoutfirst.

QgsGeometry*pConvexHull=pGeo->convexHull();

QgsGeometry*pBuff=pConvexHull->buffer(2,3);

QgsGeometry*pDiff=pBuff->difference(pGeo);

if(pDiff->isMultipart())

{

QgsMultiPolygonmp=pDiff->asMultiPolygon();

QgsMultiPolygonmpGaps=mp.mid(1);

QgsGeometry*pGaps=NULL;

if(mpGaps.size()>1){

pGaps=QgsGeometry::fromMultiPolygon(mpGaps);

}else

{

pGaps=QgsGeometry::fromPolygon(mpGaps[0]);

}

returnpGaps;

}

else

{

returnNULL;

}

}

4.2 边界融合mergeBorder

/**
*@briefQgsVectorAnalysis::mergeBorder
*
*merge:deleteintersectandaddgapstogeo2.
*@parampGeo1
*@parampGeo2
*@returnmergeredgeometry
*@author[email protected]
*@date2014-10-2016:19:16
*/
QgsGeometry*QgsVectorAnalysis::mergeBorder(QgsGeometry*pGeo1,
                                                   QgsGeometry*pGeo2)
{
    //how:
    //1.difference:getthegeo2withoutintersection.
    //2.gaps:gapsindiffandgeo1.
    //3.combinegapswithdiff:allgapswillbeaddedtodiff.
 
    //pGeo2DiffpGeo1
    QgsGeometry*pDiff=pGeo2->difference(pGeo1);
 
    //gaps
    QgsGeometry*pCombine=pGeo1->combine(pDiff);
    QgsGeometry*pGaps=detectGaps(pCombine);
    qDebug()<<"gaps="<<pGaps->exportToWkt();
 
    //combineallgapstodiff
    QgsGeometry*pMergeBorder=pDiff;
    if(NULL==pGaps){
        returnpMergeBorder;
    }
 
    if(pGaps->isMultipart())//multigaps
    {
        QgsMultiPolygonmp=pGaps->asMultiPolygon();
        for(inti=0;i<mp.size();++i)
        {
            QgsGeometry*pGapItem=QgsGeometry::fromPolygon(mp[i]);
            pMergeBorder=pMergeBorder->combine(pGapItem);
        }
 
    }
    else
    {
        pMergeBorder=pMergeBorder->combine(pGaps);
    }
    qDebug()<<"pMergeBorder="<<pMergeBorder->exportToWkt();
 
    returnpMergeBorder;
}
时间: 2024-12-20 10:27:35

Qgs开发16-拓扑分析的相关文章

移动三大平台和三大开发模式对比分析

一:移动三大平台及其对比分析: 1)移动三大平台 2)移动三大平台对比分析 二:三大开发模式及其对比分析: 1)三大开发模式 2)三大开发模式对比分析 移动三大平台和三大开发模式对比分析,布布扣,bubuko.com

久省优选系统商城开发app平台分析

久省优选系统商城开发app平台分析 王泽:151-1222-4001(微信同步)久省优选app开发,久省优选系统开发,久省优选模式开发,久省优选返利系统平台,久省优选平台开发,久省优选分系统,久省优选分红系统,久省优选软件开发,久省优选公众号搭建,久省优选购物商城,久省优选定制开发. 从"低头族"日益增多的人数来看,我们就可以知道智能手机的发展是多么好了.现在80.90的小年轻们起床的第一件事就是拿起手机刷一下朋友圈,由此可见,微信的发展也是极好的,人们无论是吃饭.逛街.约会或者是在特

Storm系列(一):搭建dotNet开发Storm拓扑的环境

上篇博客比较了目前流行的计算框架特性,如果你是 Java 开发者,那么根据业务场景选择即可:但是如果你是 .Net 开发者,那么三者都不能拿来即用,至少在这篇文章出现之前是如此.基于上篇文章的比较发现,Storm 应该是对多语言支持比较好的框架了,但即便如此,官方也没有提供 .Net 的适配器,网上也找不到第三方的开源库.So,Storm.Net.Adapter 出现了,一个使用 Csharp 开发的 针对 Apache Storm 的适配器!项目由本人开发,按照Apache License,

RK30SDK开发板驱动分析(二):DDR频率配置

在内核配置界界面,我们可以很容易的配置DDR的频率,300M OR 600M, so easy! 那么它是如何起作用的呢? 回想 RK30SDK开发板驱动分析(一) 末尾提到MACHINE_START是系统开始的地方,位于board-rk30-box.c ,注意里面有个函数rk30_map_io MACHINE_START(RK30, "RK30board") .boot_params = PLAT_PHYS_OFFSET + 0x800, .fixup = rk30_fixup, .

微享商盟小程序开发系统框架分析

从微信小程序发布这段时间,陆陆续续开发了不少小程序相关的项目,总结了一些通用性的组件,但是对于小程序如何做测试,依然是一头雾水,直到做了不少的项目,积累的一些经验和开源库之后才理清如何做测试,下面将会介绍如何对小程序做UI测试和单元测试. 微信小程序微享商盟具体做什么? --举例,顾客到某水果店购买商品后通过微信小程序共享链支付成功后进入微信小程序微享商盟小程序,该小程序里面会显示消费者的消费金额,奖励金额和已经到账金额,之后其他消费者也到该水果店消费,那微信小程序微享商盟系统会做一个时间排序,

arcgis建立拓扑分析(检验矢量图)

目的:矢量图画好后,检查是否有伪节点,悬挂节点等,线要素和面要素都可以检查.伪节点,两条线应该相交但是画的没相交:悬挂节点,两条线看似相交了但是没有节点,因此路径不同(类似于高架桥和交叉口,悬挂节点就类似高架桥) 基本步骤: 1.建立拓扑 2.验证拓扑 拓扑的建立可在arcCatalog里完成,也可以在arcMap里右侧目录下完成(本人常称小catalog).catalog是管理文件的一个软件. 注意!!建立拓扑之前需要将要素导入到数据库里的数据集中. 下面简述这个问题.通常来说在arcgis里

韩剧TV UWP开发---抓包分析

一,使用工具 ①Fiddler 摘自百度百科Fiddler简介: Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的"进出"Fiddler的数据(指cookie,html,js,css等文件,这些都可以让你胡乱修改的意思). Fiddler 要比其他的网络调试器要更加简单,因为它不仅仅暴露http通讯还提供了一个用户友好的格式. 下载地址: http://rj.baidu.com/soft/detail/10963

小组开发项目--NABC分析

我们小组--女神经们,开发项目是重力解锁,我认为我们的项目的最大特点就是不使用开锁键唤醒屏幕.下面我将针对这一特点进行NABC分析: N:经调查一部分人群的手机不能使用就是开机键坏了,我们就是针对这一问题,提出解决方案: A:这学期学习Android,之前有java基础,可以用这两个工具完成: B:减少开机键是使用次数,增强手机的寿命: C:现在市场上多数解锁软件要使用开机键,我们这款应用避免了这一问题,竞争还是可观的.

Android内核开发:学会分析系统的启动log

本文是<Android内核开发>系列的第八篇文章,本文主要关注如何分析Android系统的启动log,学会通过搜索重要的TAG标签,找到Android启动过程中的重要节点. 要学会分析系统的启动log信息,首先得了解Android系统的启动过程,建议先阅读<Android内核开发:图解Android系统的启动过程>这篇文章,它详细介绍了Android系统的启动过程.其次,你需要知道如何抓取系统启动log信息,建议阅读<Android内核开发:如何统计系统启动时间>这篇文