ArcGIS Flex API进行缓冲分析的讨论

本文介绍如何使用ArcGIS Flex API中的GeometryService服务进行点、线和多边形的缓冲分析。针对不同的几何类型,需设置合适的单位和坐标系。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在ArcGIS Flex API中可以通过GeometryService服务来进行缓冲分析,下面我们来探讨一下缓冲分析的实现。API中有<esri:GeometryService />专门用于处理Geometry服务,要进行缓冲分析,首先我们需要在ArcCatalog里面建立一个Geometry服务,建立好了我们就可以在Flex中进行代码编写了。

我设想在地图中先添加地图文件,我们可以前面我们说的LibertyGIS来添加本地shapfile文件到GraphicLayer,也可以自己代码绘制一个多边形在GraphicLayer上,我们点击这个多边形即进行缓冲分析,将分析结果添加到GraphicLayer上,操作完成。然而值得我们注意的是,缓冲分析中点和多点的处理方式与线和多边形不同,在网上找到下面这句话:

       点(Points)和多点(Multipoints):若单位(unit)是长度的,如:米、英尺等,测地线缓冲(geodesic buffering)分析将执行 is performed. 
        线(Polylines)和多边形(Polygons):单位(unit)必须是角度的,如:十进制度数,缓冲区分析才能执行。

首先我们来看看点的缓冲分析,代码如下:

			private function mouseClickHandler(e:MouseEvent):void
			{
				var myMapCenterPoint:MapPoint = MapPoint(map.extent.center);
				var bufferParm:BufferParameters=new BufferParameters();
				bufferParm.bufferSpatialReference = map.spatialReference;
				bufferParm.outSpatialReference=map.spatialReference;
				bufferParm.unit=GeometryService.UNIT_KILOMETER;
				bufferParm.distances=[50];   //这里采用的是长度单位
				bufferParm.geometries=[myMapCenterPoint];
				myGeometryService.addEventListener(GeometryServiceEvent.BUFFER_COMPLETE, bufferCompleteHandler);
				myGeometryService.buffer(bufferParm);
			}
			function bufferCompleteHandler(event:GeometryServiceEvent):void
			{
				var sfs:SimpleFillSymbol=new SimpleFillSymbol("solid",0xff0000,1,sls);
				myGeometryService.removeEventListener(GeometryServiceEvent.BUFFER_COMPLETE, bufferCompleteHandler);
				for each (var geometry:Polygon in event.result)
				{
					var graphic:Graphic = new Graphic();
					graphic.geometry = geometry;
					graphic.symbol = sfs;
					graphicsLayer.add(graphic);
				}
			}
结果如下图:


线和多边形进行缓冲分析需要对线或多边形设定参考坐标系,并且以弧度作为距离单位,下面我们以多边形为例,代码如下:

			private function mouseClickHandler(e:MouseEvent):void
			{
				var gra:Graphic=e.currentTarget as Graphic;
				var polygon:Polygon=gra.geometry as Polygon;
				polygon.spatialReference=map.spatialReference;//设定参考坐标系
				var bufferParm:BufferParameters=new BufferParameters();
				bufferParm.bufferSpatialReference = map.spatialReference;
				bufferParm.outSpatialReference=map.spatialReference;
				bufferParm.unit=GeometryService.UNIT_KILOMETER;
				bufferParm.distances=[50/6378137.0 * 180.0/Math.PI];//单位转换为弧度单位
				bufferParm.geometries=[polygon];
				myGeometryService.addEventListener(GeometryServiceEvent.BUFFER_COMPLETE, bufferCompleteHandler);
				myGeometryService.buffer(bufferParm);
			}

结果如下图:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值