我有一个折线图,我想重新排列因子在图例中出现的方式。我试过了scale_fill_discrete
,但它没有改变顺序。
这是我的问题的模拟:
df <- data.frame(var1=c("F", "F", "F", "B", "B", "B"),
var2=c("levelB", "levelC", "levelA"),
value=c("2.487585", "2.535944", "3.444764", "2.917308", "2.954155","3.739049"))
p <- ggplot(data=df, aes(x=var1, y=value,
group=var2, colour=var2, shape = var2)) +
geom_line(size = 0.8) +
geom_point()+
xlab("var1") + ylab("Value") +
scale_x_discrete(limits=c("F","B")) +
theme(legend.title = element_text(size=12)) +
theme(legend.text = element_text(size=10)) +
scale_fill_discrete(breaks=c("levelB","levelC","levelA")) +
theme(title = element_text(size=12)) +
blank + scale_color_manual(values=c("green2", "red", "black")) +
theme(legend.key = element_blank())
p
创造了这个:
除了图例之外,我希望所有内容保持完全相同,我想将订单更改为levelB
然后levelC
然后levelA
。
我猜ggplot2
按字母顺序排列图例,我想覆盖它。
重新排序我的数据框架不起作用,scale_fill_discrete
也不会更改它。
有任何想法吗?
谢谢!
答案 0 :(得分:6)
通过重新排序因子中的级别,您可以更改图例标签的顺序。运行:
df$var2 <- factor(df$var2, levels=c("levelB", "levelC", "levelA"))
然后重新运行ggplot代码,levelB现在应该位于图例的顶部,绿色,levelC第二和红色,levelA第三和黑色。