这篇教程憋了很久,其实算是3个月前leaflet在线地图系列的进阶篇,但是因为当时对于leaflet地图的数据源结构理解有限,技能勉强操控shp数据源,对于json数据源所知甚少,一直拖了这么久才更新。
随着近期在json数据结构的理解不断加深,对于list结构和向量化运算的掌握也多有提高,这才能熟练的在leaflet系统中操控json数据。
本篇主要分为两大部分:
- 如何自如的操纵json数据来打造leaflet所能识别的数据源和style属性;
- 如何操控leaflet控制台版面中的地图图层和数据图层。
想要很好的理解本文,你需先对leaflet系统基础语法有所掌握(其实可视化的图层语法都大同小异,leaflet属于JavaScript语言打造的在线地图库,同D3、plotly、Rcharts以及Highcharts等接口的语法差别不大)。
但如果你在看本文之前已经看过我的前期四篇leaflet入门篇:
那么本文理解起来就容易多了,仅仅是温故知新罢了!
当然如果你学有余力的话,你也可以顺便把百度的Echarts系统地图接口也学习一下:
如果你能熟练掌握以上两套在线地图语法,那么制作此类可视化项目至少在技术角度上来说已经没有任何门槛。
以下是本文的主要内容:
json地图数据结构和变量操控:
加载包:
|
|
导入数据集:
这样的全局预设可以为你省却很多麻烦,强烈建议
|
|
最近把自己所有的关于地图可视化的数据传到了个人Github上,这样无论是大家以后调用数据还是自己平时练习都方便多了!
以下数据导入json原生数据格式的三种方式:(2,3两种是没啥区别的,但是simplifyVector=FALSE参数设定与否则至关重要,他决定着输入的json数据是经过平整的向量化数据还是原生的list数据,这里的leaflet需要原生格式的json数据)
|
|
设置随机中非常必要,否则容易导致每次的效果都不一样:
向地图素材中添加作图数据:
向list对象中添加数据(随机数据)
从list对象中读取数据(主要读取我们可做更改与扩展的行政区划列表信息)
Default styles for all features
it has higher precedence compare with the style in a function of GeoJSON
1 geojson3$style=list(weight=1,color="#555555",opacity=1,fillOpacity=0.8)
Color by scale using quantiles
Add a properties$style list to each feature
关于属性设置的三个优先级:
按照由高到低的顺序排列为:
这是通过增加地图图层来进行图层控制的简单案例:
|
|
以下这段代码是之前leaflet系列教程的线图篇里面的案例,这里刚好应用一下:
|
|
这是一个高度综合的案例,包含底图图层的多分类控制;数据图层的多分类控制以及点线面三种数据图层的综合运用。
|
|
动态视频效果来一波!
联系方式:
wechat:ljty1991
Mail:578708965@qq.com
个人公众号:数据小魔方(datamofang)
qq交流群:[魔方学院]298236508
个人简介:
杜雨
财经专业研究僧;
伪数据可视化达人;
文科背景的编程小白;
喜欢研究商务图表与地理信息数据可视化,爱倒腾PowerBI、SAP DashBoard、Tableau、R ggplot2、Think-cell chart等诸如此类的数据可视化软件,创建并运营微信公众号“数据小魔方”。
Mail:578708965@qq.com
备注信息:
本作品采用知识共享署名-非商业性使用 4.0 国际许可协议进行许可。