esri-leaflet入门教程(4)-加载各类图层

by 李远祥

在leaflet中图层一般分为底图(Basemap)和叠加图层(Overlay)。前面章节已经介绍过底图其实也是实现了TileLayer 接口,而其他的叠加图层要么就是叠加的业务图层,要么就是动态显示的图形和符号。这一点在esri leaflet中也是有对照的。

ArcGIS产品中比较让人熟知的图层包括ArcGISDynamicMapServiceLayer、ArcGISImageServiceLayer、ArcGISTiledMapServiceLayer、FeatureLayer、GraphicsLayer、VectorTileLayer,这些图层都比较常用,在ArcGIS JavaScript API中使用也是相当的方便。在esri leaflet中同样也包含了所有的这些图层接口,可以看看关于Layer的是实现,如下图

当然,esri leaflet由于跟leaflet有所对接,所以还根据leaflet的接口于自家的服务实现了vector basemap(矢量底图)、Heatmap(热点地图)、clustered feature Layer(聚合图层)以及与自己的矢量切片图层。但这几类图层是在esri-leaflet.js 的基础上需要加入Plugin才能实现。当然实现起来也是相对简单。接下来将是各种图层的加载方式。

1. 动态图层加载

动态图层使用的是 L.esri.DynamicMapLayer 接口,其构建方式 L.esri.dynamicMapLayer(<Object>options)。其中option 中有好几个重要的参数,例如url(服务路径)、layers(图层,指的是地图服务中的图层索引的数组,如要加载第2、3、6 层,则输入数据为 [1,2,5])、layerDefs(图层过滤条件)、opacity(透明度)。为了确保官网上代码是准确无误而且完善的,笔者特意自己通过ArcGIS Server 去发布一些地图服务进行加载。

function addDyLayer(){
    var envLayer=L.esri.dynamicMapLayer({
     url: 'http://localhost:6080/arcgis/rest/services/env/MapServer',
     opacity: 0.8,
      layers: [0,3]
     });          
     map.addLayer(envLayer);
     }

可以看到这跟ArcGIS JavaScript API 还是有小小的区别,其差异在于构建的时候esri leaflet是将url也一并写到option 里面。如果要加载所有的图层,layers参数就不需要设置了,加载的就是动态地图服务的本身设置。如果只加载某一层,layers参数同样是个数据,例如只加载第二层,那则写成 layers: [1]  。

还有一点需要注意的是,url的构成必须是整个服务路径,而不能带有图层索引号,这不同于ArcGIS JavaScript的ArcGISDynamicMapServiceLayer 单图层加载,如这种 http://localhost:6080/arcgis/rest/services/env/MapServer/0  在esri leaflet 中是不允许的,所以ArcGIS 的开发人员很容易会自觉套用。其效果如下图显示

2.切片图层加载

切片图层相对来说比较简单,因为切片中可以设置的部分本来就不多,其构建方式与动态图层一样,只是option的参数部分相对来说非常少,反而不想BasemapLayer 那么多。按照leaflet的理念,有了basemap之后应该是不会其他的切片图层存在,但有时候为了提升性能,也会有有部分人希望通过叠加切片图层去提升加载的效率。而切片图层最常用的构建方式就是直接加入url,其他的诸如初始显示位置、显示级别等都在map中实现了。如下代码,就是使用了map 控件加载切片图层。

map = L.map("mapDiv").setView([23.1, 113.2], 9);//定位在广州
customBaselayer = L.esri.tiledMapLayer(
    {url: "http://cache1.arcgisonline.cn/ArcGIS/rest/services/ChinaOnlineStreetColor/MapServer"}).addTo(map);

3.要素图层加载

要素图层featurelayer在ArcGIS JavaScript API里面一般是担当数据编辑的功能,当然其后端发布需要数据源来自于ArcSDE数据库。而在esri leaflet 里面,这个featurelayer 并不全是用作编辑,它有相当的一部分功能是对口graphiclayer。先来看看官网上的例子,其加载代码也是很简单,直接使用要素服务的索引号作为图层加载(这应该是esri leaflet里面唯一可以直接在服务地址中使用图层索引号的地方),代码如下

var map = L.map('map').setView([45.526, -122.667], 13);

  L.esri.basemapLayer('Streets').addTo(map);
  L.esri.featureLayer({
    url: 'https://services.arcgis.com/rOo16HdIMeOBI4Mb/arcgis/rest/services/Heritage_Trees_Portland/FeatureServer/0'
  }).addTo(map);

