ggplot图例 - 更改标签,订单和标题

时间:2012-08-22 14:10:45

标签: r ggplot2

我正在努力修改我的情节中的传奇。这是一个可重复的例子:

dtt <- structure(list(model = structure(c(1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L, 3L, 3L, 3L, 3L, 3L, 3L), .Label = c("ma", "mb", "mc"), class = "factor"), year = c(2005L, 2006L, 2007L, 2008L, 2009L, 2010L, 2005L, 2006L, 2007L, 2008L, 2009L, 2010L, 2005L, 2006L, 2007L, 2008L, 2009L, 2010L), V = c(0.16, 0.14, 0.11, 0.13, 0.15, 0.16, 0.24, 0.17, 0.12, 0.13, 0.15, 0.15, 0.2, 0.16, 0.11, 0.12, 0.12, 0.15), lower = c(0.11, 0.11, 0.07, 0.09, 0.11, 0.12, 0.16, 0.12, 0.04, 0.09, 0.09, 0.11, 0.14, 0.1, 0.07, 0.08, 0.05, 0.1), upper = c(0.21, 0.19, 0.17, 0.17, 0.19, 0.2, 0.29, 0.23, 0.16, 0.17, 0.16, 0.2, 0.26, 0.27, 0.15, 0.16, 0.15, 0.19)), .Names = c("model", "year", "V", "lower", "upper"), class = "data.frame", row.names = c(NA, -18L))

我的情节是这样生成的:

ggplot(dtt, aes(x=year, y=V, group = model, colour = model, ymin = lower, ymax = upper)) +
    geom_ribbon(alpha = 0.35, linetype=0)+ 
    geom_line(aes(linetype=model), size = 1.5) +       
    geom_point(aes(shape=model), fill = "white", size = 4)  +      
    theme(legend.position=c(.6,0.8)) +
    theme(legend.background = element_rect(colour = 'black', fill = 'grey90', size = 1, linetype='solid'))

产生这个: enter image description here

现在,我想做的是

  1. 更改图例的标题
  2. 更改图例项目的显示顺序
  3. 更改图例项目的文本。
  4. 我已经摆弄了几个小时试图做到这一点,但没有太大的成功。我到目前为止所做的最好的是添加这个:

    scale_colour_hue(name = "Model 1",
        breaks=c("mb", "ma", "mc"),
        labels=c("MBB", "MAA", "MCC"))
    

    但它产生了这种可憎的行为: enter image description here

    如您所见,现在有一个额外不需要的图例,图例中的形状与图中的形状不匹配!

    最后,我想在图例中的图形表示蓝色和绿色线条是虚线,而不是固体 - 但我根本不知道如何做到这一点。

    任何帮助都将受到高度赞赏,

1 个答案:

答案 0 :(得分:62)

你需要做两件事:

  1. 在图
  2. 之前重命名并重新排序因子级别
  3. 将每个图例的标题重命名为相同的标题
  4. 代码:

    dtt$model <- factor(dtt$model, levels=c("mb", "ma", "mc"), labels=c("MBB", "MAA", "MCC"))
    
    library(ggplot2)
    ggplot(dtt, aes(x=year, y=V, group = model, colour = model, ymin = lower, ymax = upper)) +
      geom_ribbon(alpha = 0.35, linetype=0)+ 
      geom_line(aes(linetype=model), size = 1) +       
      geom_point(aes(shape=model), size=4)  +      
      theme(legend.position=c(.6,0.8)) +
      theme(legend.background = element_rect(colour = 'black', fill = 'grey90', size = 1, linetype='solid')) +
      scale_linetype_discrete("Model 1") +
      scale_shape_discrete("Model 1") +
      scale_colour_discrete("Model 1")
    

    enter image description here

    但是,我觉得这很丑陋,也很难解释。使用方面要好得多:

    ggplot(dtt, aes(x=year, y=V, group = model, colour = model, ymin = lower, ymax = upper)) +
      geom_ribbon(alpha=0.2, colour=NA)+ 
      geom_line() +       
      geom_point()  +      
      facet_wrap(~model)
    

    enter image description here