ggmap stamen map accuracy glitch - r

ggmap appears to be handling map tiles from Google and stamen inconsistently, at least at global scale. Stamen is the problem. The following code illustrates.
require(ggplot2); require(ggmap)
m_google = get_map(location = c(-.2, 51.5), zoom=3)
m_stamen = get_map(location = c(-.2, 51.5), zoom=3, source = "stamen", maptype = "toner")
ggmap(m_google, extent = 'panel') + geom_point(data=NULL, aes(-.2, 51.5), col='red', size=5)
ggmap(m_stamen, extent = 'panel') + geom_point(data=NULL, aes(-.2, 51.5), col='red', size=5)
Glitch?

Related

Why does the scalebar created with ggmap ggsn in R show inaccurate distance?

I am trying to create a simple map with a scale bar using ggmap and the developer version ofggsn. The map seems to load well, but the scale bar measurements seem off. It shouldn't be over 4,000 km from coast to coast in the US. Below is my current code.
##installing packages.. not all are needed
library(tidyverse)
library(ggplot2)
library(sf)
library(ggspatial)
library(devtools)
library(ggmap)
library(maptools)
library(maps)
library(magick)
library(VTrack)
library(cowplot)
library(gridExtra)
## register a google api key
ggmap::register_google(key = "")
##creating the base map
inset <- get_googlemap(center = c(lon = -90, lat = 50), zoom = 3, maptype = "satellite",color = 'bw')
##below just makes the map a little lighter
insetx <- inset
inset_attributes <- attributes(insetx)
inset_transparent <- matrix(adjustcolor(insetx,
alpha.f = 0.9),
nrow = nrow(inset))
attributes(inset_transparent) <- inset_attributes
##installing dev version of ggsn
devtools::install_github('oswaldosantos/ggsn')
##combining the map with the scale bar. Note that scale bar appears to be off.
ggmap(inset_transparent)+
ggsn::scalebar(x.min = -180, x.max = -100,
y.min = 10, y.max = 85,
dist = 2000, transform = TRUE, dist_unit = 'km', model = 'WGS84',
box.fill = c('black', 'black'), st.color = 'white', box.color = 'white')

How can I include a reference table or legend for a geom_point geographical map?

I am generating a map very similar to this
(source: dominodatalab.com)
] to visualize the frequency in which cities occur. How can I create a legend or key for this map so I can see what the size of the circles represent numerically?
Here is my code:
myLocation <- c(-124, 32, -66, 42)
myMap <- get_map(location = myLocation, source = "stamen",
maptype = "toner", crop = FALSE, zoom = 4)
ggmap(myMap) +
geom_point(aes(x = lon, y = lat), data = csr.Ax1,
col = "orange", alpha = 0.4, size = csr.Ax1$freq*.25) +
scale_size_continuous(range = range(csr.Ax1$freq), guide = "legend") +
ggtitle("CSR Active Candidates") +
legend()
EDIT: SOLVED!
The solution was placing the size=csr.Ax1$freq from the geom_point argument into the aes() argument.
The solution was placing the size=csr.Ax1$freq from the geom_point argument into the aes() argument.

Acquiring black and white stamen maps with get_map

I am trying to get the black and white version of a stamen map and its giving me the color version. I've tried downloading the map with get_map and get_stamenmap and both give me the color version regardless of whether I specify color as "bw" or "color". Any ideas or work arounds?
library(ggmap)
mapImage <- get_map(location = c(lon = -110.8, lat = 34.7),
source = "stamen",
maptype = "terrain",
color = "bw",
zoom = 7)
g <- ggmap(mapImage)
To get black-and-white stamen maps, use maptype = "toner". The color argument has no effect on stamen maps. You might also want a panel border around the plot. If so, use ggplot's theme_bw() or theme(panel.border = element_rect(fill = NA, colour = "black")).
library(ggmap)
mapImage <- get_map(location = c(lon = -110.8, lat = 34.7),
source = "stamen",
maptype = "toner",
# color = "bw",
zoom = 7)
ggmap(mapImage) + theme_bw()
My solution was get_stamenmap with maptype="toner".
It is like get_map with source="stamen" speaks with a southern soft R and sloppy lisp dialect that stamen does not understand.
library(ggmap)
mapImage <- get_stamenmap(bbox = c(-114,32,-107,37),
source = "stamen",
maptype = "toner",
zoom = 7)
ggmap(mapImage) +theme_bw()
did the trick for me (using Rstudio in Linux, potential bug)
Notice bbox as the alternative to location and theme_bw() as Sandy suggested

