全国高分辨率土地利用数据服务 土地利用数据服务 土地覆盖数据服务 坡度数据服务 土壤侵蚀数据服务 全国各省市DEM数据服务 耕地资源空间分布数据服务 草地资源空间分布数据服务 林地资源空间分布数据服务 水域资源空间分布数据服务 建设用地空间分布数据服务 地形、地貌、土壤数据服务 分坡度耕地数据服务 全国大宗农作物种植范围空间分布数据服务
多种卫星遥感数据反演植被覆盖度数据服务 地表反照率数据服务 比辐射率数据服务 地表温度数据服务 地表蒸腾与蒸散数据服务 归一化植被指数数据服务 叶面积指数数据服务 净初级生产力数据服务 净生态系统生产力数据服务 生态系统总初级生产力数据服务 生态系统类型分布数据服务 土壤类型质地养分数据服务 生态系统空间分布数据服务 增强型植被指数数据服务
多年平均气温空间分布数据服务 多年平均降水量空间分布数据服务 湿润指数数据服务 大于0℃积温空间分布数据服务 光合有效辐射分量数据服务 显热/潜热信息数据服务 波文比信息数据服务 地表净辐射通量数据服务 光合有效辐射数据服务 温度带分区数据服务 山区小气候因子精细数据服务
全国夜间灯光指数数据服务 全国GDP公里格网数据服务 全国建筑物总面积公里格网数据服务 全国人口密度数据服务 全国县级医院分布数据服务 人口调查空间分布数据服务 收入统计空间分布数据服务 矿山面积统计及分布数据服务 载畜量及空间分布数据服务 农作物种植面积统计数据服务 农田分类面积统计数据服务 农作物长势遥感监测数据服务 医疗资源统计数据服务 教育资源统计数据服务 行政辖区信息数据服务
Landsat 8 高分二号 高分一号 SPOT-6卫星影像 法国Pleiades高分卫星 资源三号卫星 风云3号 中巴资源卫星 NOAA/AVHRR MODIS Landsat TM 环境小卫星 Landsat MSS 天绘一号卫星影像
下面以一个例子显示了如何进行拓扑分析操作,主要用到了ITopologicalOperator接口,例子先查找适合条件的多边形要素,然后建立这个要素的两个缓冲区Buffer1和Buffer2,再利用Difference对两个缓冲区进行差运算,得到最后的多边形。
注意的是:要进行拓扑操作,几何图形必须是拓扑简单的。如果几何图形在上一次简单检查后没有改变过,则通过IsKnownSimple属性返回真。而IsSimple方法会真正去进行几何的简单性检查,前者会有更高的效率,尤其在循环当中。Simplfy方法可以修改几何图形,确保其符合该类几何的所有的简单的规则。
另外,用来进行空间操作的几何图形必须具有相同的坐标系统,IGeometry::Project可以用来在准备进行空间操作前将几何的坐标系进行转换。
Dim pFeatLyr As IFeatureLayer
pFeatLyr = New FeatureLayer
Dim pMap As IMap
pMap = AxMapControl1.Map
下面查找图层名字为STATES的图层索引号
Dim i As Integer
For i = 0 To pMap.LayerCount - 1
If pMap.Layer(i).Name = "STATES" Then
pFeatLyr = pMap.Layer(i)
Exit For
End If
Next
Dim pFeatClass As IFeatureClass
pFeatClass = pFeatLyr.FeatureClass
下面查找FID为1的要素
Dim pQueryFilter As IQueryFilter
pQueryFilter = New QueryFilter
pQueryFilter.WhereClause = "FID=1"
Dim pFeatCursor As IFeatureCursor
pFeatCursor = pFeatClass.Search(pQueryFilter, True)
Dim pFeat As IFeature
pFeat = pFeatCursor.NextFeature
Dim pGeometry As IGeometry
pGeometry = pFeat.Shape
下面进行缓冲区分析
Dim pTopo As ITopologicalOperator
pTopo = pGeometry
建立缓冲区的距离
Dim pDist1 As Double
Dim pDist2 As Double
pDist1 = ConvertPixelToMapUnits(pMap, 10)
pDist2 = ConvertPixelToMapUnits(pMap, 30)
缓冲区分析
Dim pBuffer1 As IGeometry
pBuffer1 = pTopo.Buffer(pDist1)
Dim pBuffer2 As IGeometry
pBuffer2 = pTopo.Buffer(pDist2)
两个缓冲区差运算得到最终的多边形pResultGeometry
Dim pResultGeometry As IGeometry
pTopo = pBuffer2
pResultGeometry = pTopo.Difference(pBuffer1)
下面在地图中显示出来
Dim pPolygonEle As IFillShapeElement
pPolygonEle = New PolygonElement
Dim pEle As IElement
pEle = pPolygonEle
pEle.Geometry = pResultGeometry
Dim pColor As IRgbColor
pColor = New RgbColor
pColor.Red = 110
pColor.Green = 120
pColor.Blue = 210
Dim pFillSym As ISimpleFillSymbol
pFillSym = New SimpleFillSymbol
pFillSym.Color = pColor
pPolygonEle.Symbol = pFillSym
Dim pGraph As IGraphicsContainer
pGraph = pMap
pGraph.AddElement(pPolygonEle, 0)
Dim pActiveView As IActiveView
pActiveView = pMap
pActiveView.PartialRefresh(esriViewDrawPhase.esriViewGraphics, Nothing, Nothing)