2011-09-26 9 views

risposta

3

A simmetrica colore-mapping intorno allo zero è difficile codificato in map.market:

legend.ncols <- 51 
l.x <- (0:(legend.ncols - 1))/(legend.ncols) 
l.y <- unit(0.25, "npc") 
l.cols <- color.ramp.rgb(seq(-1, 1, by = 2/(legend.ncols - 
    1))) 
if (is.null(scale)) { 
    l.end <- max(abs(data$color.orig)) 
} 
else { 
    l.end <- scale 
} 

e,

top.list <- gList(textGrob(label = main, y = unit(0.7, "npc"), 
    just = c("center", "center"), gp = gpar(cex = 2)), segmentsGrob(x0 = seq(0, 
    1, by = 0.25), y0 = unit(0.25, "npc"), x1 = seq(0, 1, 
    by = 0.25), y1 = unit(0.2, "npc")), rectGrob(x = l.x, 
    y = l.y, width = 1/legend.ncols, height = unit(1, "lines"), 
    just = c("left", "bottom"), gp = gpar(col = NA, fill = l.cols), 
    default.units = "npc"), textGrob(label = format(l.end * 
    seq(-1, 1, by = 0.5), trim = TRUE), x = seq(0, 1, by = 0.25), 
    y = 0.1, default.units = "npc", just = c("center", "center"), 
    gp = gpar(col = "black", cex = 0.8, fontface = "bold"))) 

nota la presenza di seq(-1,1,...) dichiarazioni. Il parametro scale ha effetto solo sulla dimensione assoluta.

+1

Giusto per chiarire per chi, come me, non ha capito cosa fare con il suggerimento di cui sopra: digitare "map.market" nella console R, copiare l'output e riscrivere il posto 'seq (-1, 1' con quello che ti serve, quindi incolla questa funzione nel tuo codice ed eseguila, invece di 'map.market()' originale. Puoi anche modificare altri parametri. –

Problemi correlati