79 color=”0×000000″ alpha=”100″/> 80 81 83 84 85 86
96 97
98
101
104
107
111
113 114 115
116 117
5.上面的代码有点多了但是并不复杂了,整个代码就是定义一个id为ifs的esri:InfoSymbol,主要部分为TitleState和DetailState的2种视图状态的设置和鼠标移上去的rollOverHandler方法、鼠标移开的rollOutHandler方法、鼠标点击的clickHandler方法定义。 6.完成上面的工作后,接下来要做的就是在地图上显示MapTip了,这里就去部分的California的Cities的点图层数据了,在 var queryTask : QueryTask = new QueryTask(\ 4 var query : Query = new Query(); 5 //查询条件取OBJECTID大于600的; 6 query.where=\ 7 //返回Geometry 8 query.returnGeometry = true; 9 //设置返回字段 10 query.outFields = [\AGE_40_49\11 //进行查询 12 queryTask.execute(query, new AsyncResponder( onResult, onFault )); 13 //查询成功后执行方法 14 function onResult( featureSet : FeatureSet, token : Object = null ) : void 15 { 16 for each ( var myGraphic : Graphic in featureSet.features ) 17 { 18 //设置显示的symbol 19 myGraphic.symbol = ifs; 20 //添加到GraphicsLayer中进行显示 21 myGraphicsLayer.add( myGraphic ); 22 //属性数组 23 var object : ArrayCollection = new ArrayCollection 24 ([ 25 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄低于5岁\ALUE : myGraphic.attributes.AGE_UNDER5}, 26 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄5-17岁\ALUE : myGraphic.attributes.AGE_5_17}, 27 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄18-21岁\ALUE : myGraphic.attributes.AGE_18_21}, 28 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄22-29岁\ALUE : myGraphic.attributes.AGE_22_29}, 29 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄30-39岁\ALUE : myGraphic.attributes.AGE_30_39}, 30 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄40-49岁\ALUE : myGraphic.attributes.AGE_40_49}, 31 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄50-64岁\ALUE : myGraphic.attributes.AGE_50_64}, 32 {AREANAME : myGraphic.attributes.AREANAME,AGE : \ 年龄65岁以上\ALUE : myGraphic.attributes.AGE_65_UP} 33 ]); 34 //设置属性 35 myGraphic.attributes = object; 36 } 37 } 38 //查询失败后执行方法 39 function onFault( info : Object, token : Object = null ) : void 40 { 41 Alert.show(info.toString()); 42 } 43 ]]> 44 7.这样就完成的功能的开发,这个例子的代码相对简单了主要的是esri:InfoSymbol的定义以及mx:PieChart控件的使用。 7.这样就完成的功能的开发,这个例子的代码相对简单了主要的是esri:InfoSymbol的定义以及mx:PieChart控件的使用。 (十)ArcGIS.Server.9.3和ArcGIS API for Flex的GeometryService和buffer分析 2009年09月11日 7:27 上午 | 分类:Flex 目的: 1.ArcGIS API for Flex用GeometryService实现点、线、面的buffer分析。 准备工作: 1.在ArcGIS.Server.9.3发布一个叫USA的Map Service。 2.在ArcGIS.Server.9.3发布一个叫Geometry的Geometry Service,默认设置就可以了。 完成后的效果图: 开始: 0.首先介绍一下Geometry Service,Geometry Service是给程序提供几何计算如 buffering, simplifying, calculating areas 、lengths, projecting等功能,Geometry Service可以用来代替 ArcObjects 或geoprocessing service等做的这些几何计算,它是ArcGIS Server 9.3提供的新功能,本篇就是用它来实现buffer的分析。 1.启动Flex Builder3新建工程以及引入1.0正式版的ArcGIS API for Flex library的开发包。 2.新建bufferTest.mxml页面,添加Map、ArcGISDynamicMapServiceLayer、GraphicsLayer等。具体代码如下: 1 verticalCenter=”16″ left=”10″> 2 url=”http://jh-53a435fbc0e8/ArcGIS/rest/services/USA/MapServer” /> 4 3. 然后在Map控件的右边在添加一个Grid用来显示buffer分析后的数据,代码如下: 1 borderThickness=”3″ left=”508″> 2 4.这里既然是用Geometry Service实现buffer的当然还需要添加esri:GeometryService控件,它的url属性就是上面发布的叫Geometry的Geometry Service的地址,代码如下: 1 id=”myGeometryService” url=”http://jh-53a435fbc0e8/ArcGIS/rest/services/Geometry/GeometryServer”/> 5.这里采用在地图上画点、线、面然后根据画的几何图进行buffer,所以还需要ToggleButtonBar按钮组控件、Draw控件以及图形显示样式的定义,具体代码如下: 1 3 4 7 6.point、polyline、polygon的icon定义如下: 1