转载自: http://bbs.esrichina-bj.cn/ESRI/thread-48168-1-1.html
空间分析功能是GIS的主要功能之一,本章将为读者介绍一些GIS开发常用的功能涉及到的空间拓扑运算,空间关系运算,空间临近运算所使用到的接口。例如开发一个缓冲区分析功能,获取两个几何要素的最短距离,判断两个几何要素的拓扑关系等都需要使用到这些接口,使用这些接口可以极大提高开发者的开发效率。
1.1目标
1.熟悉ITopologicalOperator接口(用于空间拓扑运算)的使用
2.熟悉IRelationalOperator接口(用于空间关联运算)的使用
3.熟悉IProximityOperator接口(用于空间距离运算)的使用
1.2准备工作
1.IDE:Visual Studio 2005/2008
2.ArcGIS Engine Developer kit 9.3
1.1 ITopologicalOperator接口1.1.1 ITopologicalOperator接口简介ITopologicalOperator接口用来通过对已存在的几何对象做空间拓扑运算以产生新的结合对象。实现该接口的类有Point,Multipoint,Polyline,Polygon,MultiPatch这些都是高级几何对象,另外 GeometryBag也实现了该接口,低级的构建几何对象如Segments(Line,Circular Arc,Elliptic Arc,Bezier Curve),Paths或者Rings如果想使用该接口需包装成高级几何对象。
ITopologicalOperator接口在GIS开发中使用非常广泛,通常GIS系统中缓冲区分析,裁剪几何图形,几何图形差分操作,几何图形合并操作等都需要使用此接口。下表是ITopologicalOperator接口主要的方法说明:
方法名称 | 说明 |
Boundary | 几何图形对象的边界 |
Buffer | 对几何图形对象进行缓冲区空间拓扑操作 |
Clip | 对几何图形对象进行裁剪空间拓扑操作 |
ConstructUnion | 高效的合并多个枚举几何对象与单个几何对象合并为单个几何对象,这对于大量几何对象的合并非常高效 |
ConvexHull | 构建几何对象的凸边形 |
Cut | 切割几何对象 |
Difference | 一个几何图形减去它与另一个几何图形相交的部分 |
Intersect | 两个同维度几何对象的交集部分 |
Simplify | 使几何对象拓扑一致 |
SymmetricDifference | 对称差分将两个几何图形的并集部分减去两个几何图形交集的部分 |
Union | 合并两个同维度的几何对象为单个几何对象 |
1. Boundary属性
如图所示Polygon几何对象的Boundary是组成它的Polyline几何对象
Polyline几何对象的[Boundary是组成它的顶点Point几何对象
而Point几何对象的Boundary是空对象,示意图如下图所示:
下载 (20.15 KB)
2009-6-15 09:12
2.Buffer方法:
Buffer方法可以给一个高级几何对象产生一个缓冲区,无论是Polygon,Polyline,Point它们的缓冲区都是具有面积的几何对象,如下图所示:
下载 (11.73 KB)
2009-6-15 09:12
3.Clip方法
Clip方法可以将用一个Envelope对象对一个几何对象进行裁剪,参见结果是几何对象被Envelope 对象所包围的部分如图所示:
下载 (16.11 KB)
2009-6-15 09:12
4.ConvexHull方法
ConvexHull方法可以产生一个几何图形的最小的边框凸多边形(没有凹面包含几何图形的最小多边形)
下载 (11.54 KB)
2009-6-15 09:12
5.Cut方法
Cut方法不支持GeometryBags几何对象,它可以指定一条切割曲线和一个几何图形,经过切割运算后把几何图形分为左右两部分,做,右两部分是相对曲线的方向而言。点与多点不能被切割,Polyline和Polygon只有与切割曲线相交时才能执行Cut方法,如下图:
下载 (10.03 KB)
2009-6-15 09:12
6.Difference方法
Difference方法用于产生两个几何对象的差集。如图所示:
下载 (10.61 KB)
2009-6-15 09:12
7.Union方法和ConstructUnion都用于合并几何对象,所不同的是前者合并两个同维度的几何对象为单个几何对象,而后者是高效的合并多个枚举几何对象与单个几何对象合并为单个几何对象,这对于大量几何对象的合并非常高效的。
下载 (5.69 KB)
2009-6-15 09:12
8.Intersect方法
Intersect方法用于返回两个同维度几何对象的交集,即两个几何对象的重合部分。如下图所示:
下载 (8.04 KB)
2009-6-15 09:12
9.SymetricDifference方法
SymetricDifference方法用于产生两个几何图形的对称差分,即两个几何的并集部分减去两个几何的交集部分,如下图所示:
下载 (12.38 KB)
2009-6-15 09:12
10.IsSimple属性和Simplify方法
IsSimple属性用于检测几何对象是否是拓扑正确即为简化几何对象,而Simplify方法用于简化几何对象使几何对象的拓扑正确。如下图所示:
下载 (50.01 KB)
2009-6-15 09:12
-
image001.png (20.15 KB)
下载次数:4
2009-6-15 09:12
-
image003.png (11.73 KB)
下载次数:3
2009-6-15 09:12
-
image005.png (16.11 KB)
下载次数:3
2009-6-15 09:12
-
image007.png (11.54 KB)
下载次数:1
2009-6-15 09:12
-
image009.png (10.03 KB)
下载次数:3
2009-6-15 09:12
-
image011.png (10.61 KB)
下载次数:3
2009-6-15 09:12
-
image013.png (5.69 KB)
下载次数:6
2009-6-15 09:12
-
image015.png (8.04 KB)
下载次数:4
2009-6-15 09:12
6.3.2简化几何对象功能开发
在开发对几何对象空间分析时,所操作的几何对象必须是简化的几何对象,以下代码片段演示了如何使一个几何对象在拓扑上一致,例如在一个 PointCollection对象中移除所有的重合点;对于segmentCollection移除所有重合线段,而相交的线段会变成非相交线段(即在相交处产生一个顶点);对于Polygon所有相交的环将被移除,未封闭的环将被封闭。
- /// <summary>
- /// 简化几何对象
- /// </summary>
- /// <param name="pGeometry">几何对象</param>
- private void SimplifyGeometry(IGeometry pGeometry)
- {
- try
- {
- ITopologicalOperator pTopOperator = pGeometry as ITopologicalOperator;
- if (pTopOperator != null)
- {
- if (!(pTopOperator.IsKnownSimple))
- {
- if (!(pTopOperator.IsSimple))
- {
- pTopOperator.Simplify();
- }
- }
- }
- }
- catch (Exception Err)
- {
- MessageBox.Show(Err.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
- }
- }
复制代码
6.4 IRelationalOperator接口
6.4.1 IRelationalOperator接口简介几何对象之间都存在某种关联关系,如包含,相等,在内部,相交,叠加等。这些关联关系的获得都可以通过 IRelationalOperator接口来获得,关系运算是在两个几何对象间进行的,通过IRelationalOperator的某一个方法返回一个布尔值来说明这两个几何对象是否有这种关系。所有支持ITopologicaloperator的几何对象的类也实现了 IRelationalOperator接口,其中包括Envelope对象,这意味着还可以对两个几何对象的Envelope进行关联关系检查。
方法名称 | 描述 |
Contains | 检查两个几何图形几何图形1是否包含几何图形2 |
Crosses | 用于检测两个几何图形是否相交 |
Equal | 用于检测两个几何图形是否相等 |
Touches | 用于检测两个几何图形是否相连 |
Disjoint | 用于检测两个几何图形是否不相交 |
Overlaps | 用于检测两个几何图形是否有重叠 |
Relation | 用于检测是否存在定义relationship |
Within | 检查两个几何图形几何图形1是否被包含于几何图形2 |
6.4.2判断几何对象包含关系功能开发 以下代码片段演示如何判断几何图形A是否包含几何图形B:
- /// <summary>
- /// 检测几何图形A是否包含几何图形B
- /// </summary>
- /// <param name="pGeometryA">几何图形A</param>
- /// <param name="pGeometryB">几何图形B</param>
- /// <returns>True为包含,False为不包含</returns>
- private bool CheckGeometryContain(IGeometry pGeometryA, IGeometry pGeometryB)
- {
- IRelationalOperator pRelOperator = pGeometryA as IRelationalOperator;
- if (pRelOperator.Contains(pGeometryB))
- {
- return true;
- }
- else
- {
- return false;
- }
- }
复制代码
6.5 IProximityOperator接口
6.5.1 IProximityOperator接口简介
IProximityOperator接口用于获取两个几何图形的距离,以及给定一个 Point,求另一个几何图形上离离给定点最近的点。IProximityOperator接口的主要方法有:QueryNearesPoint,ReturnDistance, ReturnNearestPoint
ReturnDistance方法用于返回两个几何对象间的最短距离,QueryNearesPoint方法用于查询获取几何对象上离给定输入点的最近距离的点的引用,ReturnNearestPoint方法用于创建并返回几何对象上离给定输入点的最近距离的点。
6.5.2 最近点查询功能开发
以下代码片段演示如何使用IProximityOperator接口获取给定点与要查询的几何图形的最近点:
- /// 在pGeometry上返回一个离pInputPoint最近的point
- /// </summary>
- /// <param name="pInputPoint">给定的点对象</param>
- /// <param name="pGeometry">要查询的几何图形</param>
- /// <returns>the nearest Point</returns>
- private IPoint NearestPoint(IPoint pInputPoint, IGeometry pGeometry)
- {
- try
- {
- IProximityOperator pProximity = (IProximityOperator)pGeometry;
- IPoint pNearestPoint = pProximity.ReturnNearestPoint(pInputPoint, esriSegmentExtension.esriNoExtension);
- return pNearestPoint;
- }
- catch(Exception Err)
- {
- MessageBox.Show(Err.Message, "提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
- return null;
- }
- }
复制代码
以下代码片段演示如何使用IProximityOperator接口查询给定的两个几何对象的距离:
- /// <summary>
- /// 获取两个几何图形的距离
- /// </summary>
- /// <param name="pGeometryA">几何图形A</param>
- /// <param name="pGeometryB">几何图形B</param>
- /// <returns>两个几何图形的距离</returns>
- private double GetTwoGeometryDistance(IGeometry pGeometryA, IGeometry pGeometryB)
- {
- IProximityOperator pProOperator = pGeometryA as IProximityOperator;
- if (pGeometryA!=null|| pGeometryB !=null)
- {
- double distance= pProOperator.ReturnDistance(pGeometryB);
- return distance;
- }
- else
- {
- return 0;
- }
- }
复制代码