Chciałbym zmienić nazwy wartości w legendzie bez zmiany kolorów niestandardowych, które zostały już ustawione. Czy istnieje sposób ustawiania etykiet legendy bez użycia scale_color_manual? Obecnie mam coś takiego:Zmienianie nazw legendy bez zmieniania kolorów w ggplot2
norm <- rnorm(1000, 0 , .5)
gam <- rgamma(1000, 2)
beta <- rbeta(1000, 2, 3)
dist <- data.frame(Normal = norm, Gamma = gam, Beta= beta)
dat <- melt(dist, variable.name = "Distribution", value.name = "XValue")
plot1 <- ggplot(dat, aes(XValue, color = Distribution)) +
stat_density(geom = "path", position = "identity", size = 2) +
scale_color_manual(values = c("yellow", "black", "forestgreen"))
plot2 <- plot1 + scale_color_discrete(labels = c("Distribution 1",
"Distribution 2",
"Distribution 3"))
To jednak nadpisuje kolory ręczne. Będę zmieniać nazwy w innej funkcji niż ustawienia kolorów, więc niestety nie będę mógł używać scale_color_manual (values = ..., labels = ...). Inną opcją, o której pomyślałem, jest jakoś uzyskać kolory użyte w spisku1. Mógłbym wtedy zrobić coś takiego:
colors <- plot1$colors_used
plot2 <- plot1 + scale_color_manual(labels = c("Distribution 1",
"Distribution 2",
"Distribution 3"),
values = colors)
Każda pomoc byłaby mile widziana. Dzięki!
PO zrezygnował z tego, co, IMHO, jest prawdziwym problemem. Namalowali się w rogu z innym kodem. Prawdziwym rozwiązaniem jest zatem, aby OP korygował ich kod tak, aby to rozwiązanie działało. – joran
Dzięki chłopaki, niestety, wolę nie refactor. Zmiana nazw etykiet nastąpi w oddzielnej funkcji. Ta funkcja będzie przyjmować wiele różnych wątków, które wszystkie mają unikalne kolory. Wykresy (wraz z kolorami) będą tworzone w wielu różnych funkcjach. Chciałbym móc zastosować tę funkcję, aby określić nowe nazwy, a następnie zmienić nazwę. Jakieś inne sugestie? Dzięki! – Taylor