空间地理数据可视化之 ggplot2 包及其拓展

2021-08-20 17:11:46 浏览数 (1)

点击下方公众号,回复资料分享,收获惊喜

前言

上次 R 可视乎主要讲述了《Geospatial Health Data》[1]一书中关于空间地理数据可视化R 包制作地图的基础内容,参见 R可视乎|空间地理数据可视化(1)。本篇将继续介绍空间地理数据可视化的 R 包和函数。

众所周知,地图对于传达地理空间信息非常有用,我们将介绍一些简单的例子,展示一些在 R 语言中常用于制图的包,即 ggplot2tmapleafletmapview 等。

本篇将主要介绍 ggplot2 包及函数的用法以及它的拓展( gganimateplotly 包)。

1. 基本画图设置

ggplot2[2]是一个基于图形语法来创建图形的包,因此我们可以使用 ggplot() 函数和以下元素创建一个图:

  • 想要可视化的数据;
  • 指定数据的几何形状,如点或条。形状是用 geom_*() 函数指定的,例如,geom_point() 用于表示点,geom_histogram() 用于表示柱状图;
  • 几何对象的美化,如颜色、大小等。其中,aes() 用于将数据中的变量映射为对象的视觉属性;
  • 可选的元素,如标尺、标题、标签、图例和主题等。

我们可以使用 geom_sf() 函数和一个简单特征对象( sf 类)来创建地图。如果可用的数据是 SpatialPolygonsDataFrame 类的空间对象,可以用 sf 包的 st_as_sf() 函数轻松地将其转换为 sf 类的简单特征对象。

例子:创建一个 1974 年北卡罗来纳州婴儿猝死的地图,如下所示(其中 map 数据可在上篇公众号(R可视乎|空间地理数据可视化(1))第 4 部分图形文件中找到相关代码):

代码语言:javascript复制
library(ggplot2)
map <- st_as_sf(map)
ggplot(map)   geom_sf(aes(fill = SID74))   theme_bw()

1974 年北卡罗来纳州婴儿猝死的地图

2. 更多设置

  1. ggplot() 中,离散变量的默认色标是 scale_*_hue() ,这里 * 表示颜色(为点和线等特征着色)或填充(为多边形或柱状图着色);
  2. scale_*_grey() 用来改变灰色颜色的默认比例, scale_*_distiller()scale_*_brewer() 使用 RColorBrewer 包的颜色(Neuwirth 2014),scale_*_viridis 使用 viridis 包的颜色(Garnier 2018);
  3. 可用 scale_*_manual() 手动定义我们自己的颜色集,此函数有一个逻辑参数叫 drop ,用来决定是否在尺度中保留不常用的因子水平;
  4. 连续变量的颜色刻度可以用 scale_*_gradient() 来指定,它在两种颜色(低-高)之间创建一个连续的梯度,scale_*_gradient2() 创建一个发散的颜色梯度(低-中-高),scale_*_gradientn() 创建一个 n 种颜色的梯度。

如果你是可视化的 R 小白,推荐你看一下庄小编的 ggplot 可视化教程,课件如下:R分享|自制112页可视化课件。在公众号回复:可视化文稿 即可免费获得,对应的视频教程见b站

下图是用 viridis 包中的 scale_*_distiller() 函数和 ggplot() 函数绘制的 1974 年北卡罗来纳州婴儿猝死的地图:

例子

代码语言:javascript复制
library(viridis)
map <- st_as_sf(map)
ggplot(map)   geom_sf(aes(fill = SID74))  
  scale_fill_viridis()   theme_bw()

viridis 和 ggplot2 创建的 1974 年北卡罗来纳州婴儿猝死的地图

3. 图像保存

要保存用 ggplot2 绘制的图,我们可以使用 ggsave() 函数。另外,我们也可以通过指定一个设备驱动(如 pngpdf )来保存绘图,打印绘图,然后用 dev.off() 关闭设备。

代码语言:javascript复制
ggsave("plot.jpg")
ggplot(map)   geom_sf(aes(fill = SID74))  
  scale_fill_viridis()   theme_bw()

png("plot1.png")
ggplot(map)   geom_sf(aes(fill = SID74))  
  scale_fill_viridis()   theme_bw()
dev.off()

4. 内容扩展

