【R语言】动画图:散点图

绘制成如下的散点图:

如果数据量大,有多个年份,就会生成多张图,例如:

具体代码如下:

R 复制代码
library(gapminder)#加载 gapminder 包,其中包含了从 1952 年至 2007 年各个国家的 GDP、预期寿命和人口数据
library(gganimate)#加载 gganimate 包,它提供了创建动画的功能
library(ggplot2)

#使用 ggplot() 函数创建了一个基础图形,设置 x 轴为 GDP 每人,y 轴为预期寿命,点的大小(size)和颜色(colour)根据国家来区分
ggplot(gapminder, aes(gdpPercap, lifeExp, size = pop, colour = country)) +
  geom_point(alpha = 0.7, show.legend = FALSE) + #添加了散点图层,设置点的透明度为 0.7,且不显示图例
  scale_colour_manual(values = country_colors) + #设置颜色映射为手动指定的颜色,country_colors 是一个预先定义的颜色向量
  scale_size(range = c(2, 12)) + #设置点的大小范围为 2 到 12
  scale_x_log10() + #将 x 轴的刻度设置为对数尺度
  facet_wrap(~continent) + #根据大洲进行面板分割
  labs(title = 'Year: {frame_time}', x = 'GDP per capita', y = 'life expectancy') + #设置图形的标题、x 轴标签和 y 轴标签,其中 {frame_time} 会被动画帧的时间替换
  transition_time(year) + #指定以年份(year)为时间变量进行过渡,使得动画按照时间的变化进行播放
  ease_aes('linear') -> anim #设置动画的渐变效果为线性,将动画保存到名为 anim 的对象中

为了生成动画的形式,还需执行以下代码:

R 复制代码
#生成并显示动画,使用 gifski_renderer() 渲染器,并设置帧率为 10
animate(anim, renderer = gifski_renderer(), fps = 10) 

实现效果,如下:

gapminder 是一个在 R 中广泛使用的数据集,记录了从 1952 年到 2007 年间不同国家的 GDP、预期寿命和人口数据。这个数据集最初由 Hans Rosling 等人在 Gapminder Foundation 的工作中收集和整理,旨在帮助人们更好地理解全球发展趋势。

数据集中包含了以下变量:

  1. country: 国家名称。
  2. year: 年份,范围从 1952 到 2007 年。
  3. pop: 人口数量,以百万为单位。
  4. continent: 大洲名称,包括非洲、亚洲、欧洲、美洲和大洋洲。
  5. lifeExp: 预期寿命,以年为单位。
  6. gdpPercap: GDP 每人,即每个人的国内生产总值,通常以美元为单位。
    如下图所示:
相关推荐
不爱学习的小枫1 小时前
scala的集合
开发语言·scala
梦醒沉醉1 小时前
Scala的初步使用
开发语言·后端·scala
小白学大数据1 小时前
Fuel 爬虫:Scala 中的图片数据采集与分析
开发语言·爬虫·scala
贩卖纯净水.1 小时前
《React 属性与状态江湖:从验证到表单受控的实战探险》
开发语言·前端·javascript·react.js
JouJz1 小时前
Java基础系列:深入解析反射机制与代理模式及避坑指南
java·开发语言·代理模式
白羊不吃白菜2 小时前
PAT乙级(1101 B是A的多少倍)C语言解析
c语言·开发语言
一号言安2 小时前
牛客python蓝桥杯11-32(自用)
开发语言·python
鸽鸽程序猿2 小时前
【JavaEE】SpringIoC与SpringDI
java·开发语言·java-ee
maybe啊2 小时前
js 使用 Web Workers 来实现一个精确的倒计时,即使ios手机锁屏或页面进入后台,倒计时也不会暂停。
开发语言·前端·javascript
Ljw...3 小时前
序列化和反序列化(Linux)
linux·开发语言·网络·c++·tcp/ip·序列化反序列化