使用带有R动画包的磁盘上的图像文件

时间:2015-10-17 02:12:03

标签: r animation

我使用R来创建一系列需要很长时间才能运行的图像。我想使用动画包从它们制作视频,而无需重新运行分析。

我找不到使用文件中现有图像的示例。最接近的是Yihui Xie的演示('flowers')来创建HTML动画。我改变了他的代码,可以成功制作花卉图像的mp4,但我不知道如何访问已存档的图像。

根据他的代码,它应该是这样的:

library(animation)
oopts = if (.Platform$OS.type == "windows") {
ani.options(ffmpeg = "C:/Software/ffmpeg/ffmpeg-20151015-git-0418541-win64-static/bin/ffmpeg.exe")}

#My list of images from disk
extList = list.files(myDir, pattern='.jpg', full.names=T)
saveVideo({
for (i in 1:length(extList)) {

#Yihui Xie's example downloads jpegs from web
#This code works to make an mp4 but I want to use images from disk
#extList = c('http://i.imgur.com/rJ7xF.jpg',
#         'http://i.imgur.com/Lyr9o.jpg',
#          'http://i.imgur.com/18Qrb.jpg')
#download.file(url = extList[i], destfile = sprintf(ani.options('img.fmt'), i), mode = 'wb')

someFunctionToAccessImage(extList[i])

  }
}, video.name='notFlowers.mp4',
use.dev = FALSE, 
ani.type = 'jpg',
interval = 2, 
single.opts = "'dwellMultiplier': 1")

红利问题 - 我可以使用PNG或其他图像类型吗?

1 个答案:

答案 0 :(得分:4)

我发现这有几个问题。 saveVideo使用临时目录来处理文件并制作电影。此外,它添加到图像名称的后缀无法正常工作。因此,这里有一种方法可以将您存储的文件夹中的图像复制到saveVideo使用的临时目录中。棘手的部分是找到该目录的路径,这是使用表达式中定义的函数的sys.frame完成的。

注意:另一种可能的选择是手动将图像复制到您知道saveVideo将使用的临时文件夹(它将调用tempdir()),或重新定义tempdir()以返回你当前图片的路径,但我还没有测试过。

library(animation)
oopts = if (.Platform$OS.type == "windows")
    ani.options(ffmpeg = "C:\\home\\src\\ffmpeg-20151017-git-e9299df-win64-static\\bin\\ffmpeg.exe")

## Some variables
dirPath <- normalizePath("images/")  # path to folder containing images
postfix <- "%03d"                    # I created my files with "Rplot%03d"

## Make the animation
saveVideo({
    ## Need to retrieve some variables from environments up the call stack
    env.info <- (function() { list(wd = sys.frame(-1)$owd, fmt=sys.frame(-2)$img.fmt,
                                   e=sys.frame(-2)) })()
    postfix <- postfix
    img.fmt <- gsub("%d", postfix, env.info$fmt, fixed=TRUE)
    assign('img.fmt', img.fmt, envir=env.info$e)
    file.copy(list.files(dirPath, full.names = TRUE), to=env.info$wd, overwrite = TRUE)
}, video.name='heatBalls.mp4', img.name='Rplot', interval = .05, use.dev=FALSE)

完整示例

## Random function to save some images to disk
circ <- function(x,y,r) { s <- seq(-pi,pi,len=30); data.frame(x=x+r*cos(s), y=y+r*sin(s)) }
imgFun <- function(n, ncircs, dirPath) {
    if (!require(scales)) stop("install scales package")
    rads <- runif(ncircs, 0.5, 3)
    xs <- runif(ncircs, 0.1+rads, 19.9-rads)
    ys <- runif(ncircs, 0.1+rads, 19.9-rads)
    vs <- matrix(runif(ncircs*2), 2)
    cols <- colorRampPalette(c('lightblue','darkblue'), alpha=0.3)(ncircs)
    png(file.path(dirPath, 'Rplot%03d.png'))
    for (i in seq_len(n)) {
        image(x=seq(0, 20, length=20), y=seq(0, 20, length=20),
              z=matrix(rnorm(400),20), col=heat.colors(20, alpha=0.6), xlab='', ylab='')
        for(j in 1:ncircs) polygon(x=circ(xs[j], ys[j], rads[j]), col=alpha(cols[j],0.7))
        condx <- (xs + rads) > 20 | (xs - rads) < 0
        condy <- (ys + rads) > 20 | (ys - rads) < 0
        vs[1,condx] <- -vs[1,condx]
        vs[2,condy] <- -vs[2,condy]
        xs <- xs + vs[1,]
        ys <- ys + vs[2,]
    }
    dev.off()
}

## Create some images on disk in a folder called "images"
dirPath <- normalizePath("images/")
dir.create(dirPath)
imgFun(50, 18, dirPath)

然后运行上面的代码,应该制作如下的电影。

enter image description here