gpt4 book ai didi

r - Annotation_raster 在 ggplot 中不起作用

转载 作者:行者123 更新时间:2023-12-02 03:59:37 25 4
gpt4 key购买 nike

我正在尝试使用栅格注释功能将图像叠加在 ggplot map 上。我已按照此线程 How do I overlay an image on to a ggplot? 中的说明进行操作,但我使用“ggplot”而不是“qplot”来绘制我的图形。

但是,图像要么没有出现在图形上(当我运行绘图函数的前三行:ggplot、geom_polygon 和annotation_raster),或者如果我运行整个序列,就会产生此错误:

Error in if (nrow(layer_data) == 0) return() : argument is of length zero

我已经尝试了各种各样的方法,所以如果有人有任何想法如何解决这个问题,我将非常感激!

### Reproducible example
library(png)
library(ggplot2)

#Create data
scores <-c(5,10,-12,20)
area <-c(2630, 3970, 1550, 7485)
lat <- c(-16, -23, -30, -27)
long <- c(132, 143, 120, 140)

data <- as.data.frame(scores)
data[,2] <- as.data.frame(area)
data[,3] <- as.data.frame(long)
data[,4] <- as.data.frame(lat)
colnames(data)<-c("scores","area","lon","lat")

#Load PGN image for raster annotation
mypngfile <- download.file('http://upload.wikimedia.org/wikipedia/commons/thumb/c/c1/Rlogo.png/200px-Rlogo.png', destfile = 'mypng.png', mode = 'wb')
mypng <- readPNG('mypng.png')


#Breaks and colours for mapping
brks <- c(-20,-10,0,10,20)
colors <- rev(c(rgb(0,0,0.6),rgb(0,0.6,1),rgb(0,0.8,1),rgb(0.8,1,0.2)))
plot_data <- as.numeric(cut(data$scores,breaks=brks))
col_data <- as.factor(plot_data)

#Map of Australia
Australia<-map_data("world",region = c("Australia", "Australia:Tasmania"))
Oz<-subset(Australia,long>110 & lat>-50 & long<155)

#Create plot
ggplot() +
geom_polygon( data=Oz, aes(x=long, y=lat, group=group), colour="black", fill="grey68") +
annotation_raster(mypng,xmin=120, xmax=130, ymin=-45, ymax=-49) +
geom_point(data=data,aes(x=long,y=lat,color=col_data, size=area),show_guide=F) +
scale_size_area(name="area",max_size=20)

最佳答案

只需要一个小的修正(我还调整了 R Logo 的坐标以使其可见):

ggplot(data=Oz, aes(x=long, y=lat)) +
geom_polygon(aes(group=group), colour="black", fill="grey68") +
annotation_raster(mypng, xmin=120, xmax=130, ymin=-37, ymax=-44) +
geom_point(data=data, aes(colour=col_data, size=area), show_guide=F) +
scale_size_area(name="area", max_size=20)

enter image description here

关于r - Annotation_raster 在 ggplot 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22370977/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com