flex中的identify

<?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:ToggleButtonBar id="toolBar"  y="10" x="33"  itemClick="itemClickHandler(event)">
    <mx:dataProvider>
     <mx:Array>
        <mx:Object icon="{point}"/>
      <mx:Object icon="{polyline}"/>
      <mx:Object icon="{polygon}"/>
    </mx:Array>
   </mx:dataProvider> 
 </mx:ToggleButtonBar>
 
    <esri:Draw id="drawTool" map="{myMap}" graphicsLayer="{myGraphicLayer}" drawEnd="drawEndHandler(event)"/>
   
 <esri:Map id="myMap" logoVisible="false" x="33" y="40" borderStyle="solid" borderThickness="3" width="1000">
  <esri:ArcGISDynamicMapServiceLayer id="myDynamicLayer" url="http://localhost/ArcGIS/rest/services/hh/MapServer" complete="mapHandler(event)"/>
  <esri:GraphicsLayer id="myGraphicLayer" symbolFunction="{symbolFunctionHandler}"/>  
 </esri:Map>
 <mx:ComboBox id="layerList" x="500" y="10"/>
 <esri:SimpleLineSymbol id="sls" style="solid" color="0x00FF00" width="2" alpha="1"/>
 <esri:SimpleMarkerSymbol id="sms" style="diamond" color="0x00FF00" size="15"/>
 <esri:SimpleFillSymbol id="sfs" /> 
 <esri:IdentifyTask id="myIdentifyTask" url="http://localhost/ArcGIS/rest/services/hh/MapServer" identifyComplete="identifyCompleteHandler(event)">
 </esri:IdentifyTask> 
 <mx:DataGrid id="datalist"  borderStyle="solid" borderThickness="3"  borderColor="#1B67D9" y="40" left="1035"/>

 <mx:Script>
  <![CDATA[
   import com.esri.ags.tasks.IdentifyResult;
   import com.esri.ags.events.IdentifyEvent;
   import com.esri.ags.tasks.IdentifyParameters;
   import com.esri.ags.events.DrawEvent;      
   import mx.events.ItemClickEvent; 
   import com.esri.ags.geometry.Geometry;
   import com.esri.ags.symbol.Symbol;
   import com.esri.ags.Graphic;
   import com.esri.ags.layers.LayerInfo;
   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;   
   
  //获取图层的名字加到combox上,在图层加载完成后执行
  private function mapHandler(event:Event):void
  {
    var layersinfo:Array;
    layersinfo=myDynamicLayer.layerInfos;
    var myLayers:Array=new Array();
    //遍历图层数组,将图层的名字和index加载
    var i:int;
    for( i=0;i<layersinfo.length;i++)
    {
        myLayers.push({label:layersinfo[i].name,data:i});//??????      
    }
    //给combox绑定数据源
    layerList.dataProvider=myLayers;   
  }
  //这个功能是当有元素添加到GraphicsLayer时进行元素显示样式的设置,
  private function symbolFunctionHandler(myGraphic:Graphic):Symbol
  {
    var result:Symbol;  
    //根据元素的类型进行显示图像的设置   
    switch(myGraphic.geometry.type)
    {
      case Geometry.MAPPOINT:
      {
        result=sms;
        break;
      }
      case  Geometry.POLYLINE:
      {
        result=sls;
        break;
      }
         case  Geometry.POLYGON:
      {
        result=sfs;
        break;
      }
    }
    return result;
  }
  //toolBar
  private function itemClickHandler(event:ItemClickEvent):void
  {
    switch(event.index)
    {
      case 0:
      {
       drawTool.activate(Draw.MAPPOINT);
       break;
      }
      case 1:
      {
       drawTool.activate(Draw.POLYLINE);
       break;
      }
      case 2:
      {
       drawTool.activate(Draw.POLYGON);
       break;
      }
    }
  } 
  //drawEnd事件
  private function  drawEndHandler(event:DrawEvent):void
  {
     //获取查询结果geometry
    var myGraphic:Graphic=event.graphic;
    var myGeometry:Geometry=event.graphic.geometry;
    var identifyPara:IdentifyParameters=new IdentifyParameters();
    //查询需要返回的Geometry
    identifyPara.returnGeometry=true;
    identifyPara.tolerance=3;
    identifyPara.width=myMap.width;
    identifyPara.height=myMap.height;
    //设置查询的geometry
    identifyPara.geometry=myGeometry;
    //从ComboBox获取选择的图层index设置要查询的图层
    var myLayer:Array=new Array();
  //  Alert.show(layerList.value.toString());
    myLayer.push(layerList.value);
    identifyPara.layerIds=myLayer;  
  
    Alert.show(identifyPara.layerIds.toString());
    //查询可见图层
    identifyPara.layerOption=IdentifyParameters.LAYER_OPTION_VISIBLE;
    identifyPara.mapExtent=myMap.extent;
    //进行查询
    myIdentifyTask.execute(identifyPara);
  }
  //查询完成后执行的事件
  private function identifyCompleteHandler(event:IdentifyEvent):void
  {
    var datas:Array=new Array();
    //遍历查询结果把查询到的feature添加到GraphicsLayer进行高亮显示
           //同时把查询到的元素的名称添加到datas对象数组用来DataGrid显示用
         var result:IdentifyResult;
         for each(result in event.identifyResults)
         {
            myGraphicLayer.add(result.feature);
            datas.push({"value":result.value});
         }
         //设置datalist的数据源
         datalist.dataProvider=datas;
  }
  
  ]]>
 </mx:Script>
</mx:Application>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值