Удалить заливку вокруг ключа легенды в ggplot

Hallo Я хотел бы удалить серый прямоугольник вокруг легенды. Я пробовал различные методы, но никто не работал.

ggtheme <- 
theme(
axis.text.x = element_text(colour='black'),
axis.text.y = element_text(colour='black'),
panel.background = element_blank(),
panel.grid.minor = element_blank(),
panel.grid.major = element_blank(),
panel.border = element_rect(colour='black', fill=NA),
strip.background = element_blank(),
legend.justification = c(0, 1),
legend.position = c(0, 1),
legend.background = element_rect(colour = NA),
legend.key = element_rect(colour = "white", fill = NA),
legend.title = element_blank()
)

colors <- c("red", "blue")
df <- data.frame(year = c(1:10), value = c(10:19), gender = rep(c("male","female"),each=5))
ggplot(df, aes(x = year, y = value)) + geom_point(aes(colour=gender))  +
stat_smooth(method = "loess", formula = y ~ x, level=0, size = 1, aes(group = gender, colour=gender)) +
ggtheme + scale_color_manual(values = colors) 

Ответ 1

Вы получаете этот серый цвет внутри ключей легенды, потому что вы используете stat_smooth(), который по умолчанию также делает доверительный интервал вокруг строки с некоторым заполнением (серый, если fill= не используется внутри aes()).

Одним из решений является установка se=FALSE для stat_smooth(), если вам не нужны доверительные интервалы.

  +stat_smooth(method = "loess", formula = y ~ x, level=0, size = 1, 
              aes(group = gender, colour=gender),se=FALSE) 

Другое решение - использовать функции guides() и override.aes=, чтобы удалить заливку из легенды, но сохраняйте доверительные интервалы вокруг строк.

  + guides(color=guide_legend(override.aes=list(fill=NA)))

Ответ 2

theme_set(theme_gray() + theme(legend.key=element_blank())) 

Если вы хотите также удалить серый фон:

theme_set(theme_bw() + theme(legend.key=element_blank())) 

Ответ 3

+ theme(legend.background=element_blank())