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 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
| <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>QueryTask</title> <link rel="stylesheet" href="https://js.arcgis.com/3.28/esri/css/esri.css"/> <link rel="stylesheet" href="https://js.arcgis.com/3.28/dijit/themes/tundra/tundra.css"/> <script type="text/Javascript" src="https://js.arcgis.com/3.28/"></script> <style type="text/css"> .MapClass{ width:100%; height:800px; border:1px solid #000; } </style> <script type="text/javascript">
require(["esri/map", "esri/layers/ArcGISDynamicMapServiceLayer", "dojo/dom", "dojo/on", "esri/tasks/QueryTask", "esri/toolbars/draw", "esri/tasks/query", "esri/symbols/SimpleLineSymbol", "esri/symbols/SimpleFillSymbol", "esri/graphic", "dojo/domReady!"], function (Map, ArcGISDynamicMapServiceLayer,dom, on, QueryTask, Draw, Query, SimpleLineSymbol,SimpleFillSymbol,Graphic) { var map = new Map("mapdiv"); var layer = new ArcGISDynamicMapServiceLayer ("http://localhost:6080/arcgis/rest/services/ecology/beijing_2012_3/MapServer"); map.addLayer(layer)
var toolBar = new Draw(map); on(dom.byId("Btn"),"click",function(){ toolBar.activate(Draw.POLYGON); }) on(toolBar, "draw-complete", function (result) { var geometry=result.geometry; toolBar.deactivate(); queryGraphic(geometry); }); function queryGraphic(geometry) { var queryTask = new QueryTask( "http://localhost:6080/arcgis/rest/services/ecology/beijing_2012_3/MapServer/0"); var query = new Query(); query.returnGeometry = true; query.geometry = geometry; query.outFields = ["*"]; query.outSpatialReference = map.spatialReference; query.spatialRelationship = Query.SPATIAL_REL_INTERSECTS;
queryTask.execute(query, showQueryResult); }
function showQueryResult(queryResult) { var lineSymbol=new SimpleLineSymbol(SimpleLineSymbol.STYLE_DASH, new dojo.Color([255, 0, 0]), 3); var fill=new SimpleFillSymbol(SimpleFillSymbol.STYLE_SOLID, lineSymbol); if (queryResult.features.length == 0) { dom.byId("divShowResult").innerHTML = ""; return; } var htmls = ""; if (queryResult.features.length >= 1) { htmls = htmls + "<table style=\"width: 100%\">"; htmls = htmls + "<tr><td>名称</td></tr>"; for (var i = 0; i < queryResult.features.length; i++) { var graphic = queryResult.features[i]; graphic.setSymbol(fill); map.graphics.add(graphic); var ptName = graphic.attributes["NL_NAME_3"]; if (i % 2 == 0) htmls = htmls + "<tr>"; else htmls = htmls + "<tr bgcolor=\"#F0F0F0\">"; htmls = htmls + "<td><a href=\"#\"\">" + ptName + "</a></td>"; htmls = htmls + "</tr>"; } htmls = htmls + "</table>"; dom.byId("divShowResult").innerHTML = htmls; } } });
</script> </head> <body> <div id="mapdiv" class="MapClass"></div> <input type="button" value="空间查询" id="Btn"/> <div id="divShowResult"></div> </body> </html>
|