描述
本例允许用户输入一个地址,然后显示匹配的地址的位置。这通常地被称为地理编码。在ArcGIS JavaScript API中,使用Locator类执行地理编码。
定位器构造函数需要ArcGIS Server 地理编码服务的URL。一个地理编码服务表示一个在服务器上可用的地址定位器。本例使用ESRI sample server上的ESRI_Geocode_USA服务。可以使用服务目录来查出自己的地理编码服务的URL。
当用户单击Locate按钮,locate函数被调用。这个函数解析用户输入的地址文本到一个four-item的数组。这四个项目(地址,城市,州和邮编)相当于定义在定位器里的地址字段。可以通过查阅服务目录里的地理编码服务查出这些地址字段。例如, 这个页面显示本例使用的四个地理编码服务的地址字段。
当addressToLocations方法被调用,定位器开始搜索匹配值:
locator.addressToLocations(address);
但定位器结束查找匹配值, onAddressToLocationsComplete事件的监听器调用函数showResults,该函数增加匹配度超过80的候选地址到地图。候选地址通过传递给监听器的回调函数的AddressCandidate对象数组表示。每个候选地址包含地址的位置点,关联的新的图形。
本例使用InfoTemplate定义如何将地址信息反馈给用户。匹配的地址通过几何体放置在地图上,几何体被单击时默认显示一个信息窗口。InfoTemplate定义了在信息窗口中显示的文本的格式。本例中,信息模板被定义显示匹配地址和匹配度。
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2 <html>
3 <head>
4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
5 <meta http-equiv="X-UA-Compatible" content="IE=7" />
6 <title>Find Address</title>
7 <link rel="stylesheet" type="text/css" href="http://serverapi.arcgisonline.com/jsapi/arcgis/1.5/js/dojo/dijit/themes/tundra/tundra.css">
8 <script type="text/javascript" src="http://serverapi.arcgisonline.com/jsapi/arcgis/?v=1.5"></script>
9 <script type="text/javascript">
10 dojo.require("esri.map");
11 dojo.require("esri.tasks.locator");
12
13 var map, locator;
14
15 function init() {
16 map = new esri.Map("map", { extent: new esri.geometry.Extent(-125, 28, -62, 45, new esri.SpatialReference({wkid:4326})) });
17 var tiledMapServiceLayer = new esri.layers.ArcGISTiledMapServiceLayer("http://server.arcgisonline.com/ArcGIS/rest/services/ESRI_StreetMap_World_2D/MapServer");
18 map.addLayer(tiledMapServiceLayer);
19
20 locator = new esri.tasks.Locator("http://sampleserver1.arcgisonline.com/ArcGIS/rest/services/Locators/ESRI_Geocode_USA/GeocodeServer");
21 dojo.connect(locator, "onAddressToLocationsComplete", showResults);// onAddressToLocationsComplete事件的监听器调用函数showResults,该函数增加匹配度超过70的候选地址到地图
22 }
23
24 function locate() {
25 map.graphics.clear();
26 var add = dojo.byId("address").value.split(",");
27 var address = {
28 Address : add[0],
29 City: add[1],
30 State: add[2],
31 Zip: add[3]
32 };
33 locator.addressToLocations(address,["Loc_name"]);//开始搜索匹配值
34 }
35 //该函数增加匹配度超过70的候选地址到地图
36 function showResults(candidates) {
37 var candidate;
38 //简单注记样式。用于表示点和多点。 SimpleMarkerSymbol是用来显示点作为一个简单的形状,例如,一个圆圈。此外,符号可以有一个可选的轮廓。
39 var symbol = new esri.symbol.SimpleMarkerSymbol();
40 //设置信息窗口显示的格式
41 var infoTemplate = new esri.InfoTemplate("Location", "Address: ${address}<br />Score: ${score}<br />Source locator: ${locatorName}");
42 //设置样式为菱形
43 symbol.setStyle(esri.symbol.SimpleMarkerSymbol.STYLE_DIAMOND);
44 //设置颜色为红色
45 symbol.setColor(new dojo.Color([255,0,0,0.75]));
46
47 var points = new esri.geometry.Multipoint(map.spatialReference);
48
49 for (var i=0, j=candidates.length; i<j; i++) {
50 candidate = candidates[i];
51 if (candidate.score > 70) {//如果匹配值大于70的话,将他加入到地图中
52 var attributes = { address: candidate.address, score:candidate.score, locatorName:candidate.attributes.Loc_name };
53 var graphic = new esri.Graphic(candidate.location, symbol, attributes, infoTemplate);
54 map.graphics.add(graphic);
55 map.graphics.add(new esri.Graphic(candidate.location, new esri.symbol.TextSymbol(attributes.address).setOffset(0, 8)));
56 points.addPoint(candidate.location);
57 }
58 }
59 map.setExtent(points.getExtent().expand(3));//用原来的基础上扩展范围
60 }
61
62 dojo.addOnLoad(init);
63 </script>
64 </head>
65 <body class="tundra">
66 Address : <input type="text" id="address" size="60" value="380 New York St, Redlands, CA, 92373" /> <i>(Address, City, State, Zip)</i>
67 <input type="button" value="Locate" onclick="locate()" /><br />
68 <br />
69 <div id="map" style="width:1200px; height:600px; border:1px solid #000;"></div>
70 </body>
71 </html>