Google Geo Map with R googleChartName <- "geomap"gvisChartName <- "gvisGeoMap"
Google Geo Map with R googleChartName <- "geomap"
gvisChartName <- "gvisGeoMap"
The gvisGeoMap function reads a data.frame and creates text output referring to the Google Visualisation API, which can be included into a web page, or as a stand-alone page.
A geo map is a map of a country, continent, or region map, with colours and values assigned to specific regions. Values are displayed as a colour scale, and you can specify optional hover-text for regions. The map is rendered in the browser. Note that the map is not scroll-able or drag-gable, but can be configured to allow zooming.
data: data.frame. The data has to have at least two columns with location name (locationvar), value to be mapped to location (numvar) and an optional variable to display any text while the mouse hovers over the location (hovervar).
locationvar: column name of data with the geo locations to be analysed. The locations can be provide in two formats:
Format 1: 'latitude:longitude'. See the example below.
Format 2: Address, country name, region name locations, or US metropolitan area codes, see https://developers.google.com/adwords/api/docs/appendix/geotargeting?csw=1. This format works with the dataMode option set to either 'markers' or 'regions'. The following formats are accepted: A specific address (for example, "1600 Pennsylvania Ave"). A country name as a string (for example, "England"), or an uppercase ISO-3166 code or its English text equivalent (for example, "GB" or "United Kingdom"). An uppercase ISO-3166-2 region code name or its English text equivalent (for example, "US-NJ" or "New Jersey").
numvar: column name of data with the numeric value displayed when the user hovers over this region.
hovervar: column name of data with the additional string text displayed when the user hovers over this region.
options: list of configuration options. The options are documented in detail by Google online:
## Please note that by default the googleVis plot command## will open a browser window and requires Internet## connection to display the visualisation.## Regions Example## The regions style fills entire regions (typically countries) with colors## corresponding to the values that you assign. Specify the regions style## by assigning options['dataMode'] = 'regions' in your code.G1 <- gvisGeoMap(Exports, locationvar='Country', numvar='Profit', options=list(dataMode="regions"))plot(G1)## Markers Example## The "markers" style displays a circle, sized and colored to indicate## a value, over the regions that you specify. G2 <- gvisGeoMap(CityPopularity, locationvar='City', numvar='Popularity', options=list(region='US', height=350, dataMode='markers', colors='[0xFF8747, 0xFFB581, 0xc06000]'))plot(G2)## Example showing US data by state require(datasets)states <- data.frame(state.name, state.x77)G3 <- gvisGeoMap(states,"state.name","Illiteracy", options=list(region="US", dataMode="regions", width=600, height=400))plot(G3)## Example with latitude and longitude information## Show Hurricane Andrew (1992) storm trackG4 <- gvisGeoMap(Andrew, locationvar="LatLong", numvar="Speed_kt", hovervar="Category", options=list(height=350, region="US", dataMode="markers"))plot(G4)## World populationWorldPopulation=data.frame(Country=Population$Country, Population.in.millions=round(Population$Population/1e6,0), Rank=paste(Population$Country,"Rank:", Population$Rank))G5 <- gvisGeoMap(WorldPopulation,"Country","Population.in.millions","Rank", options=list(dataMode="regions", width=600, height=300))plot(G5)
References
Google Chart Tools API: gsub("CHARTNAME", googleChartName, readLines(file.path(".", "inst","mansections", "GoogleChartToolsURL.txt")))