//需要注意的是1、不知道flex ags buffer是否支持自定义投影。因为buffer的spatial都要写wkid的
2、就是直接照着那个例子上的程序敲进去buffer不出来,查了半天知道了问题的所在原来是你要做buffer的图形必须有spatial
,看了一个例子是直接用featureSet.features[i].geometry可是查了帮助也没见features有geometry属性。解决办法
var featureSet:FeatureSet=new FeatureSet(); featureSet.features=[myGraphic];; var featureSet2:FeatureSet=new FeatureSet(); for(var i:int=0;i<featureSet.features.length;i++) { var graphic:Graphic=featureSet.features[i]; graphic.geometry.spatialReference=new SpatialReference(102100); featureSet2.features= [graphic]; } bufferParameters.features=featureSet2.features;
这样就算把空间信息赋值给了features
<?xml version="1.0" encoding="utf-8"?><mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" xmlns:esri="http://www.esri.com/2008/ags"> <mx:Canvas width="490" height="401" borderStyle="solid" borderThickness="3" verticalCenter="16" left="10"> <esri:Map id="myMap" crosshairVisible="true"> <esri:ArcGISDynamicMapServiceLayer url="http://localhost/ArcGIS/rest/services/ggg/MapServer" /> <esri:GraphicsLayer id="myGraphicsLayer" /> </esri:Map> </mx:Canvas> <mx:DataGrid id="datalist" height="398" verticalCenter="14" borderStyle="solid" borderThickness="3" left="508"> </mx:DataGrid> <esri:GeometryService id="myGeometryService" url="http://localhost/ArcGIS/rest/services/Geometry/GeometryServer"/> <esri:SimpleFillSymbol id="sfs" color="0xFF0000" alpha="0.6"/> <esri:Draw id="drawToolbar" map="{myMap}" graphicsLayer="{myGraphicsLayer}" drawEnd="drawEndHandler(event)" /> <mx:ToggleButtonBar verticalCenter="-203" itemClick="itemClickHandler(event)" toggleOnClick="true" left="11"> <mx:dataProvider> <mx:Array> <mx:Object icon="{point}" /> <mx:Object icon="{polyline}" /> <mx:Object icon="{polygon}" /> </mx:Array> </mx:dataProvider> </mx:ToggleButtonBar> <esri:IdentifyTask id="identifyTask" identifyComplete="identifyCompleteHandler(event)" url="http://localhost/ArcGIS/rest/services/ggg/MapServer"/> <mx:Script> <![CDATA[ import com.esri.ags.geometry.Geometry; import com.esri.ags.tasks.FeatureSet; import com.esri.ags.tasks.IdentifyResult; import com.esri.ags.SpatialReference; import com.esri.ags.events.IdentifyEvent; import com.esri.ags.tasks.IdentifyParameters; import com.esri.ags.events.GeometryServiceEvent; import com.esri.ags.tasks.BufferParameters; import com.esri.ags.Graphic; import mx.events.ItemClickEvent; import com.esri.ags.events.DrawEvent; import mx.controls.Alert; [Bindable] [Embed(source="assets/measure-point.png")] public var point:Class; [Bindable] [Embed(source="assets/measure-line.png")] public var polyline:Class; [Bindable] [Embed(source="assets/measure-poly.png")] public var polygon:Class; private function itemClickHandler(event:ItemClickEvent):void { switch(event.index) { case 0: { drawToolbar.activate(Draw.MAPPOINT); break; } case 1: { drawToolbar.activate(Draw.POLYLINE); break; } case 2: { drawToolbar.activate(Draw.POLYGON); break; } } } private function drawEndHandler(event:DrawEvent):void { var myGraphic:Graphic=event.graphic; //设置buffer参数 var bufferParameters:BufferParameters = new BufferParameters(); // bufferParameters.features=[myGraphic]; var featureSet:FeatureSet=new FeatureSet(); featureSet.features=[myGraphic];; var featureSet2:FeatureSet=new FeatureSet(); for(var i:int=0;i<featureSet.features.length;i++) { var graphic:Graphic=featureSet.features[i]; graphic.geometry.spatialReference=new SpatialReference(102100); featureSet2.features= [graphic]; } bufferParameters.features=featureSet2.features; //buffer距离半径 bufferParameters.distances = [2000]; //buffer单位 bufferParameters.unit = BufferParameters.UNIT_METER; //buffer空间参照系,102113为WKID是REST API定义好的空间参照系的id // bufferParameters.bufferSpatialReference = new SpatialReference(102113); //bufferParameters // bufferParameters. // bufferParameters.outSpatialReference=new SpatialReference(102025); bufferParameters.bufferSpatialReference=new SpatialReference(102100);//WGS_1984_Web_Mercator_Auxiliary_Sphere // bufferParameters.bufferSpatialReference=new SpatialReference(3349);//WGS_1984_PDC_Mercator //添加BUFFER_COMPLETE监听 myGeometryService.addEventListener(GeometryServiceEvent.BUFFER_COMPLETE,bufferCompleteHandler); //进行buffer分析 myGeometryService.buffer(bufferParameters); Alert.show("123"); // myGraphicsLayer.clear(); } private function bufferCompleteHandler(event:GeometryServiceEvent) : void { Alert.show("456"); myGraphicsLayer.clear(); //移除BUFFER_COMPLETE监听 myGeometryService.removeEventListener(GeometryServiceEvent.BUFFER_COMPLETE,bufferCompleteHandler); //获取buffer结果Graphic for each (var graphic : Graphic in event.graphics ) { //设置显示样式 graphic.symbol = sfs; //添加到GraphicsLayer进行显示 myGraphicsLayer.add( graphic ); var identifyParams:IdentifyParameters=new IdentifyParameters(); //查询结果需要返回Geometry identifyParams.returnGeometry=true; //查询冗余范围 identifyParams.tolerance=1; //宽 identifyParams.width = myMap.width; //高 identifyParams.height = myMap.height; //设置查询的Geometry identifyParams.geometry=graphic.geometry; //从ComboBox获取选择的图层index设置要查询的图层 //查询图层id为2的图层,就是States层 identifyParams.layerIds=[7]; //查询可见图层 identifyParams.layerOption=IdentifyParameters.LAYER_OPTION_VISIBLE; identifyParams.mapExtent=myMap.extent; //进行查询 identifyTask.execute(identifyParams); } } private function identifyCompleteHandler(event:IdentifyEvent):void { // myNav.activate(Navigation.PAN); var datas:Array=new Array(); //myGraphicsLayer.clear(); //遍历查询结果把查询到的feature添加到GraphicsLayer进行高亮显示 //同时把查询到的元素的名称添加到datas对象数组用来DataGrid显示用 for each (var result:IdentifyResult in event.identifyResults) { myGraphicsLayer.add(result.feature); //datas.push(result.feature.attributes); datas.push({"value":result.value}); } //设置mx:DataGrid的数据源 datalist.dataProvider=datas; } ]]> </mx:Script> </mx:Application>