ArcEngine拓扑
空间拓扑描述的是自然界地理对象的空间位置关系-相邻,重合,连通等,是地理对象空间属性的一部分.目前ESRI提供的数据存储方式中,Coverage和GeoDatabase能够建立拓扑,Shape格式的数据不能建立拓扑.
1. GeoDataBase建立拓扑的基础
1).GeoDatabase实现拓扑的基础是”几何重合”,Geodatabase中的地理对象都是实体存储,主要是根据节点坐标是否重合来判断地理要素之间是否存在某种拓扑关系
2).拓扑只能在要素集(FeatureDataset)中创建,参加创建拓扑的所有要素类(FeatureClass)必须具有相同的空间参考
3).参与拓扑创建的必须是简单要素类,注记类(Annoca),尺寸和几何网络要素类不能参与拓扑的创建
4)单个要素集可以创建多个拓扑
2. GeoDatabase拓扑中的重要概念
1).规则:表达要素之间的空间关系,ESRI提供了27中拓扑关系(见后面附表)
2).拓扑容限.决定在多大范围内要素能够被捕捉在一起(也称为聚类容限(cluster tolerance))
3).拓扑等级 控制在拓扑验证的过程中节点移动的级别.这时候,等级低的要素类将向等级高的要素类移动,最高级别为1,最低级别为-50
4).脏区(dirty area):脏区就是参与拓扑创建时被修改的地理要素(增,删,改)的区域
5).错误要素(Error Feature):只要素类中不符合拓扑规则的要素或者要素的一部分
3. 使用拓扑的详细步骤及代码
1).创建拓扑
ITopology是一个不可创建类,创建拓扑需通过调用ITopologyContainer:CreateTopology方法来建立拓扑,拓扑的规则要用ITopologyRule接口来表达,必须加到ITopologyRuleContainer中.
public void CreateTopology(IFeatureDataset featuredataset, string topologyName,esriTopologyRuleType rulename,double clusterTolerance,int classID)
{
try
{
ITopologyContainer topologyContainer = (ITopologyContainer)featureDataset;
ITopology topology=topologyContainer.CreateTopology(topologyName, clusterTolerance, -, "");
IFeatureClassContainer featureclassContainer = (IFeatureClassContainer)featureDataset;
ITopologyRuleContainer topologyRuleContainer = (ITopologyRuleContainer)topology;
ITopologyRule topologyRule = new TopologyRuleClass();
topologyRule.TopologyRuleType = rulename;
topologyRule.OriginClassID = classID;
if (topologyRuleContainer.get_CanAddRule(topologyRule))
{
topologyRuleContainer.AddRule(topologyRule);
}
}
catch (COMException ex)
{
MessageBox.Show(ex.
}
}
2).验证拓扑
通过调用ITopology:ValidateTopology 方法来验证指定区域内的拓扑,没有版本的拓扑可以在任何时候验证,指定版本的拓扑必须在编辑会话中验证
例如验证整个区域的拓扑的代码片段,假设已经存在创建好的拓扑ITopology topo
IGeoDataset geodataset=(IGeoDataset) topo; topo. ValidateTopology(geodataset. Extent.Envelope);
ESRI的拓扑规则
esriTRTAny
任何拓扑规则. 查询拓扑的时候用
esriTRTFeatureLargerThanClusterTolerance
地理要素小于聚类容限被删除
esriTRTAreaNoGaps
面是封闭的
esriTRTAreaNoOverlap
面不相交
esriTRTAreaCoveredByAreaClass
The rule is an area covered by area class rule.
esriTRTAreaAreaCoverEachOther
两个区域完全重合
esriTRTAreaCoveredByArea
一个区域被另一个区域覆盖
esriTRTAreaNoOverlapArea
一个面没有相交的面
esriTRTLineCoveredByAreaBoundary
线被区域的边线覆盖
esriTRTPointCoveredByAreaBoundary
点在面的边界上
esriTRTPointProperlyInsideArea
点完全在面内
esriTRTLineNoOverlap
无重合的线
esriTRTLineNoIntersection
无相交的线
esriTRTLineNoDangles
无摇摆的线
esriTRTLineNoPseudos
线不存在伪节点
esriTRTLineCoveredByLineClass
The rule is a line covered by line class rule.
esriTRTLineNoOverlapLine
The rule is a line-no overlap line rule.
esriTRTPointCoveredByLine
点被线覆盖
esriTRTPointCoveredByLineEndpoint
点被线的尾节点覆盖
esriTRTAreaBoundaryCoveredByLine
一个面的边界被线覆盖
esriTRTAreaBoundaryCoveredByAreaBoundary
一个面的边界被另一个面的边界覆盖
esriTRTLineNoSelfOverlap
不存在自重合的线
esriTRTLineNoSelfIntersect
不存在自相交的线
esriTRTLineNoIntersectOrInteriorTouch
The rule is a line-no intersect or interior touch rule.
esriTRTLineEndpointCoveredByPoint
线的尾节点被点覆盖
esriTRTAreaContainPoint
面包含点
esriTRTLineNoMultipart
The rule is a line cannot be multipart rule.
ArcEngine拓扑的更多相关文章
- arcengine 开发经典帖
http://bbs.esrichina-bj.cn/ESRI/viewthread.php?tid=25575&page=1&extra= 使用ArcGIS Engine 开发自定义 ...
- arcengine 开发经典帖 【强烈推荐仔细研读】
转自原文 arcengine 开发经典帖 使用ArcGIS Engine 开发自定义GIS应用: 第一部分:使用ArcGIS Engine 发布自定义GIS应用软件-全面了解ArcGIS Engine ...
- 算法与数据结构(七) AOV网的拓扑排序
今天博客的内容依然与图有关,今天博客的主题是关于拓扑排序的.拓扑排序是基于AOV网的,关于AOV网的概念,我想引用下方这句话来介绍: AOV网:在现代化管理中,人们常用有向图来描述和分析一项工程的计划 ...
- 有向无环图的应用—AOV网 和 拓扑排序
有向无环图:无环的有向图,简称 DAG (Directed Acycline Graph) 图. 一个有向图的生成树是一个有向树,一个非连通有向图的若干强连通分量生成若干有向树,这些有向数形成生成森林 ...
- 通过HTML5的Drag and Drop生成拓扑图片Base64信息
HTML5 原生的 Drag and Drop是很不错的功能,网上使用例子较多如 http://html5demos.com/drag ,但这些例子大部分没实际用途,本文将搞个有点使用价值的例子,通过 ...
- 【BZOJ-2938】病毒 Trie图 + 拓扑排序
2938: [Poi2000]病毒 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 609 Solved: 318[Submit][Status][Di ...
- Arcgis, ArcEngine, Arcgis Server使用开发汇总 索引
ArcGIS系列软件license及安装: Arcgis SDE10.1 和 Arcgis server10.1的授权文件license tnt_esri.dat Arcgis8.1安装license ...
- BZOJ1565 [NOI2009]植物大战僵尸(拓扑排序 + 最大权闭合子图)
题目 Source http://www.lydsy.com/JudgeOnline/problem.php?id=1565 Description Input Output 仅包含一个整数,表示可以 ...
- 图——拓扑排序(uva10305)
John has n tasks to do. Unfortunately, the tasks are not independent and the execution of one task i ...
随机推荐
- dpkg: 处理归档 /var/cache/apt/archives/软件名 (--unpack)时出错:由于已经达到 MaxReports 限制,没有写入 apport 报告。
一.环境介绍: OS:ubuntu16.04 64bit 二.错误如下: 正准备解包 .../libqt4-script_4%3a4.8.7+dfsg-5ubuntu2_i386.deb ...正在 ...
- 用FileInputStream读取数据,计算机如何实现将两个字节拼接成中文的?
package itcast_02; import java.util.Arrays; /* * 在计算机中如何识别将连个字节转换为中文的呢? * 在计算机中中文的存储为两个字节 : * 第一个字节 ...
- JavaScript中的各种宽高属性
转自慕课网:http://www.imooc.com/article/14516 在js中,存在着N多的关于高度和宽度的属性,比如:clientHeight.offsetHeight.scroll ...
- unreal slate 创建 window
testWindow = SNew(SWindow) .Title(LOCTEXT("Asset Window", "Asset Window")) .Clie ...
- 不再为Apache进程淤积、耗尽内存而困扰((转))
本篇文章是为使用Apache+MySQL,并为Apache耗尽内存而困扰的系统管理员而写.如果您没有耐心读完本文,请参考以下步骤: 修改/etc/my.cnf,加上这样一行: log-slow-que ...
- ORA-28001: the password has expired (DBD ERROR: OCISessionBegin) EM无法登录
先发句牢骚,明明刚才写完了,发布的时候却说没登陆,一下子全没了. 今天打开EM发现提示 ORA-28001: the password has expired (DBD ERROR: OCISessi ...
- java.nio.file.Path
public interface Path extends Comparable<Path>, Iterable<Path>, Watchable 1. A Path repr ...
- Windows下 Maven 使用 阿里云镜像配置
新建或者修改文件: C:\Users\user\.m2\settings.xml <settings xmlns="http://maven.apache.org/SETTINGS/1 ...
- loadrunner获取当前CST时间
第一种方法:使用LR的参数化功能. 代码如下,nowtime是保存当前CST时间的字符串变量,local_time是要参数化的变量. Action() { char *nowtime; nowtime ...
- ALT+TAB切换时小图标的添加 界面透明 屏幕大小 竖行字体 进程信息
一,ALT+TAB切换时小图标的添加 Dlg类中添加变量 protected: HICON m_hIcon; #define IDR_MAINFRAME 128 ICON IDR_MAINFRAME, ...