zoukankan      html  css  js  c++  java
  • ArcGIS api for javascript——显示多个ArcGIS Online服务

    描述

    本例展示了如何使用按钮在地图里的两个不同的图层间切换。所有地图里的图层恰巧是来自ArcGIS Online的 ArcGISTiledMapServiceLayers。按钮是Dojo dijit按钮,不过也可以使用HTML按钮,radio按钮等调用相同的函数。

    当应用运行时,发生下面的事情:

    1.init函数被调用,创建一个地图并且通过map.addLayer方法直接加入影像图层。函数也填充了图层名字的数组,但是没有创建除影像图层之外的任何图层。

    2.用户单击按钮,调用changeMap函数。一个包含与按钮一致的图层ID的单个项目数组作为输入参数被传递给changeMap函数。

    3.changeMap直接调用hideImageTiledLayers函数,传给hideImageTiledLayers函数同样的包含和被点击的按钮一致的图层ID的单个项目的数组。hideImageTiledLayers函数循环访问地图里的每个图层,和传入函数的图层ID不匹配的图层ID的图层被隐藏。

    4.函数 当hideImageTiledLayers函数完成,changeMap函数循环访问图层数组里的每个图层,并调用函数initLayer。 记住数组仅仅包含一个图层,和被单击的按一致的图层

    5.initLayer函数创建图层,然后增加图层到地图里。

    6.changeMap函数显示图层(使图层可见)。

     1 <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
     2 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
     3 <html>
     4   <head>
     5     <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
     6     <meta http-equiv="X-UA-Compatible" content="IE=7" />
     7     <title>显示多个ArcGIS Online服务</title>
     8     <script type="text/javascript">djConfig = { isDebug:true };</script>
     9     <link rel="stylesheet" type="text/css" href="http://serverapi.arcgisonline.com/jsapi/arcgis/1.6/js/dojo/dijit/themes/tundra/tundra.css">
    10     <script type="text/javascript" src="http://serverapi.arcgisonline.com/jsapi/arcgis/?v=1.6"></script>
    11     <script type="text/javascript">
    12         dojo.require("esri.map");
    13         dojo.require("dijit.form.Button");
    14         
    15         var map;
    16         var streetMap, imageryPrime, shadedRelief, ngsTopoUS, boundariesWorld;
    17         
    18         function init(){
    19             map = new esri.Map("map");
    20             imageryPrime = new esri.layers.ArcGISTiledMapServiceLayer("http://server.arcgisonline.com/ArcGIS/rest/services/ESRI_Imagery_World_2D/MapServer", {id:"imageryPrime"});
    21                map.addLayer(imageryPrime);
    22 
    23             streetMap = initLayer("http://server.arcgisonline.com/ArcGIS/rest/services/ESRI_StreetMap_World_2D/MapServer", "streetMap");
    24             shadedRelief = initLayer("http://server.arcgisonline.com/ArcGIS/rest/services/ESRI_ShadedRelief_World_2D/MapServer", "shadedRelief");
    25             ngsTopoUS = initLayer("http://server.arcgisonline.com/ArcGIS/rest/services/NGS_Topo_US_2D/MapServer", "ngsTopoUS");
    26             boundariesWorld = initLayer("http://server.arcgisonline.com/ArcGIS/rest/services/Reference/ESRI_BoundariesPlaces_World_2D/MapServer", "boundariesWorld");
    27         
    28         }
    29         function initLayer(url, id) {
    30             var layer = new esri.layers.ArcGISTiledMapServiceLayer(url, {id:id, visible:false});
    31                map.addLayer(layer);
    32                return layer;
    33         }
    34         
    35         function changeMap(layers) {
    36             hideImageTiledLayers(layers);
    37             for (var i=0;i<layers.length;i++) {
    38                 layers[i].show();
    39             }
    40         
    41         }
    42         
    43         function hideImageTiledLayers(layers) {
    44         
    45         alert(map.layerIds.length);
    46             for(var i=0,j=map.layerIds.length;i<j;i++) {
    47                   
    48                 var layer = map.getLayer(map.layerIds[i]);
    49                 if(dojo.indexOf(layers,layer) == -1) {//没有找到
    50                     layer.hide();
    51                 }
    52             
    53             }
    54         
    55         } 
    56         
    57       
    58         dojo.addOnLoad(init);
    59     </script>
    60  
    61   </head>
    62 
    63   <body class="tundra">
    64       <div id="map" style=" 1100px;height: 600px;border: 1px solid #000"></div>
    65       <div  style="position: absolute;right: 175px;top: 10px;z-index: 999;">
    66           <button dojoType="dijit.form.Button" onclick="changeMap([imageryPrime]);"> imageryPrime</button>
    67           <button dojoType="dijit.form.Button" onclick="changeMap([imageryPrime,boundariesWorld]);">imageryPrime,boundariesWorld </button>
    68           <button dojoType="dijit.form.Button" onclick="changeMap([streetMap]);"> streetMap</button>
    69           <button dojoType="dijit.form.Button" onclick="changeMap([ngsTopoUS]);">ngsTopoUS </button>
    70           <button dojoType="dijit.form.Button" onclick="changeMap([shadedRelief]);">shadedRelief </button>
    71       </div>
    72   
    73   </body>
    74 </html>
  • 相关阅读:
    流 例题

    容器集合整理
    容器集合
    容器 集合知识点
    面向对象回顾
    面向对象例题
    Java常用的8大排序算法
    Java中两个动态代理
    为什么synchronized无法禁止指令重排,却能保证有序性
  • 原文地址:https://www.cnblogs.com/xiaotian-222/p/6526053.html
Copyright © 2011-2022 走看看