2013-07-04 14 views
10

Sto tentando di allineare i bordi sinistro e destro di 4 mappe di choropleth ggplot utilizzando this method. Non sono in grado di farlo comunque.Allinea i bordi di ggplot choropleth (il titolo della legenda varia)

trama originale:

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) 

tentativo di allineare i bordi trama (stesso risultato):

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) 

enter image description here

PS: assumere Ho bisogno di utilizzare griglia di organizzare e le leggende non sono in realtà la stessa scala quindi facet_grid è fuori ecc

+1

Se è solo il titolo della legenda che è il problema, avete considerato posizionandolo orizzontalmente nella parte superiore o inferiore ? Cioè 'plot1 + theme (legend.position = 'bottom', legend.direction = 'horizontal')' – MrGumble

+0

come suggerito nei commenti per il link che hai postato, probabilmente volevi usare 'widths [2: 5]' per includere la leggenda nel confronto delle unità. Si noti che il risultato sarà lo stesso centraggio della legenda come nella prima risposta di @kohske, perché il grido della guida si centra nella finestra assegnata. – baptiste

+0

Ho provato "widths [2: 5]" e ho ottenuto posizionamenti molto strani. –

risposta

9

Ecco un esempio:

library(gtable) 
grid.draw(cbind(rbind(p1, p2, size="last"), rbind(p3, p4, size="last"), size = "first")) 

enter image description here


Aggiornato

Questa è una cattiva trucco quindi non consiglio di utilizzare. Probabilmente questo non funzionerà in futuro.

gt <- cbind(rbind(p1, p2, size="last"), rbind(p3, p4, size="last"), size = "first") 
for (i in which(gt$layout$name == "guide-box")) { 
    gt$grobs[[i]] <- gt$grobs[[i]]$grobs[[1]] 
} 
grid.draw(gt) 

enter image description here

+2

+1 Buona soluzione. Mi chiedo se sia possibile allineare le legende, in modo che aumenti solo lo spazio a destra dei grafici. –

+2

@SvenHohenstein vedere aggiornato ma non consiglierei di usare. – kohske

+0

Da dove proviene 'gt'? –

1

utilizza cowplot pacchetto:

library(cowplot) 
plot_grid(plot1, plot3, plot2, plot4, ncol = 2, align = "v") 

enter image description here

Problemi correlati