How to display partial borders in R using ggmap

I am creating maps using ggmap and am having trouble displaying some polygons and borders in my code. I have a map of a city that has parts of 3 counties in it. I would like to display the city along with the appropriate county lines. If I set the zoom such that all 3 counties are completely visible, then the county lines appear in the map. However, if I zoom to the portion of the city, the county lines disappear.
Example 1: County lines visible on map
tempplot <- get_map(location = c(lon = -97.37605, lat = 32.94748), zoom=9, maptype = 'roadmap')
myplot <- ggmap(tempplot) + borders ("county", colour = "red", alpha = 0.5, region = "Texas")
myplot <- myplot + geom_point(aes(x = -97.37605, y = 32.94748), color = "dodgerblue4", pch = 20, size = 9)
myplot
Image: http://imgur.com/nx3XU2I
Example 2: County lines partially visible on map
tempplot <- get_map(location = c(lon = -97.37605, lat = 32.94748), zoom=10, maptype = 'roadmap')
myplot <- ggmap(tempplot) + borders ("county", colour = "red", alpha = 0.5, region = "Texas")
myplot <- myplot + geom_point(aes(x = -97.37605, y = 32.94748), color = "dodgerblue4", pch = 20, size = 9)
myplot
Example 3: No county lines visible on map
tempplot <- get_map(location = c(lon = -97.37605, lat = 32.94748), zoom=12, maptype = 'roadmap')
myplot <- ggmap(tempplot) + borders ("county", colour = "red", alpha = 0.5, region = "Texas")
myplot <- myplot + geom_point(aes(x = -97.37605, y = 32.94748), color = "dodgerblue4", pch = 20, size = 9)
myplot
Image: http://imgur.com/dIpp6kp
The only difference between these 3 examples is the zoom on the map. I need the map to be at zoom 12 to see the additional details that I will be adding (individual homes), but when I zoom in, the county lines vanish. Any suggestions?
(Sorry about the links to the images ... I am new to the forum and don't have a 10 reputation yet!)
It appears that also the borders you get in example 1 are not 100% correct. You may check with a lower Zoom lever (eg 5).
To me it looks like there is a problem with borders that are cut off by the picture; the function then tries to connect it to an edge that is still visible. In the zoom level you provided even that is not possible, and therefore it has unexpected behaviour.
To sum up: I don't know what exactly the problem is, but maybe this short analysis helps in any way!

Omit some borders in ggplot/ggmap

I'm very new to R and I was just playing around with a project to plot projected population growth of Alabama counties from 2010 to 2020. Here's my code:
dat <- read.table("C:/Users/rasmus/Documents/countyinfo.txt", sep="\t", header=TRUE)
library(ggplot2)
library(maps)
library(ggmap)
mdat <- map_data('county')
str(mdat)
al1 = get_map(location = c(lon = -86.304474, lat = 32.362563),
zoom = 7, maptype = 'roadmap')
al1MAP = ggmap(al1) +
geom_point(data=dat,inherit.aes = FALSE,
aes(y=Lat, x=Lon, map_id=County, size=Growth), col="red") +
borders("state", colour="red", alpha=0.8) +
borders("county", colour="blue", alpha=0.5)
al1MAP
Now, I have two questions.
1) The state borders seem to be doing weird things. Here's a screenshot with the county overlay turned off:
2) Given that this is only about Alabama, I would like to turn borders outside the state borders off, but I don't know how to do that. My guess would be to experiment with xlim and ylim, but I don't know how to restrict those to the Alabama border polygon.
It seems that with function borders() for coordinates of some states are connected together.
To solve this problem you can store state borders as separate data frame using map_data() and then add state borders using geom_path() to your map. In geom_path() add group=region to ensure that points are connected only according one region.
To show borders just for the Alabama counties you should add argument region="alabama" to function borders().
al1 = get_map(location = c(lon = -86.304474, lat = 32.362563),
zoom = 6, maptype = 'roadmap')
mdat <- map_data('state')
ggmap(al1) +
geom_path(data=mdat,aes(x=long,y=lat,group=region),colour="red",alpha=0.8)+
borders("county", colour="blue", alpha=0.5,region="alabama")

Resources