在ggplot中自定义图例

3

我需要帮助使用ggplot2自定义图表。以下是我使用的代码和结果图表:

> p=ggplot(a2,aes(x=grid,y=median))+geom_line(size=1.3)+
    geom_line(aes(x=grid,y=lower,linetype=2,colour='red'),size=1.3)+
    geom_line(aes(x=grid,y=upper,linetype=2,colour='red'),size=1.3)+
    geom_line(aes(x=trueX,y=trueY,linetype=1,colour='blue'),size=.8)+
    geom_line(aes(x=grid,y=xDens,linetype=1),size=.5)+
    geom_point(data=a1,aes(x=X,y=Y),size=1)

输入图像描述

首先,红色和蓝色看起来与应有的颜色不同。其次,我想自定义图例,包括四个条目:

  1. 适合度(黑线)
  2. 置信区间(红色虚线)
  3. 真实曲线(蓝线)
  4. X密度(小黑线)

我已经尝试了一段时间,但无法解决问题。希望得到建议。

我可能需要重新排列我的数据以获得我想要的结果,这是我现在拥有的预览(忽略带点的数据集a1):

> head(a2[,c(1,2,4,5,6,7,8)])
     lower    upper   median      grid   trueX     trueY    xDens
1 26.65933 28.83431 27.54782 -4.845770 -3.998449 27.73697 0.02803692
2 26.65933 28.77224 27.54284 -4.826273 -3.967264 27.71877 0.02902979
3 26.65933 28.77224 27.54284 -4.806776 -3.910030 27.68470 0.02953585
4 26.65933 28.77224 27.54284 -4.787279 -3.898646 27.67782 0.03056721
5 26.65933 28.77224 27.54284 -4.767782 -3.891712 27.67361 0.03162419
6 26.65933 28.77224 27.54284 -4.748285 -3.890767 27.67304 0.03270666
1个回答

4
可能这就是您想要的内容:
示例数据:
> d
     lower    upper   median      grid     trueX    trueY      xDens
1 26.65933 28.83431 27.54782 -4.845770 -3.998449 27.73697 0.02803692
2 26.65933 28.77224 27.54284 -4.826273 -3.967264 27.71877 0.02902979
3 26.65933 28.77224 27.54284 -4.806776 -3.910030 27.68470 0.02953585
4 26.65933 28.77224 27.54284 -4.787279 -3.898646 27.67782 0.03056721
5 26.65933 28.77224 27.54284 -4.767782 -3.891712 27.67361 0.03162419
6 26.65933 28.77224 27.54284 -4.748285 -3.890767 27.67304 0.03270666

代码:

d2 <- melt(subset(d, select = -c(trueX)), id = "grid")
ggplot(d2, aes(grid, value, colour = variable, linetype = variable, size = variable)) +
  geom_line() +
  scale_colour_manual("", values = c("red", "red", "black", "blue", "black"), breaks = levels(d2$variable)) +
  scale_linetype_manual("", values = c(2, 2, 1, 1, 1), breaks = levels(d2$variable)) +
  scale_size_manual("", values = c(0.5, 0.5, 0.5, 0.5, 0.25), breaks = levels(d2$variable))

输出:

在此输入图片描述


谢谢,这个方法很有效。但是当我尝试从新的数据集中添加点(最后一行)时,出现了一个错误信息。如果plt是原始图形(就像你展示的那样),我运行:plt+geom_point(data=a1,aes(x=X,y=Y)),会出现以下错误:在eval(expr, envir, enclos)中出错:找不到对象'variable'。 - Glen

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接