我试图通过包含国家国旗来制作一个带有ggplot/ggimage的气泡图。下面是一个可重复的例子:
library(dplyr)
library(ggplot)
library(ggimage)
A <- data.frame(X = c(1,4,5), Y = c(10, 1, 5), Z = c(1, 2, 3)/30, Country = c("FR", "BE", "IT"), CountryFlag = paste0("https://flagcdn.com/h20/", str_to_lower(Country), ".png"))
A_plot <- ggplot(A, mapping = aes(x = X, y = Y, size = I(Z), image = CountryFlag)) +
geom_image()
X11(); print(A_plot)除了下载四舍五入的标志外,是可以将国旗转换为圆形,还是可以将国家插入泡泡中。我尝试了以下代码,但它不起作用:
library(dplyr)
library(ggplot)
library(ggimage)
A <- data.frame(X = c(1,4,5), Y = c(10, 1, 5), Z = c(1, 2, 3), Country = c("FR", "BE", "IT"), CountryFlag = paste0("https://flagcdn.com/h20/", str_to_lower(Country), ".png"))
A_plot <- ggplot(A, mapping = aes(x = X, y = Y, size = Z, image = CountryFlag)) +
geom_point(alpha = 0.5, col = "lightblue") +
geom_image()
X11(); print(A_plot)我知道错误:
Error in `[<-`(`*tmp*`, !is.na(alpha), 4, value = alpha[!is.na(alpha)]) :
(subscript) logical subscript too long
In addition: Warning message:
In rep(colour, length.out = length(alpha)) :
'x' is NULL so the result will be NULL任何建议都是欢迎的。
发布于 2022-03-28 16:58:48
下面是一个函数,它为每个标志添加了一个循环掩码。如果我们从你的阴谋开始,
A_plot

我们获取urls并创建一些本地文件名:
flags <- A_plot$data$CountryFlag
png_files <- sapply(strsplit(flags, "/"), function(x) x[length(x)])现在,我们使用循环掩码创建一些图像,并在本地保存它们:
OK <- Map(function(flag, png) {
im <- magick::image_read(flag)
im <- magick::image_resize(im, magick::geometry_size_percent(500, 2000))
ii <- magick::image_info(im)
width <- ii$width
fig <- magick::image_draw(magick::image_blank(height, height))
symbols(width/2, width/2, circles=(width/2), bg='black', inches=FALSE, add=TRUE)
im2 <- magick::image_composite(im, fig, operator='copyopacity')
magick::image_write(im2, png)
}, flag = flags, png = png_files)现在,将这些文件路径写入绘图对象中的图像位置:
A_plot$data$CountryFlag <- png_files这将我们的图谋改变为:
A_plot

为了完整起见,一旦画出了情节,我们就应该自己整理:
sapply(png_files, unlink)https://stackoverflow.com/questions/71650342
复制相似问题