热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

esrileaflet入门教程(4)加载各类图层

esri-leaflet入门教程(4)-加载各类图层by李远祥在leaflet中图层一般分为底图(Basemap)和叠加图层(Overlay)。前面章节已经介绍过底图其实也是实

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(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-leaflet 还支持其他的一些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)-加载各类图层


推荐阅读
  • MySQL的查询执行流程涉及多个关键组件,包括连接器、查询缓存、分析器和优化器。在服务层,连接器负责建立与客户端的连接,查询缓存用于存储和检索常用查询结果,以提高性能。分析器则解析SQL语句,生成语法树,而优化器负责选择最优的查询执行计划。这一流程确保了MySQL能够高效地处理各种复杂的查询请求。 ... [详细]
  • 本文详细介绍了如何解决DNS服务器配置转发无法解析的问题,包括编辑主配置文件和重启域名服务的具体步骤。 ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • CentOS 7 中 iptables 过滤表实例与 NAT 表应用详解
    在 CentOS 7 系统中,iptables 的过滤表和 NAT 表具有重要的应用价值。本文通过具体实例详细介绍了如何配置 iptables 的过滤表,包括编写脚本文件 `/usr/local/sbin/iptables.sh`,并使用 `iptables -F` 清空现有规则。此外,还深入探讨了 NAT 表的配置方法,帮助读者更好地理解和应用这些网络防火墙技术。 ... [详细]
  • 解决Win10下MySQL连接问题:Navicat 2003无法连接到本地MySQL服务器(10061)
    本文介绍如何在Windows 10环境下解决Navicat 2003无法连接到本地MySQL服务器的问题,包括启动MySQL服务和检查配置文件的方法。 ... [详细]
  • 本文详细介绍了如何利用Duilib界面库开发窗体动画效果,包括基本思路和技术细节。这些方法不仅适用于Duilib,还可以扩展到其他类似的界面开发工具。 ... [详细]
  • Spark中使用map或flatMap将DataSet[A]转换为DataSet[B]时Schema变为Binary的问题及解决方案
    本文探讨了在使用Spark的map或flatMap算子将一个数据集转换为另一个数据集时,遇到的Schema变为Binary的问题,并提供了详细的解决方案。 ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
  • 解决 Windows Server 2016 网络连接问题
    本文详细介绍了如何解决 Windows Server 2016 在使用无线网络 (WLAN) 和有线网络 (以太网) 时遇到的连接问题。包括添加必要的功能和安装正确的驱动程序。 ... [详细]
  • 使用Jsoup解析并遍历HTML文档时,该库能够高效地生成一个清晰、规范的解析树,即使源HTML文档存在格式问题。Jsoup具备强大的容错能力,能够处理多种异常情况,如未闭合的标签等,确保解析结果的准确性和完整性。 ... [详细]
  • 在 LeetCode 的“有效回文串 II”问题中,给定一个非空字符串 `s`,允许删除最多一个字符。本篇深入解析了如何判断删除一个字符后,字符串是否能成为回文串,并提出了高效的优化算法。通过详细的分析和代码实现,本文提供了多种解决方案,帮助读者更好地理解和应用这一算法。 ... [详细]
  • 系统数据实体验证异常:多个实体验证失败的错误处理与分析
    在使用MVC和EF框架进行数据保存时,遇到了 `System.Data.Entity.Validation.DbEntityValidationException` 错误,表明存在一个或多个实体验证失败的情况。本文详细分析了该错误的成因,并提出了有效的处理方法,包括检查实体属性的约束条件、调试日志的使用以及优化数据验证逻辑,以确保数据的一致性和完整性。 ... [详细]
  • 装饰者模式(Decorator):一种灵活的对象结构设计模式
    装饰者模式(Decorator)是一种灵活的对象结构设计模式,旨在为单个对象动态地添加功能,而无需修改原有类的结构。通过封装对象并提供额外的行为,装饰者模式比传统的继承方式更加灵活和可扩展。例如,可以在运行时为特定对象添加边框或滚动条等特性,而不会影响其他对象。这种模式特别适用于需要在不同情况下动态组合功能的场景。 ... [详细]
author-avatar
mobiledu2502898253
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有