webgis

arcgis-api-for-js-之添加图层到地图及地图服务设

2018-05-16  本文已影响8人  jiegiser

1. 前言

ArcGISDynamicMapServiceLayer 类代表动态图层,因此就有很大的属性与方法来操作视图服务。

2. 添加图层到地图

我们使用 addLayer() 方法将图层加载到地图中,代码如下:

        require(["esri/map","esri/layers/ArcGISDynamicMapServiceLayer",
                "dojo/domReady!"],
            function(Map,ArcGISDynamicMapServiceLayer){
                var map = new Map("mapDiv");
                //利用url创建一个动态地图服务对象
                var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/nongda/农大/MapServer",{
                });
                //将地图服务对象添加到地图容器中
                map.addLayer(layer);

除了添加到图层外,还可以使用 Map.removeLayer() 或者 Map.removeAllLayers() 来从地图地图中标移除某个或者所有图层。

3. 地图服务设置可见图层

可以使用 setVisibleLayers() 方法控制动态地图服务中单个图层的可见性。该方法仅适用于动态地图图层,对切片地图服务则不适用。该方法接受一个数组,对应地图服务中数据图层索引编号。
比如下面的一个动态地图服务的信息:

图层信息

上面是我发布的一个动态地图服务的信息,上面 setVisibleLayers() 方法接受的数组,数组是从0开始的,因此地图服务中的第一个图层占据位置0,就如上面的图层,大门就是索引为0。要想显示大门,和宿舍楼7的信息,只需要如下代码:

        require(["esri/map","esri/layers/ArcGISDynamicMapServiceLayer",
                "dojo/domReady!"],
            function(Map,ArcGISDynamicMapServiceLayer){
                var map = new Map("mapDiv");
                //利用url创建一个动态地图服务对象
                var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/nongda/农大/MapServer",{
                });
                layer.setVisibleLayers([0,7]);
                //将地图服务对象添加到地图容器中
                map.addLayer(layer);
            });
所有图层信息 只显示0,7图层

ArcGISDynamicMapServiceLayer 类的通过 setLayerDefinitions 方法来设置图层的定义,该定义可用于过滤指定图层的要素,例如:

        require(["esri/map","esri/layers/ArcGISDynamicMapServiceLayer",
                "dojo/domReady!"],
            function(Map,ArcGISDynamicMapServiceLayer){
                var map = new Map("mapDiv");
                //利用url创建一个动态地图服务对象
                var layer=new ArcGISDynamicMapServiceLayer("http://localhost:6080/arcgis/rest/services/nongda/农大/MapServer",{
                });
                var layerDefinitions=[];
                layerDefinitions[0]="POPULATION>5000000";
                layerDefinitions[5]="AREA>100000";
                layer.setLayerDefinitions(layerDefinitions);
                //将地图服务对象添加到地图容器中
                map.addLayer(layer);
上一篇 下一篇

猜你喜欢

热点阅读