前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >手把手:如何用R制作动态图

手把手:如何用R制作动态图

作者头像
大数据文摘
发布2018-05-21 17:20:38
1.1K0
发布2018-05-21 17:20:38
举报
文章被收录于专栏:大数据文摘

作者|顾运筠

如何用R制作动态的统计图呢?下面我们以“大数据文摘”国庆献礼的世界独立进程为例,手把手地教大家如何用R制作动态图。

  • 安装制作GIF所需要的ImageMagic程序

从http://www.imagemagick.org/script/binary-releases.php网址下载相关的ImageMagic.exe。安装ImageMagic.exe。安装完成后启动Rstudio编写代码。

  • 载入制作动画和地图的R程序包

library(animation)

library(maps)

  • 输入相关数据

由于国家很多,这里只选择几个国家,足够说明问题就可以了。

mtitle <-c("660","1668","1776","1788","1840","1867","1880","1948","1949","1950","1990")

regList<-list(c("Japan"),c("UK"), c("USA"), c("Australia"),c("NewZealand"), c("Canada"), c("France"),c("Korea","South Korea"), c("China","Hungary"),c("Kuwait","India"),c("Russia","Germany","Yemen"))

对区域的列表采用了list形式,同一年成立的国家包含在一个regList[[k]]元素中,这样成立年份就和区域列表的元素一一对应了。

  • 绘图函数绘制地图

采用maps包中的map函数绘制成立区域。代码如下:

#绘制空白世界地图

map("world")

#添加独立区域,着色

map("world", region=reg,exact=FALSE, add=TRUE, fill=TRUE, col="pink")

  • 制作动态图
  • 同一种颜色填充的世界独立进程动态图

#设定动画的时间间隔和帧数

oopt = ani.options(interval = 0.2, nmax =11)

#生成动画

for (i in 1:ani.options("nmax")){

map("world")

reg=""

reg=regList[[1]]

if (i>1) {

for (k in 2:i) {reg =c(reg,regList[[k]])}

}

map("world", region=reg, exact=FALSE, add=TRUE, fill=TRUE,col="pink")

title(mtitle[i])

#等待interval设置的时间长度

ani.pause()

}

#重载动画options

ani.options(oopt)

  1. 根据年份的不同,用不同颜色填充的世界独立进程动态图

oopt = ani.options(interval = 0.2, nmax =11)

amax=ani.options("nmax")

for (i in 1:amax) {

map("world")

for (k in 1:i) {

map("world",region=regList[[k]], exact=FALSE, add=TRUE, fill=TRUE,col=rgb(k+15,16,16,max=3*amax))

}

title(mtitle[i])

ani.pause()

}

ani.options(oopt)

  • 生成HTML文件或GIF图
  • 生成HTML文件

library(maps)

library(animation)

#设定网页文件所在目录

setwd("…./webpage")

mtitle <-c("660","1668","1776","1788","1840","1867","1880","1948","1949","1950","1990")

regList <- list(c("Japan"),c("UK"), c("USA"), c("Australia"),c("NewZealand"), c("Canada"), c("France"), c("Korea","SouthKorea"),c("China","Hungary"),c("Kuwait","India"),c("Russia","Germany","Yemen"))

saveHTML(

{

oopt = ani.options(interval = 0.2, nmax =11)

amax=ani.options("nmax")

for (i in 1:amax) {

map("world")

for (k in 1:i) {

map("world",region=regList[[k]], exact=FALSE, add=TRUE, fill=TRUE,col=rgb(k+15,16,16,max=3*amax))

}

title(mtitle[i])

ani.pause()

}

ani.options(oopt)

},img.name = "map1", imgdir ="./img", htmlfile = "map.html",

autobrowse =FALSE, title = "Demo of Country Independents")

  1. 生成GIF图

library(maps)

library(animation)

#设定GIF 图片所在目录

setwd("…./")

mtitle <-c("660","1668","1776","1788","1840","1867","1880","1948","1949","1950","1990")

regList <- list(c("Japan"),c("UK"), c("USA"), c("Australia"),c("NewZealand"), c("Canada"), c("France"),c("Korea","SouthKorea"),c("China","Hungary"),c("Kuwait","India"),c("Russia","Germany","Yemen"))

saveGIF(

{

oopt = ani.options(interval = 0.2, nmax =11)

amax=ani.options("nmax")

for (i in 1:amax) {

map("world")

for (k in 1:i) {

map("world",region=regList[[k]], exact=FALSE, add=TRUE, fill=TRUE,col=rgb(k+15,16,16,max=3*amax))

}

title(mtitle[i])

ani.pause()

}

ani.options(oopt)

},movie.name="demo.gif",img.name="map1")

粗略的就介绍到这里了。还可以生成flash等其他的动画,不一一列出了。祝大家工作、生活愉快!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2015-11-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 大数据文摘 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档