2011-09-26 12 views

Respuesta

3

A simétrica de color-mapping en torno a cero es difícil codificado en 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 
} 

y,

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"))) 

Obsérvese la presencia de seq(-1,1,...) declaraciones. El parámetro scale solo afecta el tamaño absoluto.

+1

Solo para aclarar para aquellos que, como yo, no entendieron qué hacer con la sugerencia anterior: escriba "map.market" en la consola R, copie el resultado y vuelva a escribir el lugar 'seq (-1, 1' con lo que necesita. Luego simplemente pegue esta función en su código y ejecútelo, en lugar de 'map.market()' original. También se pueden cambiar otros parámetros. –

Cuestiones relacionadas