来看看其效果如何,加入的url是一个featureservice的一个图层,所以使用了一个索引号为0,意味着只加载第一层的数据。由于这个数据在加载到地图中的时候,leaflet会默认给点线面加入一个符号,当然这个符号样式也是可以后期修改的。从下图可以看出,这个默认的符号比较“互联网”一点。

4.热点图加载

热点图是一种比较宏观的表现方式,一般用来表示点要素的密度分布。在早期的ArcGIS Javascript API中是没有热点图层的形式,必须使用spatial工具进行制作,然后通过GP生成热点图进行加载。而在esri-leaflet中,热点图的生成就非常简单了,直接使用L.esri.Heat.featureLayer 接口可以实现。但是,该接口并非直接集成在esri-leaflet 中,而是通过plugins来实现,也就是说,还必须引用实现该功能的js才能实现。通过github 地址可以获取该js脚本 https://github.com/Esri/esri-leaflet-heatmap/tree/master/src

我们无需纠结其怎么动态实现热点图生成,只需要关注怎么使用就行了。在原来代码的head标签出多加入该HeatmapFeatureLayer.js 文件,然后进行调用,调用的方法如下:

L.esri.Heat.featureLayer({
    url: 'https://services.arcgis.com/rOo16HdIMeOBI4Mb/ArcGIS/rest/services/Graffiti_Reports/FeatureServer/0',
    radius: 12
  }).addTo(map);

主要两处重要的参数,一是构建时的URL必须使用的是FeatureService,并且是点图层;而是需要输入融合的半径radius 的值。

5.聚合图层加载

聚合图是一种表现更加优美的地图,它既兼顾了热点图的宏观特性,又最大限度的保留了一些细节的总结。下图就是聚合图的一些表现,不同的颜色表示不同的数量值,并且将这个数量标绘在地图上。

聚合图同样也需要插件才能实现,可以在 https://github.com/Esri/esri-leaflet-cluster 找到其代码,也是简单的引用js脚本就OK了,其具体的实现参考以下调用方法,使用 L.esri.Cluster.featureLayer 接口

  L.esri.Cluster.featureLayer({
    url: 'https://services.arcgis.com/rOo16HdIMeOBI4Mb/arcgis/rest/services/Trimet_Transit_Stops/FeatureServer/0'
  }).addTo(map);

聚合图和热点图都是在客户端动态构建的,不需要再对esri的feature service 作设置,其自带的样式也是比较美观。当然,这些样式也是可以定义的。在后面的章节中我们会再进一步讨论。

除此之外,esri-leatlet 还支持其他的一些ArcGIS 服务,例如 imageservice,streamService等,其加载方式也比较有规律,例如在家影像服务,

    L.esri.imageMapLayer({
      url: 'https://landsat.arcgis.com/arcgis/rest/services/Landsat/PS/ImageServer',
      attribution: 'United States Geological Survey (USGS), National Aeronautics and Space Administration (NASA)'
    }).addTo(map);

加载其Geoevent的流服务

  var buses = L.esri.streamFeatureLayer({
    url: 'https://geoeventsample3.esri.com:6443/arcgis/rest/services/SeattleBus/StreamServer',
    pointToLayer: function (geojson, latlng) {
      return L.circleMarker(latlng, {
        fillColor: createRandomFill(),
        fillOpacity: 0.8,
        color: "#cccccc",
        weight: 2
      });
    },
  }).addTo(map);

总结:esri-leaflet 无论是基础脚本还是扩展脚本,都实现了自家全线服务的支持,单从兼容性来看,已经不逊色于自家的ArcGIS Javascript API,而且esri-leaflet非常小,基本上不存在安装部署的问题,再也不需要兼顾庞大而复杂的dojo,给ArcGIS的开发者们一种全新的开发方式。

