flex中的buffer

    技术2022-05-20  69

    //需要注意的是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>


    最新回复(0)