Próbuję wyrównać lewą i prawą krawędź 4 map kartogramowych ggplot, używając this method. Nie jestem jednak w stanie tego zrobić.Wyrównaj krawędzie goplotu ggplota (zmienia się tytuł legendy)
Oryginalna fabuła:
library(ggplot2); library(gridExtra)
crimes <- data.frame(state = tolower(rownames(USArrests)), USArrests)
states_map <- map_data("state")
plot1 <- ggplot(crimes, aes(map_id = state)) +
geom_map(aes(fill = Murder), map = states_map) +
expand_limits(x = states_map$long, y = states_map$lat) +
scale_fill_gradient(low="white", high="darkgreen", name="Really Long Name 1")
plot2 <- plot1 + scale_fill_gradient(name="Really Long Name 2 and then some")
plot3 <- plot1 + scale_fill_gradient(name="Short 3")
plot4 <- plot1 + scale_fill_gradient(name="Really Long Name 4")
grid.arrange(plot1, plot3, plot2, plot4, ncol = 2)
Próba wyrównać krawędzie wydruku (taki sam wynik):
p1 <- ggplotGrob(plot1)
p2 <- ggplotGrob(plot2)
p3 <- ggplotGrob(plot3)
p4 <- ggplotGrob(plot4)
maxWidth <- grid::unit.pmax(p1$widths[2:3], p2$widths[2:3], p3$widths[2:3], p4$widths[2:3])
p1$widths[2:3] <- as.list(maxWidth)
p2$widths[2:3] <- as.list(maxWidth)
p3$widths[2:3] <- as.list(maxWidth)
p4$widths[2:3] <- as.list(maxWidth)
grid.arrange(p1, p3, p2, p4, ncol = 2)
PS: Załóżmy, że trzeba użyć siatki zorganizować i legendy nie są w rzeczywistości tej samej skali, więc facet_grid
jest na zewnątrz itp
Jeśli jest to tylko tytuł legendy, że jest kwestia, czy uważa się za umieszczenie go poziomo w górnej lub dolnej ? To znaczy. 'plot1 + theme (legend.position = 'bottom', legend.direction = 'horizontal')' – MrGumble
zgodnie z sugestiami zamieszczonymi w komentarzach do opublikowanego linku, prawdopodobnie chciałbyś użyć 'widths [2: 5]' legenda w porównaniu jednostek. Zwróć uwagę, że spowoduje to wyśrodkowanie tej samej legendy, co w pierwszej odpowiedzi @ kohske, ponieważ grob prowadzący ustawia się w przydzielonej rzutni. – baptiste
Próbowałem "szerokości [2: 5]", co spowodowało bardzo dziwne miejsca docelowe. –