esri-leaflet入门教程(4)-加载各类图层的更多相关文章

  1. [译]Vulkan教程(31)加载模型

    [译]Vulkan教程(31)加载模型 Loading models 加载模型 Introduction 入门 Your program is now ready to render textured ...

  2. ArcGIS API for Silverlight 调用GP服务加载等值线图层

    原文:ArcGIS API for Silverlight 调用GP服务加载等值线图层 第二篇.Silverlight客户端调用GP服务 利用ArcGIS API for Silverlight实现G ...

  3. Qt+QGis二次开发:加载栅格图层和矢量图层

    一.加载栅格图像 加载栅格图像的详细步骤在下面代码里: //添加栅格数据按钮槽函数 void MainWindow::addRasterlayers() { //步骤1:打开文件选择对话框 QStri ...

  4. arcgis api for JavaScript _加载三维图层(scene layer)

    arcgis api for JavaScript _加载三维图层(scene layer) arcgis api for JavaScript  4.x 版本增加对三维的支持. 关于三维图层(sce ...

  5. Photoshop入门教程(三):图层

    学习心得:图层可以说是Photoshop的核心,看似简单,但是对于图像的各种编辑都是基于图层.他就像一层透明的.没有厚度的玻璃纸,每张玻璃纸设置不同的效果,层层叠加,最后显现出绚烂的效果. 在进行图像 ...

  6. SharpDX之Direct2D教程II——加载位图文件和保存位图文件

    本系列文章目录: SharpDX之Direct2D教程I——简单示例和Color(颜色) 绘制位图是绘制操作的不可缺少的一部分.在Direct2D中绘制位图,必须先利用WIC组件将位图加载到内存中,再 ...

  7. Unity跳转场景进度条制作教程(异步加载)

    Unity跳转场景进度条制作 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享 ...

  8. Android系统编程入门系列之加载界面Activity

    上回说到应用初始化加载及其生命周期,在Android系统调用Applicaiton.onCreate()之后,继续创建并加载清单文件中注册的首个界面即主Activity,也可称之为入口界面.主Acti ...

  9. FusionCharts简单教程(六)------加载外部Logo

    一.加载外部文件Logo       在使用FusionCharts时,我们可能需要在加载图像的时候需要在图表中显示标识.图片等等.这里我们可以使用logoURL属性来实现.如: <chart ...

随机推荐

  1. mongodb 3.x connect with credential

    package mongoDb; import java.net.UnknownHostException; import java.util.ArrayList; import java.util. ...

  2. MIPI-3

    上一篇文章讲了以下D_PHY层,这只是最底层的,针对于显示,上层由分出了四种,由专门的工作组进行定义,显示器方面叫做display wrok group,主要分为 DSC(display comman ...

  3. leetcode--009 Linked List Cycle I

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZgAAACACAIAAAC5q+hAAAAJ+UlEQVR4nO2dwbXrKBJAOyelRShEQw

  4. time.setToNow() 取当前时间,月份有误

      [java] view plaincopy Time time = new Time("GMT+8"); time.setToNow(); int year = time.ye ...

  5. kmp算法理解与记录

    字符串匹配的暴力解法 给定字符串s和p,寻找字符串p在字符串s中出现的位置,暴力解法如下所示: 如果当前字符匹配成功,++i;++j,继续匹配下一字符. 如果s[i]与s[j]匹配失败,令i-=(j- ...

  6. RAMOS系统 WIN7+VHD+GURB map

    转载(并未验证) 前段时间加了一个内存条,将笔记本内存升级到了6G,由于之前用的是32位的win7不可以直接使用6G内存,便装了64位的系统.网上找资源的时候发现,大内存可以使用RamOS,从内存中虚 ...

  7. [转python 父类可以调用子类的方法

    问题描述:我也是在读500 Line 里满的DBDB 的代码时发现的,python的父类可以调用子类的方法,这跟平常习惯的理解方式很不一样,所以就查了下原因,记录如下:   1.现象:最近使用到了So ...

  8. Intent的概念及应用(二)

    ------siwuxie095 1.Intent过滤器 intent-filter 相关选项 如果多个Activity拥有同样的action,在启动时这个action时的情况: 首先在LearnIn ...

  9. 【Xilinx-VDMA模块学习】-01- VDMA IP的GUI配置介绍

    使用的是Vivado 2015.4,XC7Z020, AXI Video Direct Memory Acess(6.2). 在我的系统中,GUI配置图片如下:(其实和默认配置没有太大区别) 下面介绍 ...

  10. #最小生成树# #kruskal# ----- OpenJudge丛林中的路

    最小生成树 一个有 n 个结点的连通图的生成树是原图的极小连通子图,且包含原图中的所有 n 个结点,并且有保持图连通的最少的边.最小生成树可以用kruskal(克鲁斯卡尔)算法或prim(普里姆)算法 ...