Feature Layer with selection(ArcGIS JS Api 图上点选)

简介:

Demo是编程之母,API是编程之父。面对一个陌生的框架,直接从api开始写代码是不明智的,最好的办法就是按照Demo来写,这样既能很快的吧Api用起来,又能避免摸着石头过河的愚蠢行为。用的差不多了,需要更多的功能扩展,这时候就可以依葫芦画瓢看着api来写功能。api也是人写的,每个人有每个人的思维方式,从demo起步是熟悉某种api思维方式的最好方式。有些人说,抄例子太低级,我认为,抄例子能解决的事儿,绝不要自命清高地自己琢磨,生命有限,把时间用在解决问题上,而不是思考无意义的问题。


Arcgis api for JS中,选择的例子中只提供了通过缓冲区选择的方式,下面提供一个点选的。

描述
This sample shows how to use the draw toolbar to select gas fields from a feature layer. The gas fields are displayed using a feature layer with ONDEMAND mode. On-demand mode retrives selected features and features within the current extent.

Click the select fields button then draw a rectangle on the map.The toolbar's onDrawEnd event fires when you finish sketching the selection rectangle. Notice that the sketch is used with the FeatureLayer's selectFeatures method to perform a spatial query.
         dojo.connect(selectionToolbar, "onDrawEnd", function(geometry) {
         selectionToolbar.deactivate();
         selectQuery.geometry = geometry;
         featureLayer.selectFeatures(selectQuery, esri.layers.FeatureLayer.SELECTION_NEW);
       });

After the features are selected onSelectionComplete fires and the total gas production for the selected fields is calculated. 
代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  < html >
  < head >
    < meta  http-equiv = "Content-Type"  content = "text/html; charset=utf-8" />
    < meta  http-equiv = "X-UA-Compatible"  content = "IE=7"  />
    <!--The viewport meta tag is used to improve the presentation and behavior of the samples
    on iOS devices-->
    < meta  name = "viewport"  content = "initial-scale=1, maximum-scale=1,user-scalable=no" />
    < title >Layer in a map service - [ON-DEMAND]</ title >
      < link  rel = "stylesheet"  type = "text/css"  href = "http://serverapi.arcgisonline.com/jsapi/arcgis/2.2/js/dojo/dijit/themes/claro/claro.css" >
      < script  type = "text/javascript" >djConfig = { parseOnLoad:true };</ script >
      < script  type = "text/javascript"  src = "http://serverapi.arcgisonline.com/jsapi/arcgis/?v=2.2" ></ script >
      < script  type = "text/javascript" >
        dojo.require("esri.map");
        dojo.require("esri.layers.FeatureLayer");
        var selectionToolbar, featureLayer;
        function init() {
          var initialExtent = new esri.geometry.Extent(-97.5328,37.4344,-97.2582,37.64041, new esri.SpatialReference({wkid:4326}) );
          var map = new esri.Map("map", { extent: esri.geometry.geographicToWebMercator(initialExtent), slider: true, nav: true });
          dojo.connect(map, "onLoad", initSelectToolbar);
          var baseMapLayer = new esri.layers.ArcGISTiledMapServiceLayer("http://server.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer");
          map.addLayer(baseMapLayer);
          var fieldsSelectionSymbol = new esri.symbol.SimpleFillSymbol().setColor(new dojo.Color([255,255,0,0.5]));
          fieldsSelectionSymbol.setOutline(new esri.symbol.SimpleLineSymbol("dashdot", new dojo.Color([255,0,0]), 2));
              
          var content = "< b >Status</ b >: ${STATUS}" +
                        "< br >< b >Cummulative Gas</ b >: ${CUMM_GAS} MCF" +
                        "< br >< b >Total Acres</ b >: ${APPROXACRE}" +
                        "< br >< b >Avg. Field Depth</ b >: ${AVG_DEPTH} meters";
          var infoTemplate = new esri.InfoTemplate("${FIELD_NAME}", content);
          featureLayer = new esri.layers.FeatureLayer("http://sampleserver3.arcgisonline.com/ArcGIS/rest/services/Petroleum/KSPetro/MapServer/1",{
            mode: esri.layers.FeatureLayer.MODE_ONDEMAND,
            infoTemplate: infoTemplate,
            outFields: ["*"]
          });
             
          featureLayer.setDefinitionExpression("PROD_GAS='Yes'");
          featureLayer.setSelectionSymbol(fieldsSelectionSymbol);
          dojo.connect(featureLayer, "onSelectionComplete", sumGasProduction);
          dojo.connect(featureLayer, "onSelectionClear", function(features) {
            dojo.byId('messages').innerHTML = "< i >No Selected Fields</ i >";
          });
               
          map.addLayer(featureLayer);
        }
        function initSelectToolbar(map) {
          selectionToolbar = new esri.toolbars.Draw(map);
          var selectQuery = new esri.tasks.Query();
               
          dojo.connect(selectionToolbar, "onDrawEnd", function(geometry) {
            selectionToolbar.deactivate();
            selectQuery.geometry = geometry;
            featureLayer.selectFeatures(selectQuery, esri.layers.FeatureLayer.SELECTION_NEW);
          });
               
        }
        function sumGasProduction(features) {
          var productionSum = 0;
          //summarize the cummulative gas production to display
          dojo.forEach(features, function(feature) {
            productionSum = productionSum + feature.attributes.CUMM_GAS;
          });
          dojo.byId('messages').innerHTML = "< b >Selected Fields Production: " + productionSum + " mcf. </ b >";
        }
      dojo.addOnLoad(init);
    </ script >
  </ head >
  < body  class = "claro" >
    < button  dojoType = "dijit.form.Button"  onClick = "selectionToolbar.activate(esri.toolbars.Draw.EXTENT);" >Select Fields</ button >
    < button  dojoType = "dijit.form.Button"  onClick = "featureLayer.clearSelection();" >Clear Selection</ button >< br >
    < div  id = "map"  style = "position: relative; width:700px; height:500px; border:1px solid #000;" ></ div >
    < span  id = "messages" ></ span >
  </ body >
  </ html >


