简介
关于地理地图绘制已经由师弟师妹系统出了几期。具体推文可见:
- Leaflet 与高德合并会擦出怎么样的火花?
- Leaflet 与高德继续碰撞火花!
- 空间地理数据可视化之 mapview 包
- 空间地理数据可视化之 leaflet 包及其拓展
- 空间地理数据可视化之 tmap 包及其拓展
- 空间地理数据可视化之 ggplot2 包及其拓展
- 空间地理数据可视化之前言
网上有很多关于中国地图绘制教程,但是关于省市级地图绘制非常少,本推文就是来解决这个问题。下面推文主要以浙江省、温州市为例,使用 leaflet 包绘制省/市级地图。
绘制省级地图
首先,使用 regionNames()
导入浙江省各市的名字。dem_data
可以是读者想要填充在地图上的数据(例如:各市的 GDP,空气质量指数等数据)。使用 leafletGeo()
创建一个 sp 对象的数据框。
代码语言:javascript复制注意:这里的
dem_data
可以是连续型或离散型变量(各市 GDP 排名),以下例子使用runif()
随机生成连续型数据。
library(leaflet) #加载包
library(leafletCN)
region = regionNames("浙江")
dem_data = runif(length(region)) # 这里使用自己的数据
dat = data.frame(region,dem_data)
map = leafletGeo("浙江", dat)
构建好数据集之后,进行绘图。载入高德地图 amap,设置各市边界及颜色并加入图例,得到以下 html 形式图形。
代码语言:javascript复制#涂色环节
pal <- colorNumeric(
palette = "Blues",
domain = map$value)
#载入高德地图amap
leaflet(map) %>% amap() %>%
#加入框边界及颜色
addPolygons(stroke = TRUE,
smoothFactor = 2,
fillOpacity = 0.7,
weight = 1,
color = ~pal(value),
popup = ~htmltools::htmlEscape(popup)
) %>%
#加入右下角边框
addLegend("bottomright", pal = pal, values = ~value,
title = "legendTitle",
labFormat = leaflet::labelFormat(prefix = ""),
opacity = 1)
由于小编能力有限,下面的图是通过 ppt 手动添加的文字(涂色换成palette = "Greens"
,数据来自真实数据,其他代码相同),然后应用到自己的论文中。如果你要发表到英文期刊,建议图内不要出现中文。
绘制市级地图
绘制市级地图与绘制省级地图类似,只需在regionNames()
中进行变化即可,其他几乎相同。下面绘制的温州市地图做了一些小小的拓展。1. 使用真实案例数据;2. 填充颜色变化。数据处理方面主要是用 dplyr 包的 full_join()
,具体细节就不做过多介绍了。
#===============================================================
#======================== 温州市地图绘制 =======================
#===============================================================
library(leafletCN)
library(dplyr)
library(leaflet)
#demomap("温州")
#主函数——geojsonmap:地图标色函数
data = read.csv("各区县经营效率.csv",header=T)
data$mean = apply(data[,2:13],1,mean)
colnames(data) = c('region',as.character(2009:2020),"mean")
dim(data)
region = regionNames("温州市")
dat = data.frame(region,runif(length(region)))
data1 = full_join(dat,data[,c(1,8)])
data2 = data1[,-2]
map = leafletGeo("温州市", data2)
#涂色环节heat.colors(6,rev = T)
# c("#FFFF00FF","#FF0000FF","#00FF00FF","#00FFFFFF","#FF00FFFF","#0000FFFF")
pal <- colorNumeric(
palette = c("purple","blue","lightblue","green","yellow","orange",'red'),
domain = map$value)
#载入高德地图amap
leaflet(map) %>% amap() %>%
#加入框边界及颜色
addPolygons(stroke = TRUE,
smoothFactor = 1,
fillOpacity = 1,
weight = 1,
color = ~pal(value),
popup = ~htmltools::htmlEscape(popup)
) %>%
#加入右下角边框
addLegend("bottomright", pal = pal, values = ~value,
title = "效率值",
labFormat = leaflet::labelFormat(prefix = ""),
opacity = 2)
小编有话说
- 本推文主要介绍,如何使用 leaflet 包绘制省/市级地图并以浙江省、温州市作为案例。读者可以使用函数保存该图片,并将其使用到论文中。
- 但是本推文的省市级绘图还存在几个问题,小编还没有能力通过代码解决:1. 如何凸显各市/县的名字到填充颜色上方?2. 有些市、县发生变化(从县变为区),但 leaflet 包没有及时更新,应该如何处理?
- 以上是小编在实际科研中存在的问题,我的“笨”办法是:画图细节不会改?那就用 AI 吧!。或者使用 ppt,手动修改。如果读者们有什么好办法,可以留言分享下,十分感谢。