2014-05-08 22 views
5

Ho uno SpatialPolygonsDataFrame che ho grafico usando il seguente comando:tramando SpatialPointsDataFrame nel corso di uno SpatialPolygonsDataFrame

spplot(milanoNILNew, "percPolVita",at = c(0,0.0696,0.08979,0.0974,0.1116,0.181),col.regions =pal,main="Quota Clienti Unipol con Polizze Vita ") 

Ho creato una spatialPointsDataFrame con il seguente comando

agenziePoints<-SpatialPointsDataFrame(coords=datiAgenzie[,c("Long","Lat")],data=datiAgenzie,proj4string = llCRS, match.ID = TRUE). 

sono in grado di tracciare il poligoni ma non sono in grado di rappresentare i punti di occupazione sui poligoni sullo stesso grafico. Grazie in anticipo per il supporto.

risposta

5

Basta usare la funzione di grafico di base con l'argomento add = TRUE.

require(sp) 

# Create polygons 
sr=SpatialPolygons(list(
    Polygons(list(Polygon(cbind(c(180114,180553,181127,181477,181294,181007,180409, 
    180162,180114),c(332349, 332057, 332342, 333250, 333558, 333676, 332618, 332413, 332349)))),"1"), 
    Polygons(list(Polygon(cbind(c(180042,180545,180553,180314,179955,179142,179437,179524,179979,180042), 
    c(332373,332026,331426,330889,330683,331133,331623,332152,332357,332373)))),"2"))) 
srdf=SpatialPolygonsDataFrame(sr, data.frame(cbind(1:2,1:2), row.names=c("1","2"))) 

# Add points (sp meuse dataset) 
data(meuse) 
coordinates(meuse) = ~x+y 

# Create a color vector for the meuse points 
color <- rep("xx", nrow([email protected])) 
    color[([email protected]$copper > 0)&([email protected]$copper <= 31)] <- "black" 
    color[([email protected]$copper > 31)] <- "red" 

# Plot polygons with points overlaid  
plot(srdf, col=c("grey","blue")) 
    plot(meuse, col=color, pch=19, add=TRUE) 

Se davvero si vuole utilizzare la funzione spplot si potrebbe implementa qualcosa di simile:

# spplot approach 
pts=list("sp.points", meuse, pch=19, col=color) 
    spplot(srdf, "X1", col.regions=c("grey","blue"), colorkey=FALSE, 
     sp.layout=list(pts))