参考:http://maps.rosreestr.ru/arcgis_js_api/sdk/help/jssamples/fl_selectfeatures.html



本文转自 huohe2009 51CTO博客,原文链接:http://blog.51cto.com/zhaojie/1352057

相关文章
|
JavaScript
Arcgis js多线程克里金插值初体验
最近做关于雨量插值的项目,本来使用后台的GP工具做的,但是处理时间比较长需要十几秒钟左右,所以研究怎么通过前台来计算。
147 0
|
JSON JavaScript API
geoserver图层属性查询及查询结果转换为arcgis js api能使用的格式
一个项目使用了ArcGIS JS API开发GIS展示层,但GIS服务使用了Geoserver,这时加载Geoserver数据和查询数据就和之前完全不一样了,以下介绍下我使用ArcGIS JS API+Geoserver开发过程中解决Geoserver图层属性查询的一个方案。
1392 0
|
JavaScript API
arcgis js 空间关系查询
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/bitree1/article/details/78425222 ARCGIS空间查询关系  Boundary(边界): 只有线和面才有边界。
1066 0
|
API JavaScript
国内免费arcgis jsapi arcgis jsapi国内镜像
arcgis js3.20 api地址 http://devgis.majcms.com/lib/arcgis/3.20/init.js arcgis js4.
2329 0
|
JavaScript 定位技术
ArcGIS JS 学习笔记4 实现地图联动
原文:ArcGIS JS 学习笔记4 实现地图联动 1.开篇       守望屁股实在太好玩了,所以最近有点懒,这次就先写个简单的来凑一下数。这次我的模仿目标是天地图的地图联动。 天地的地图联动不仅地图有联动,而且鼠标也有联动,我就照着这个目标进行山寨。
1018 0
|
JavaScript 算法 API
arcgis api for js共享干货系列之一自写算法实现地图量算工具
原文:arcgis api for js共享干货系列之一自写算法实现地图量算工具 众所周知,使用arcgis api for js实现地图的量算工具功能,无非是调用arcgisserver的Geometry服务(http://localhost:6080/arcgis/rest/services/U...
1291 0
|
JavaScript 前端开发 定位技术
Arcgis for JS之Cluster聚类分析的实现
原文:Arcgis for JS之Cluster聚类分析的实现 在做项目的时候,碰见了这样一个问题:给地图上标注点对象,数据是从数据库来 的,包含XY坐标信息的,通过graphic和graphiclayer 的方式添加到地图上,其中有一个对象的数量很多,上万了吧,通过上述的方式无法在地图上进行展示,就想到了聚类,当时由于技术和时间的关系,没有实现,最 近,稍微有点先下时间,就又想起这事,继续研究,终于,皇天不负有心人,出来了,出来的第一时间写出来,以便大家使用。
1245 0
|
JavaScript 前端开发 数据挖掘
Arcgis for JS之Cluster聚类分析的实现(基于区域范围的)
原文:Arcgis for JS之Cluster聚类分析的实现(基于区域范围的) 咱们书接上文,在上文,实现了基于距离的空间聚类的算法实现,在本文,将继续介绍空间聚类之基于区域范围的实现方式,好了,闲言少叙,先看看具体的效果: 聚类效果 点击显示信息 显示单个聚类点 下面说说具体的实现思路。
1747 0