问题描述
我正在尝试在R中定义情节的传说。
我有以下代码,这只是一个演示,实际数据将具有7-8列和最多20个样本
library(ggplot2)
library(RColorBrewer)
colors <-brewer.pal(n = 3,name = 'Paired')
ids <- c("TestA","TestB","TestC")
bg <-c(23,13,15)
sample1 <- c(21,15,17)
sample2 <- c(27,25,11)
sample3 <- c(24,14,18)
df <- data.frame(ids,bg,sample1,sample2,sample3)
ggplot(df) +
geom_col(aes(x = ids,y = bg),size = 1,color = "grey",fill = "grey") +
geom_point(aes(x = ids,y = sample1),size = 10,color=colors[1],group = 1) +
geom_point(aes(x = ids,y = sample2),color=colors[2],y = sample3),color=colors[3],group = 1)+
ggtitle("Plot title") +
xlab("x label") + ylab(" y label") +
scale_colour_manual(values = c("95% PI"= "black","Forecasts" = "red","Threshold" = "green"))
如何添加下图所示的图例,并确保颜色匹配,即图例颜色与样本或背景色匹配
解决方法
这是您想要的吗?
ggplot(df) +
geom_col(aes(x = ids,y = bg,fill = "background"),size = 1,color = "grey") +
geom_point(data = df %>% pivot_longer(cols = starts_with("sample"),names_to = "sample",values_to = "values"),aes(x = ids,y = values,color = sample),size = 10) +
ggtitle("Plot title") +
xlab("x label") + ylab(" y label") +
scale_colour_manual(name = NULL,values = c("sample1"= "black","sample2" = "red","sample3" = "green"),labels = c("95% PI","forecasts","Threshold")) +
scale_fill_manual(name = NULL,values = c("background" = "grey"))