Czasami łatwiej jest zmodyfikować Grob korzystając grid
„s funkcje edycji - jeśli można znaleźć nazwy odpowiednich grobs . W takim przypadku można je znaleźć, a edycja jest prosta - zmień kolor etykiety z czarnego na czerwony lub niebieski.
library(ggplot2)
library(grid)
df <- data.frame(a=rnorm(10),b=1:10,c=letters[1:10],d=c("one","two"))
p1 <-ggplot(data=df,aes(x=b,y=a))
p1 <- p1 + geom_text(aes(label = c, color=d, fontface="bold"))
p1 <- p1 + scale_color_hue(name="colors should match",breaks=c("one", "two"),
labels=c("should be salmon", "should be sky blue"))
p1
# Get the ggplot grob
g <- ggplotGrob(p1)
# Check out the grobs
grid.ls(grid.force(g))
Przejrzyj listę grobs. Groby, które chcemy edytować, znajdują się na samym dole listy, w zestawie "gr-guide", z nazwami zaczynającymi się od "label". Istnieją dwa grobs:
Etykieta 3-3.4-4-4-4
etykieta-4-3.5-4-5-4
# Get names of 'label' grobs.
names.grobs <- grid.ls(grid.force(g))$name
labels <- names.grobs[which(grepl("label", names.grobs))]
# Get the colours
# The colours are the same as the colours of the plotted points.
# These are available in the ggplot build data.
gt <- ggplot_build(p1)
colours <- unique(gt$data[[1]][, "colour"])
# Edit the 'label' grobs - change their colours
# Use the `editGrob` function
for(i in seq_along(labels)) {
g <- editGrob(grid.force(g), gPath(labels[i]), grep = TRUE,
gp = gpar(col = colours[i]))
}
# Draw it
grid.newpage()
grid.draw(g)
Co czy wymagano, aby klucze były punktami, a nie literami? Może to być przydatne, ponieważ "a" jest symbolem na wykresie i jest symbolem w kluczu legendy. To nie jest zwykła edycja, jak wyżej. Potrzebuję grobu punktowego, który zastąpi tekstowy grob.Rysuję groby w rzutniach, ale jeśli uda mi się znaleźć nazwy odpowiednich rzutni, zmiana powinna być prosta.
# Find the names of the relevant viewports
current.vpTree() # Scroll out to the right to find he relevant 'key' viewports.
wziernika [klucz 4-1-1.5-2-5-2] wziernika [klucz 3-1-1.4-2-4-2]
# Well, this is convenient. The names of the viewports are the same
# as the names of the grobs (see above).
# Easy enough to get the names from the 'names.grobs' list (see above).
# Get the names of 'key' viewports(/grobs)
keys <- names.grobs[which(grepl("key-[0-9]-1-1", names.grobs))]
# Insert points grobs into the viewports:
# Push to the viewport;
# Insert the point grob;
# Pop the viewport.
for(i in seq_along(keys)) {
downViewport(keys[i])
grid.points(x = .5, y = .5, pch = 16, gp = gpar(col = colours[i]))
popViewport()
}
popViewport(0)
# I'm not going to worry about removing the text grobs.
# The point grobs are large enough to hide them.
plot = grid.grab()
grid.newpage()
grid.draw(plot)
Aktualizacja
Uwzględniając @ „s user20650 radę zmienić lege nd key (patrz komentarz poniżej):
p1 <-ggplot(data=df,aes(x=b,y=a))
p1 <- p1 + geom_text(aes(label = c, color=d, fontface="bold"))
p1 <- p1 + scale_color_hue(name="colors should match",breaks=c("one", "two"),
labels=c("should be salmon", "should be sky blue"))
GeomText$draw_key <- function (data, params, size) {
pointsGrob(0.5, 0.5, pch = 16,
gp = gpar(col = alpha(data$colour, data$alpha),
fontsize = data$size * .pt)) }
p1
Następnie postępuj jak poprzednio, aby zmienić kolor tekstu legendy.
+1 za wykonanie ciężkiej pracy, chociaż PO powinien ocenić, czy naprawdę jest tego wart. – BrodieG
BrodieG - jako OP zgadzam się z Tobą, ale starałem się odpowiedzieć na prośbę recenzentów w rękopisie, ponieważ istnieje więcej niż 2 poziomy czynników i kolor tekstu może wprowadzać w błąd. Może jest lepszy sposób na spisek. Zapoznam się z tym. –