Пространство выше и ниже легенды, используя ggplot2

Если вы посмотрите на диаграммы здесь! вы можете видеть, что над легендой и над ней много белого пространства. Я хочу уменьшить объем пространства.

Пример кода:

library(ggplot2)
library(gridExtra)
library(reshape)
library(plyr)
library(scales)

theme_set(theme_bw())

rows <- 1:nrow(faithful)
data <- cbind(faithful, rows)
molten <- melt(data, id.vars='rows', measure.vars=c('eruptions', 'waiting'))

p <- ggplot() +
    geom_line(data=molten, 
        mapping=aes(x=rows, y=value, group=variable, colour=variable), size=0.8) +
    scale_colour_manual(values=c('red','blue')) +
    opts(title='Title') +
    xlab(NULL) + ylab('Meaningless Numbers') +
    opts(
        legend.position='bottom',
        legend.direction='horizontal',
        legend.title=theme_blank(),
        legend.key=theme_blank(),
        legend.text=theme_text(size=9),
        legend.margin = unit(0, "line"),
        legend.key.height=unit(0.6,"line"),      
        legend.background = theme_rect(colour='white', size=0)
    )

ggsave(p, width=8, height=4, filename='crap.png', dpi=125)

Ответ 1

Чтобы удалить поля легенды (отрицательные значения еще больше уменьшают пробел):

p + theme(legend.margin=margin(t=0, r=0, b=0, l=0, unit="cm"))
p + theme(legend.margin=margin(t=0, r=0, b=-0.5, l=0, unit="cm"))

Вы также можете удалить нижнюю часть поля графика, указав отрицательные числа (но убедитесь, что вы не отрезаете свою легенду):

p + theme(plot.margin = unit(x = c(0, 0, -0.2, 0), units = "cm")

Иллюстрации: ggplot2, легенда сверху и по размеру

Ответ 2

Вот два дополнительных параметра, которые позволяют сжимать пространство вокруг легенды:

p + opts(
      legend.key.height=unit(0, "cm"),      
      plot.margin = unit(c(1,0.5,0,0.5), "lines")
    )

Опция plot.margin описывает, сколько места вокруг сюжета. Третий аргумент описывает объем пространства ниже сюжета. Установка этого значения в ноль помогает.

enter image description here