给定 png/jpeg 格式的“n”个图像和 2 个维度(x,y)中的“n”个对应坐标:我想在一个图上的给定坐标处绘制这些图像。如果我发现图像太大,理想情况下我希望将它们绘制为给定坐标处的较小/缩放版本。我怎样才能在 R 中实现这样的情节?
下面给出了这样一个图的外观示例:
给定 png/jpeg 格式的“n”个图像和 2 个维度(x,y)中的“n”个对应坐标:我想在一个图上的给定坐标处绘制这些图像。如果我发现图像太大,理想情况下我希望将它们绘制为给定坐标处的较小/缩放版本。我怎样才能在 R 中实现这样的情节?
下面给出了这样一个图的外观示例:
xy <- data.frame(x=runif(10, 0, 100), y=runif(10, 0, 100))
require(png)
img <- readPNG(system.file("img", "Rlogo.png", package="png"))
thumbnails <- function(x, y, images, width = 0.1*diff(range(x)),
height = 0.1*diff(range(y))){
images <- replicate(length(x), images, simplify=FALSE)
stopifnot(length(x) == length(y))
for (ii in seq_along(x)){
rasterImage(images[[ii]], xleft=x[ii] - 0.5*width,
ybottom= y[ii] - 0.5*height,
xright=x[ii] + 0.5*width,
ytop= y[ii] + 0.5*height, interpolate=FALSE)
}
}
plot(xy, t="n")
thumbnails(xy[,1], xy[,2], img)
该my.symbols
函数和ms.image
函数(均来自 TeachingDemos 包)可用于绘制图像。
这是一个例子:
library(png)
flag.list <- lapply( list.files('flags/',pattern='png$', full=TRUE),
function(x) readPNG(x) )
library(TeachingDemos)
ms.flags <- function(ind,...) {
tmp <- array(0, dim=c(150,150,4) )
tmp[ 26:125, , 1:3] <- flag.list[[ind]]
tmp[ 26:125, , 4 ] <- 1
ms.image(tmp,...)
}
x <- rnorm(50)
y <- rnorm(50)
my.symbols(x,y, symb = ms.flags, ind=1:50, symb.plots=TRUE,
add=FALSE, xlim=c(-3,3), ylim=c(-3,3), inches=0.75)
ggflags 包提供了一个原理证明示例
library(ggflags)
set.seed(1234)
d <- data.frame(x=rnorm(50), y=rnorm(50),
country=sample(c("ar","fr", "nz", "gb", "es", "ca"), 50, TRUE),
stringsAsFactors = FALSE)
ggplot(d, aes(x=x, y=y, country=country, size=x)) +
geom_flag() +
scale_country()