I've been looking forever on how to use shapefiles originating from North Carolina for making maps. Normally, I'll get crazy latitude and longitude coordinates if I plot the shapefiles using the default parameters through R's rgdal package.
Tonight, I stumbled upon this StackOverflow post, which shows that TWO functions are needed in order to fully utilize NC shapefiles: readOGR and spTransform.
I've always just used readOGR, which works fine for shapefile originating from other places, like the US Census bureau. I've always had problems with files from my state, however, until I came across the aforementioned StackOverflow post.
Here's what I put into R to make a simple map of all roads in Wake County:
roads <- readOGR("c:\\data\\poly\\wake_streets\\streets.shp","streets", p4s = CRS("+proj=lcc +lat_1=34.33333333333334 +lat_2=36.16666666666666 +lat_0=33.75 +lon_0=-79 +x_0=609601.2199999997 +y_0=0 +ellps=GRS80 +towgs84=0,0,0,0,0,0,0 +units=us-ft +no_defs"))
roadmap <- spTransform(roads, CRS("+proj=longlat +datum=WGS84"))
plot(roadmap,axes=T)
title("Roads in Wake County, North Carolina")
This'll produce a map like so:
If you want to try this at home, you can get a bunch of shapefiles from North Carolina's State Board of Elections FTP site that seem to work with this code.
Now that this mystery has finally been uncovered, my mapping options are much improved!
No comments:
Post a Comment