tmap example: choropleth (World)
Source:vignettes/21_examples_choro_World.Rmd
21_examples_choro_World.Rmd
library(tmap)
library(dplyr)
#> Error in get(paste0(generic, ".", class), envir = get_method_env()) :
#> object 'type_sum.accel' not found
library(sf)
tmap_options(scale = 0.75)
About the data
A spatial data object contained in tmap is called World
. It is a data frame with a row for each country. The columns are the following data variables plus an additional geometry column which contains the geometries (see sf package):
names(World)
#> [1] "iso_a3" "name" "sovereignt" "continent" "area"
#> [6] "pop_est" "pop_est_dens" "economy" "income_grp" "gdp_cap_est"
#> [11] "life_exp" "well_being" "footprint" "HPI" "inequality"
#> [16] "gender" "press" "geometry"
We will create a choropleth of the Gender Inequality Index (GII) per country.
The choropleth: step 1
tm_shape(World) +
tm_polygons(fill = "gender")
#> [tip] Consider a suitable map projection, e.g. by adding `+ tm_crs("auto")`.
#> This message is displayed once per session.
The choropleth: step 2
A few improvements:
- A suitable map projection. This one ‘Equal Earth’ is equal-area, i.e. the polygon area sizes are proportianal to the real-world country area sizes.
- A different color scheme. Run
cols4all::c4a_gui()
to explore them. For this application, we were looking for: a diverging, color-blind friendly palette with sufficient contrast with black (to see the border lines) - A custom legend title
- The option
earth_boundary
is enabled, which shows the earth boundaries. Note that this feature is only available for certain map projections (for advanced users: families of pseudo-cylindrical and orthographic projections). - The legend box is placed on top of the map, on the left bottom.
tm_shape(World, crs = "+proj=eqearth") +
tm_polygons(
fill = "gender",
fill.scale = tm_scale_intervals(values = "-tableau.classic_orange_blue"),
fill.legend = tm_legend(
"Gender Inequality Index (GII)",
position = tm_pos_on_top(pos.h = "left", pos.v = "bottom"),
bg.color = "white")) +
tm_options(earth_boundary = TRUE, frame = FALSE)