我有如下的情节如下。它是用下面的命令创建的:

library(ggplot2)

df <- data.frame(cond = factor(rep(c("A", "B"), each = 200)), 
                 rating = c(rnorm(200), rnorm(200, mean=.8)))

ggplot(df, aes(x=rating, fill=cond)) + 
geom_density(alpha = .3) +
xlab("NEW RATING TITLE") +
ylab("NEW DENSITY TITLE")

现在,我想把传说标题从cond修改为NEW legend title。

所以,我只是添加了下面的行添加上述代码的结尾:

+labs(colour="NEW LEGEND TITLE")

但这并不奏效。正确的做法是什么?


当前回答

这应该可以工作:

p <- ggplot(df, aes(x=rating, fill=cond)) + 
           geom_density(alpha=.3) + 
           xlab("NEW RATING TITLE") + 
           ylab("NEW DENSITY TITLE")
p <- p + guides(fill=guide_legend(title="New Legend Title"))

(或者)

p + scale_fill_discrete(name = "New Legend Title")

其他回答

我没有深入研究,但因为你在ggplot()中使用了fill=cond,

 + labs(color='NEW LEGEND TITLE') 

可能没起作用。无论你用填充代替颜色,它都是有效的!

+ labs(fill='NEW LEGEND TITLE') 

我在ggplot2_2.1.0中使用了这种方法

这应该可以工作:

p <- ggplot(df, aes(x=rating, fill=cond)) + 
           geom_density(alpha=.3) + 
           xlab("NEW RATING TITLE") + 
           ylab("NEW DENSITY TITLE")
p <- p + guides(fill=guide_legend(title="New Legend Title"))

(或者)

p + scale_fill_discrete(name = "New Legend Title")

我在ggplot中使用facet_wrap,除了ArnaudA的解决方案外,没有一个建议的解决方案适合我:

qplot(…) + guides(color=guide_legend(title="sale year")) 

唉,这些解决方案对我都不起作用。我正在使用brms::conditional_effects()的输出。

我的解决方案需要:

+实验室(fill = "新标题",color = "新标题",labels = "新标题")

为了添加到列表中(这里的其他选项对我不起作用),你还可以为ggplot使用update_labels函数:

p <- ggplot(df, aes(x=rating, fill=cond)) + 
           geom_density(alpha=.3) + 
           xlab("NEW RATING TITLE") + 
           ylab("NEW DENSITY TITLE")
update_labels(p, list(colour="MY NEW LEGEND TITLE")

这也将允许您更改x轴和y轴标签,使用单独的行:

update_labels(p, list(x="NEW X LABEL",y="NEW Y LABEL")