gganimate 包[3]plotly 包[4]可以与 ggplot2 包结合使用,分别创建动画和交互式绘图。

4.1 gganimate 包

一个典型的例子是使用 gapminder 数据集创建的动画,其中 transition_time() 是核心函数,添加动态。

例子

代码语言:javascript复制
library(ggplot2)
library(gganimate)
library(gapminder)
head(gapminder)

我们使用gapminder数据集做一个简单的例子,前 6 行数据如下所示:

前 6 行数据

接下来我们根据不同情况进行数据可视化。

以年份的形式进行动画演示

代码语言:javascript复制
theme_set(theme_bw())
p <- ggplot(gapminder,
            aes(x = gdpPercap, y=lifeExp, size = pop, colour = country))  
  geom_point(show.legend = FALSE, alpha = 0.7)  
  scale_color_viridis_d()  
  scale_size(range = c(2, 12))  
  scale_x_log10()  
  labs(x = "GDP per capita", y = "Life expectancy")

p   transition_time(year)   labs(title = "Year: {frame_time}")

gapminder 数据集创建的动画

将数据点作为背景

加入参数shadow_mark(alpha = 0.3, size = 0.5),使得数据点作为动画演示的背景。

代码语言:javascript复制
p   transition_time(year)   
    labs(title = "Year: {frame_time}")   
    shadow_mark(alpha = 0.3, size = 0.5)

将数据点作为背景后的动画

按大陆创建分面

使用facet_wrap(~continent),创造分面。

代码语言:javascript复制
p   facet_wrap(~continent)  
  transition_time(year)  
  labs(title = "Year: {frame_time}") 

按大陆创建分面后的动画

4.2 plotly 包

Rplotly 包是一个基于浏览器的交互式图表库,它建立在开源的 JavaScript 图表库 plotly.js 之上。它通过 HTML widgets 框架完全在本地上运行,把结果上传到 plotly 账户,可以查看交互图及相应的数据,并进行修改。plotlyggplot2 结合,可创建交互式地图,实现放大、缩小、移动等操作。

例子1

我们还是使用原来那个地图作为例子,这时候使用ggplotly()将其转化为一个可交互的图形。

代码语言:javascript复制
library(plotly) 
library(ggplot2) 
library(viridis)
library(sf)
map <- st_as_sf(map)
p2 <- ggplot(map)   geom_sf(aes(fill = SID74))  
  scale_fill_viridis()   theme_bw()
ggplotly(p2)

plotly 与 ggplot2 创建的1974年北卡罗来纳州婴儿猝死的地图

例子2

或者使用该包自带的函数plot_ly()进行可视化。

代码语言:javascript复制
library(plotly)
set.seed(100)
d <- diamonds[sample(nrow(diamonds), 1000), ]
plot_ly(d, x = ~carat, y = ~price, color = ~carat,size = ~carat, text = ~paste("Clarity: ", clarity))

poltly 创建的钻石的克拉数与价格之间的变动关系

小编有话说

  • 本篇主要介绍:《Geospatial Health Data》 一书中 ggplot2 包和函数的基本使用方法,另外扩展了一些其他相关内容。
  • 本篇是空间地理数据可视化系列的第二期,主要由 林华师 制作。本系列的宗旨是带你系统学习如何使用 R 对空间地理数据进行可视化。下一期将会继续介绍其他可视化的 R 包,敬请期待。

参考资料

[1]

《Geospatial Health Data》: https://www.paulamoraga.com/book-geospatial/sec-spatialdataandCRS.html

[2]

ggplot2: https://ggplot2.tidyverse.org/

[3]

gganimate 包: https://blog.csdn.net/weixin_45178611/article/details/108053035

[4]

plotly 包: https://my.oschina.net/u/2605101/blog/597871

推荐: 可以保存以下照片,在 b 站扫该二维码,或者 b 站搜索【庄闪闪】观看 Rmarkdown 系列的视频教程。Rmarkdown 视频新增两节视频(写轮眼幻灯片制作)需要视频内的文档,可在公众号回复【rmarkdown

可视化推文推荐

R可视乎|空间地理数据可视化(1)

R可视乎|用R给心仪的对象表白吧

R可视乎|棒棒糖图

R可视乎|合并多幅图形

R可视乎|等高线图

R可视乎|气泡图

0 人点赞