flex中的buffer

来源:互联网 发布:mac安装apache php 编辑:程序博客网 时间:2024/05/22 23:35

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