如何将图例框与ggplot2中图例标题的中间对齐?

时间:2017-10-07 23:50:58

标签: r ggplot2 legend legend-properties

默认情况下,图例框/键与图例标题的左侧对齐。由于我有很长的传奇头衔,我想把它与中心对齐。我试过了themeguide_legend但没有成功。任何建议将不胜感激。谢谢!

  • 数据

    df <- structure(list(Flow = c(0.992762, 0.802408, 0.9826, 0.754863, 
            0.174542, 0.056777), Coef = c(0.62, 0.49, 0.38, 0.59, 0.25, 0.67
            ), VeryLongLegendTitle = c(4.47680710313542, 18.8500193246859, 
            5.82742564783431, 23.3217237977105, 13.0155332302148, 88.4960885143824
            )), class = "data.frame", row.names = c(NA, -6L), .Names = c("Flow", 
            "Coef", "VeryLongLegendTitle"))
    
  • 代码

    library(ggplot2)
    p1 <- ggplot(df, aes(x = Flow, y = Coef, color = VeryLongLegendTitle)) +
      xlab(NULL) + scale_x_continuous(limits = c(0.0, 1.0), breaks = c(0.25, 0.75)) +
      geom_point(size = 2, alpha = 0.8) + 
      theme_bw(base_size = 14) +
      theme(axis.text.x = element_text(angle = 0, vjust = 0.5))
    p1
    
    p1 + theme(legend.title.align = 0.5) 
    p1 + theme(legend.title = element_text(hjust = 0.5))
    p1 + guides(color = guide_legend(title.hjust = 0.5))
    
  • 剧情 enter image description here

2 个答案:

答案 0 :(得分:2)

我同意@www但您可以尝试p1 + guides(color = guide_legend(keywidth = 5, keyheight = 2))。它会产生这样的东西: enter image description here

查看Legend guide

也是一件好事

答案 1 :(得分:1)

借用此workaround

中的解决方案
library(ggplot2)
library(gtable)
library(grid)

long1 <- ggplot(df, aes(x = Flow, y = Coef, color = VeryLongLegendTitle)) +
  xlab(NULL) + scale_x_continuous(limits = c(0.0, 1.0), breaks = c(0.25, 0.75)) +
  geom_point(size = 2, alpha = 0.8) + 
  theme_bw(base_size = 14) +
  theme(axis.text.x = element_text(angle = 0, vjust = 0.5))

# extract legend
g <- ggplotGrob(long1)
grobs <- g$grobs
legend_index <- which(sapply(grobs, function(x) x$name) == "guide-box")
legend <- grobs[[legend_index]]

# extract guides table
guides_index <- which(sapply(legend$grobs, function(x) x$name) == "layout")
guides <- legend$grobs[[guides_index]]

# add extra column for spacing
# guides$width[5] is the extra spacing from the end of the legend text
# to the end of the legend title. If we instead distribute it 50:50 on
# both sides, we get a centered legend
guides <- gtable_add_cols(guides, 0.5*guides$width[5], 1)
guides$widths[6] <- guides$widths[2]
title_index <- guides$layout$name == "title"
guides$layout$l[title_index] <- 2

# reconstruct legend and write back
legend$grobs[[guides_index]] <- guides
g$grobs[[legend_index]] <- legend

grid.newpage()
grid.draw(g)

reprex package(v0.2.0)创建于2018-03-18。