使用R语言绘制简单地图的教程

今天主要讲的部分是绘制静态地图,使用的R语言绘图包是tmap,关于介绍就不多讲,下面开始代码的讲解,小白也可以放心食用。

1、绘制简单的单幅地图,这里以新西兰地区为例

R 复制代码
#导入必要的包
library(tmap)
library(sp)
library(spData)

# 只显示填充
tm_shape(nz) + 
  tm_fill()
# 只显示边界
tm_shape(nz)+
  tm_borders()
# 填充和边界都显示
tm_shape(nz)+
  tm_fill()+
  tm_borders()

通过上面的代码,事实上我们分别可以得到三个不同版本的地图,分别为"只显示填充"(左),"只显示边界"(中),"边界和填充都显示"(右)

传给tm_shape()的对象是nz,这个nz是代表新西兰地区的sf类型的对象,我们可以通过一行简单的代码查看一下nz的属性,如下:

注意:在实际使用中我们通常使直接使用tm_polygons()方法绘制填充和边界。

R 复制代码
tm_shape(nz) + tm_polygons()
# tm_polygons()函数就是把tm_fill() 和 tm_borders()合成了一个

2、绘制组图或者叫多幅地图

tmap可以提供"tmap"类的对象,我们可以把绘制好的地图暂存在tmap对象中,通过制作多个tmap对象来达到绘制组图的目的。

R 复制代码
#map1和map2就是tmap对象
map1 = tm_shape(nz) + tm_polygons(col = "Population")
map2 = tm_shape(nz) + tm_polygons(col = "Median_income")
#绘制组图
tmap_arrange(map1,map2)

这个组图的图例出现了一些问题,是由于图例太窄放不下文字造成的,另外我们还需要添加一些地图要素,如比例尺,指北针等等。可通过下面的代码来完成:

R 复制代码
map1 = tm_shape(nz) + tm_polygons(col = "Population") +
  tm_compass(position = c(0.8,0.8))+ 
  tm_layout(legend.width = 2)+
  tm_scale_bar(breaks = c(0,100,200),text.size = 1)
map2 = tm_shape(nz) + tm_polygons(col = "Median_income") +
  tm_compass(position = c(0.8,0.8))+ 
  tm_layout(legend.width = 2)+
  tm_scale_bar(breaks = c(0,100,200),text.size = 1)
tmap_arrange(map1,map2)

以上就是今天的内容,主要就是要熟练各类地图函数的参数设置,总结来说R语言绘制地图并不难。如果这个教程有帮到你,请点赞转发支持一下!我是加拿大一直黄花,我们下期再见。

相关推荐
用户5569188175344 分钟前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录
python·自动化运维
兵慌码乱15 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析
python·opencv·计算机视觉·人机交互·手势识别·mediapipe·pyside2
luckdewei17 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化
python
aqi001 天前
15天学会AI应用开发(八)使用向量数据库实现RAG功能
人工智能·python·大模型·ai编程·ai应用
Csvn1 天前
`functools.lru_cache` —— 一行代码搞定缓存加速
后端·python
金銀銅鐵2 天前
[Python] 从《千字文》中随机挑选汉字
后端·python
cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
aqi002 天前
15天学会AI应用开发(七)有了大模型为什么还要引入RAG
人工智能·python·大模型·ai编程·ai应用