2013-03-09 13 views
5

Sto cercando di produrre una mappa del mondo usando ggplot2 in R. Voglio mostrare il PIL pro capite degli Stati brasiliani. Ci sono 2 problemi:Formatta la mappa ggplot2

  1. Nel centro del paese sono due etichette non facili da leggere le informazioni. Si stanno sovrapponendo. Riducendo i numeri non risolti.

  2. Vorrei modificare le interruzioni di colore e non so come accedervi. Vorrei usare i colori per rendermi facilmente conto delle differenze di PIL.

I miei dati sono: https://docs.google.com/file/d/0B_coFit6AovfcEFkbHBjZEJaQ1E/edit

Ecco il mio codice:

library(maptools) 
gpclibPermit() 
library(ggplot2) 
library(rgdal) 
library(rgeos) 
library(ggmap) 


# read administrative boundaries (change folder appropriately) 
brMap <- readShapePoly("BRASIL.shp") 
brMap 

# read downloaded data (change folder appropriately) 
brRen <- read.csv("Renda.csv", sep = ";", quote = "\"", dec=".", stringsAsFactors = FALSE) 
brRen$rendapc <- as.numeric(as.character(brRen$rendapc)) # format as numeric 

#convert shp to UTF8 
library(descr) 
brMap$ESTADO<-toUTF8(brMap$ESTADO, "IBM850") 

# convert shp data to data frame for ggplot 
as.data.frame(brMap) # para definir a region 
brMap = gBuffer(brMap, width=0, byid=TRUE) #correct problem with Polygons - TopologyException 
brMapDf <- fortify(brMap, region="UF") 
brMapDf 


# merge map and data 
brRenMapDf <- merge(brMapDf, brRen, by.x="id", by.y="Iden") 
brRenMapDf <- brRenMapDf[order(brRenMapDf$order),] 

# limit data to main Europe 
brazil.limits <- geocode(c("Monte Caburaí", "Barra do Chuí", "Serra do Divisor", "Ilhas Martin Vaz")) 
brRenMapDf <- subset(brRenMapDf, long > min(brazil.limits$lon) & long < max(brazil.limits$lon) & lat > min(brazil.limits$lat) & lat < max(brazil.limits$lat)) 

# ggplot mapping 
# data layer 
m0 <- ggplot(data=brRenMapDf) 
# empty map (only borders) 
m1 <- m0 + geom_path(aes(x=long, y=lat, group=group), color='gray') + coord_equal() 
m1 

# fill with education expenditure data 
m2 <- m1 + geom_polygon(aes(x=long, y=lat, group=group, fill=rendapc)) 
m2 


# inverse order (to have visible borders) 
m0 <- ggplot(data=brRenMapDf) 
m1 <- m0 + geom_polygon(aes(x=long, y=lat, group=group, fill=rendapc)) + coord_equal() 
m2 <- m1 + geom_path(aes(x=long, y=lat, group=group), color='black') 
m2 


# over a GoogleMap (not working if not correctly projected) 
map <- get_map(location = 'Brazil', zoom=4) 
m0 <- ggmap(map) 
m1 <- m0 + geom_polygon(aes(x=long, y=lat, group=group, fill=rendapc), data=brRenMapDf, alpha=.9) 
m2 <- m1 + geom_path(aes(x=long, y=lat, group=group), data=brRenMapDf, color='black') 
m2 


# add text 
library(doBy) 
txtVal <- summaryBy(long + lat + rendapc ~ id, data=brRenMapDf, FUN=mean, keep.names=T) 
m3 <- m2 + geom_text(aes(x=long, y=lat, label=rendapc), data=txtVal, col="yellow", hjust=0.5, vjust=0.5, cex=3) 
m3 

Il mio risultato Voglio migliorare:

enter image description here

+0

Whay su SVG grafica per le etichette? Ci sono fuori uso? –

risposta

5

Per quanto riguarda la modifica della colorscale, ggplot2 ha un modo uniforme di gestire s cales. La funzione che stai cercando ha sempre il formato scale_{which_scale}_{scale_type}, dove which_scale è un'estetica (quello che usi in aes(), ad esempio fill o size) e scale_type può essere continuo o discreto, ecc. Che cosa stai cercando se vuoi modificare la scala fill è scale_fill_continuous, scale_fill_gradient o scale_fill_gradient2. Dai un'occhiata alla documentazione di quelle funzioni.

Un esempio di codice:

m2 <- m1 + geom_polygon(aes(x=long, y=lat, group=group, fill=rendapc)) 
m2 + scale_fill_gradient(low = "blue", high = "red") 
+0

Grazie mille per avermi aiutato! – user2152340