Title: | Spatial Data Framework for ggplot2 |
---|---|
Description: | Spatial data plus the power of the ggplot2 framework means easier mapping when input data are already in the form of spatial objects. |
Authors: | Dewey Dunnington [aut, cre] , Brent Thorne [ctb] , Diego Hernangómez [ctb] |
Maintainer: | Dewey Dunnington <[email protected]> |
License: | GPL-3 |
Version: | 1.1.9.9000 |
Built: | 2025-01-05 03:32:44 UTC |
Source: | https://github.com/paleolimbot/ggspatial |
Uses rosm::osm.image()
to add background tiles. If you are publishing
a map using these tiles, make sure to use the proper attribution
(e.g., "Copyright OpenStreetMap contributors" when using an
OpenStreetMap-based tile set).
annotation_map_tile( type = "osm", zoom = NULL, zoomin = -2, forcedownload = FALSE, cachedir = NULL, progress = c("text", "none"), quiet = TRUE, interpolate = TRUE, data = NULL, mapping = NULL, alpha = 1 ) GeomMapTile
annotation_map_tile( type = "osm", zoom = NULL, zoomin = -2, forcedownload = FALSE, cachedir = NULL, progress = c("text", "none"), quiet = TRUE, interpolate = TRUE, data = NULL, mapping = NULL, alpha = 1 ) GeomMapTile
type |
The map type (one of that returned by rosm::osm.types) |
zoom |
The zoom level (overrides zoomin) |
zoomin |
Delta on default zoom. The default value is designed
to download fewer tiles than you probably want. Use |
forcedownload |
Re-download cached tiles? |
cachedir |
Specify cache directory |
progress |
Use |
quiet |
Use |
interpolate |
Passed to |
data , mapping
|
Specify data and mapping to use this geom with facets |
alpha |
Use to make this layer semi-transparent |
An object of class GeomMapTile
(inherits from Geom
, ggproto
, gg
) of length 5.
A ggplot2 layer
library(ggplot2) load_longlake_data(which = "longlake_waterdf") ggplot() + annotation_map_tile(zoom = 13, cachedir = system.file("rosm.cache", package = "ggspatial")) + geom_sf(data = longlake_waterdf, fill = NA, col = "grey50")
library(ggplot2) load_longlake_data(which = "longlake_waterdf") ggplot() + annotation_map_tile(zoom = 13, cachedir = system.file("rosm.cache", package = "ggspatial")) + geom_sf(data = longlake_waterdf, fill = NA, col = "grey50")
Spatial-aware north arrow
annotation_north_arrow( mapping = NULL, data = NULL, ..., height = unit(1.5, "cm"), width = unit(1.5, "cm"), pad_x = unit(0.25, "cm"), pad_y = unit(0.25, "cm"), rotation = NULL, style = north_arrow_orienteering ) GeomNorthArrow
annotation_north_arrow( mapping = NULL, data = NULL, ..., height = unit(1.5, "cm"), width = unit(1.5, "cm"), pad_x = unit(0.25, "cm"), pad_y = unit(0.25, "cm"), rotation = NULL, style = north_arrow_orienteering ) GeomNorthArrow
mapping , data , ...
|
See Aesthetics |
height , width
|
Height and width of north arrow |
pad_x , pad_y
|
Padding between north arrow and edge of frame |
rotation |
Override the rotation of the north arrow (degrees conterclockwise) |
style |
A grob or callable that produces a grob that will be drawn as the north arrow. See north_arrow_orienteering for options. |
An object of class GeomNorthArrow
(inherits from Geom
, ggproto
, gg
) of length 5.
A ggplot2 layer
The following can be used as parameters or aesthetics. Using them as
aesthetics is useful when facets are used to display multiple panels,
and a different (or missing) scale bar is required in different panels.
Otherwise, just pass them as arguments to annotation_north_arrow()
.
which_north: "grid" results in a north arrow always pointing up; "true" always points to the north pole from whichever corner of the map the north arrow is in.
location: Where to put the scale bar ("tl" for top left, etc.)
cities <- data.frame( x = c(-63.58595, 116.41214), y = c(44.64862, 40.19063), city = c("Halifax", "Beijing") ) ggplot(cities) + geom_spatial_point(aes(x, y), crs = 4326) + annotation_north_arrow(which_north = "true") + coord_sf(crs = 3995) ggplot(cities) + geom_spatial_point(aes(x, y), crs = 4326) + annotation_north_arrow(which_north = "grid") + coord_sf(crs = 3995)
cities <- data.frame( x = c(-63.58595, 116.41214), y = c(44.64862, 40.19063), city = c("Halifax", "Beijing") ) ggplot(cities) + geom_spatial_point(aes(x, y), crs = 4326) + annotation_north_arrow(which_north = "true") + coord_sf(crs = 3995) ggplot(cities) + geom_spatial_point(aes(x, y), crs = 4326) + annotation_north_arrow(which_north = "grid") + coord_sf(crs = 3995)
Spatial-aware scalebar annotation
annotation_scale( mapping = NULL, data = NULL, ..., plot_unit = NULL, bar_cols = c("black", "white"), line_width = 1, height = unit(0.25, "cm"), pad_x = unit(0.25, "cm"), pad_y = unit(0.25, "cm"), text_pad = unit(0.15, "cm"), text_cex = 0.7, text_face = NULL, text_family = "", tick_height = 0.6 ) GeomScaleBar
annotation_scale( mapping = NULL, data = NULL, ..., plot_unit = NULL, bar_cols = c("black", "white"), line_width = 1, height = unit(0.25, "cm"), pad_x = unit(0.25, "cm"), pad_y = unit(0.25, "cm"), text_pad = unit(0.15, "cm"), text_cex = 0.7, text_face = NULL, text_family = "", tick_height = 0.6 ) GeomScaleBar
mapping , data , ...
|
See Aesthetics |
plot_unit |
For non-coord_sf applications, specify the unit for x and y coordinates. Must be one of km, m, cm, mi, ft, or in. |
bar_cols |
Colours to use for the bars |
line_width |
Line width for scale bar |
height |
Height of scale bar |
pad_x , pad_y
|
Distance between scale bar and edge of panel |
text_pad , text_cex , text_face , text_family
|
Parameters for label |
tick_height |
Height of ticks relative to height of scale bar |
An object of class GeomScaleBar
(inherits from Geom
, ggproto
, gg
) of length 5.
A ggplot2 layer.
The following can be used as parameters or aesthetics. Using them as
aesthetics is useful when facets are used to display multiple panels,
and a different (or missing) scale bar is required in different panels.
Otherwise, just pass them as arguments to annotation_scale
.
width_hint: The (suggested) proportion of the plot area which the scalebar should occupy.
unit_category: Use "metric" or "imperial" units.
style: One of "bar" or "ticks"
location: Where to put the scale bar ("tl" for top left, etc.)
line_col and text_col: Line and text colour, respectively
cities <- data.frame( x = c(-63.58595, 116.41214), y = c(44.64862, 40.19063), city = c("Halifax", "Beijing") ) ggplot(cities) + geom_spatial_point(aes(x, y), crs = 4326) + annotation_scale() + coord_sf(crs = 3995)
cities <- data.frame( x = c(-63.58595, 116.41214), y = c(44.64862, 40.19063), city = c("Halifax", "Beijing") ) ggplot(cities) + geom_spatial_point(aes(x, y), crs = 4326) + annotation_scale() + coord_sf(crs = 3995)
Projected horizontal and vertical lines
annotation_spatial_hline( mapping = NULL, data = NULL, stat = "identity", ..., intercept = waiver(), limits = NULL, detail = 100, crs = NULL, na.rm = FALSE, show.legend = NA ) annotation_spatial_vline( mapping = NULL, data = NULL, stat = "identity", ..., intercept = waiver(), limits = NULL, detail = 100, crs = NULL, na.rm = FALSE, show.legend = NA ) GeomSpatialXline
annotation_spatial_hline( mapping = NULL, data = NULL, stat = "identity", ..., intercept = waiver(), limits = NULL, detail = 100, crs = NULL, na.rm = FALSE, show.legend = NA ) annotation_spatial_vline( mapping = NULL, data = NULL, stat = "identity", ..., intercept = waiver(), limits = NULL, detail = 100, crs = NULL, na.rm = FALSE, show.legend = NA ) GeomSpatialXline
mapping |
An aesthetic mapping created with |
data |
A data frame or other object, coerced to a data.frame by |
stat |
Statistical transformation to use on this layer. See |
... |
Passed to the combined stat/geom as parameters or fixed aesthetics. |
intercept |
The x or y value that should be constant in the given
|
limits |
Use |
detail |
The number of points that should be used when converting the line into segments. |
crs |
The crs of the x and y aesthetics, or NULL to use default lon/lat crs (with a message). |
na.rm |
Should missing aesthetic values be removed? |
show.legend |
Should the legend be shown? |
An object of class GeomSpatialXline
(inherits from GeomHline
, Geom
, ggproto
, gg
) of length 4.
cities <- data.frame( x = c(-63.58595, 116.41214, 0), y = c(44.64862, 40.19063, 89.9), city = c("Halifax", "Beijing", "North Pole") ) p <- ggplot(cities, aes(x, y, label = city)) + geom_spatial_point(crs = 4326) + # view of the north pole coord_sf(crs = 3995) p + # longitude lines annotation_spatial_vline( intercept = seq(-180, 180, by = 10), crs = 4326 ) + # latitude lines annotation_spatial_hline( intercept = seq(0, 90, by = 10), crs = 4326 )
cities <- data.frame( x = c(-63.58595, 116.41214, 0), y = c(44.64862, 40.19063, 89.9), city = c("Halifax", "Beijing", "North Pole") ) p <- ggplot(cities, aes(x, y, label = city)) + geom_spatial_point(crs = 4326) + # view of the north pole coord_sf(crs = 3995) p + # longitude lines annotation_spatial_vline( intercept = seq(-180, 180, by = 10), crs = 4326 ) + # latitude lines annotation_spatial_hline( intercept = seq(0, 90, by = 10), crs = 4326 )
Create a ggplot-friendly data frame from a spatial object
df_spatial(x, ...)
df_spatial(x, ...)
x |
A spatial object |
... |
Passed to specific methods |
A tibble with coordinates as x
and y
,
features as feature_id
, and parts as part_id
.
load_longlake_data(which = c("longlake_osm", "longlake_depthdf")) df_spatial(longlake_osm) df_spatial(longlake_depthdf) df_spatial(as(longlake_depthdf, "Spatial"))
load_longlake_data(which = c("longlake_osm", "longlake_depthdf")) df_spatial(longlake_osm) df_spatial(longlake_depthdf) df_spatial(as(longlake_depthdf, "Spatial"))
When using a fixed-aspect coordinate system, fixed_plot_aspect()
expands
either the width or height of the plot to ensure that the output
has dimensions that make sense. This is a useful workaround for
getting reasonable-shaped plots when using ggplot2::coord_sf()
or ggplot2::coord_fixed()
when the data happen to be
aligned vertically or horizontally.
fixed_plot_aspect(ratio = 1)
fixed_plot_aspect(ratio = 1)
ratio |
The desired aspect ratio (width / height) |
A ggplot2::layer()
that can be added to a ggplot2::ggplot()
.
library(ggplot2) df <- data.frame(x = 0:5, y = seq(0, 10, length.out = 6)) ggplot(df, aes(x, y)) + geom_point() + fixed_plot_aspect(ratio = 1) + coord_fixed()
library(ggplot2) df <- data.frame(x = 0:5, y = seq(0, 10, length.out = 6)) ggplot(df, aes(x, y)) + geom_point() + fixed_plot_aspect(ratio = 1) + coord_fixed()
This geometry used to plot polygons with holes in ggplot2 at the more correctly than geom_polygon; however, in recent R and ggplot2 versions this is no longer needed.
geom_polypath( mapping = NULL, data = NULL, stat = "identity", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, rule = "winding", ... )
geom_polypath( mapping = NULL, data = NULL, stat = "identity", position = "identity", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE, rule = "winding", ... )
mapping |
An aesthetic mapping, created with aes. The aesthetic
will mostly likely need to contain a |
data |
A data.frame containing the coordinates to plot. |
stat |
A statistic to apply (most likely "identity") |
position |
A position to apply (most likely "identity") |
na.rm |
Should missing coordinate be removed? |
show.legend |
Should a legend be shown for mapped aesthetics? |
inherit.aes |
Should aesthetics be inherited? |
rule |
A fill rule to apply. One of "winding" or "evenodd". |
... |
Passed to the geom and/or stat. |
A ggplot2 layer
library(ggplot2) load_longlake_data(which = "longlake_waterdf") ggplot(df_spatial(longlake_waterdf), aes(x, y, group = piece_id)) + geom_polypath()
library(ggplot2) load_longlake_data(which = "longlake_waterdf") ggplot(df_spatial(longlake_waterdf), aes(x, y, group = piece_id)) + geom_polypath()
If you need to plot a sf::st_bbox()
, use layer_spatial()
instead.
While the implementation is slightly differrent, these functions are
intended to behave identically to ggplot2::geom_rect()
and
ggplot2::geom_tile()
.
geom_spatial_rect( mapping = NULL, data = NULL, ..., crs = NULL, detail = 30, linejoin = "mitre", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) geom_spatial_tile( mapping = NULL, data = NULL, ..., crs = NULL, detail = 30, linejoin = "mitre", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) StatSpatialRect StatSpatialTile
geom_spatial_rect( mapping = NULL, data = NULL, ..., crs = NULL, detail = 30, linejoin = "mitre", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) geom_spatial_tile( mapping = NULL, data = NULL, ..., crs = NULL, detail = 30, linejoin = "mitre", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) StatSpatialRect StatSpatialTile
mapping |
An aesthetic mapping created with |
data |
A data frame or other object, coerced to a data.frame by |
... |
Passed to the combined stat/geom as parameters or fixed aesthetics. |
crs |
The crs of the x and y aesthetics, or NULL to use default lon/lat crs (with a message). |
detail |
Passed to |
linejoin |
How corners should be joined |
na.rm |
Should missing aesthetic values be removed? |
show.legend , inherit.aes
|
See |
An object of class StatSpatialRect
(inherits from Stat
, ggproto
, gg
) of length 4.
An object of class StatSpatialTile
(inherits from StatSpatialRect
, Stat
, ggproto
, gg
) of length 4.
library(ggplot2) tile_df <- expand.grid( x = seq(-140, -52, by = 20), y = seq(40, 70, by = 10) ) ggplot(tile_df, aes(x, y)) + geom_spatial_tile(crs = 4326) + coord_sf(crs = 3979) # the same plot using geom_spatial_rect() ggplot( tile_df, aes(xmin = x - 10, xmax = x + 10, ymin = y - 5, ymax = y + 5) ) + geom_spatial_rect(crs = 4326) + coord_sf(crs = 3979)
library(ggplot2) tile_df <- expand.grid( x = seq(-140, -52, by = 20), y = seq(40, 70, by = 10) ) ggplot(tile_df, aes(x, y)) + geom_spatial_tile(crs = 4326) + coord_sf(crs = 3979) # the same plot using geom_spatial_rect() ggplot( tile_df, aes(xmin = x - 10, xmax = x + 10, ymin = y - 5, ymax = y + 5) ) + geom_spatial_rect(crs = 4326) + coord_sf(crs = 3979)
While the implementation is slightly differrent, this function is
intended to behave identically to ggplot2::geom_segment()
. Use
great_circle = FALSE
and detail = NULL
if you wish ignore the fact
that the earth is round.
geom_spatial_segment( mapping = NULL, data = NULL, ..., crs = NULL, detail = waiver(), great_circle = TRUE, wrap_dateline = TRUE, arrow = NULL, lineend = "butt", linejoin = "round", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) StatSpatialSegment
geom_spatial_segment( mapping = NULL, data = NULL, ..., crs = NULL, detail = waiver(), great_circle = TRUE, wrap_dateline = TRUE, arrow = NULL, lineend = "butt", linejoin = "round", na.rm = FALSE, show.legend = NA, inherit.aes = TRUE ) StatSpatialSegment
mapping |
An aesthetic mapping created with |
data |
A data frame or other object, coerced to a data.frame by |
... |
Passed to the combined stat/geom as parameters or fixed aesthetics. |
crs |
The crs of the x and y aesthetics, or NULL to use default lon/lat crs (with a message). |
detail |
Passed to |
great_circle |
If |
wrap_dateline |
When using |
arrow |
An arrow specification as a call to |
lineend |
|
linejoin |
How corners should be joined |
na.rm |
Should missing aesthetic values be removed? |
show.legend , inherit.aes
|
See |
An object of class StatSpatialSegment
(inherits from StatSpatialRect
, Stat
, ggproto
, gg
) of length 3.
library(ggplot2) # visualize flights from # Halifax -> Anchorage -> Berlin -> Halifax cities <- data.frame( lon = c(-63.58595, 116.41214, 13.50, -149.75), lat = c(44.64862, 40.19063, 52.51, 61.20), city = c("Halifax", "Beijing", "Berlin", "Anchorage"), city_to = c("Anchorage", "Beijing", "Berlin", "Halifax") ) cities$lon_end <- cities$lon[c(4, 3, 1, 2)] cities$lat_end <- cities$lat[c(4, 3, 1, 2)] p <- ggplot(cities, aes(lon, lat, xend = lon_end, yend = lat_end)) + geom_spatial_point(crs = 4326) # by default, geom_spatial_segment() connects points # using the shortest distance along the face of the earth # wrapping at the date line p + geom_spatial_segment(crs = 4326) + coord_sf(crs = 3857) # to let the projection handle the dateline, # use `wrap_dateline = FALSE` (most useful for # when using `arrow`) p + geom_spatial_segment( wrap_dateline = FALSE, arrow = grid::arrow(), crs = 4326 ) + coord_sf(crs = 3995) # to ignore the roundness of the earth, use # `great_circle = FALSE` p + geom_spatial_segment( great_circle = FALSE, arrow = grid::arrow(), crs = 4326 ) + coord_sf(crs = 3995)
library(ggplot2) # visualize flights from # Halifax -> Anchorage -> Berlin -> Halifax cities <- data.frame( lon = c(-63.58595, 116.41214, 13.50, -149.75), lat = c(44.64862, 40.19063, 52.51, 61.20), city = c("Halifax", "Beijing", "Berlin", "Anchorage"), city_to = c("Anchorage", "Beijing", "Berlin", "Halifax") ) cities$lon_end <- cities$lon[c(4, 3, 1, 2)] cities$lat_end <- cities$lat[c(4, 3, 1, 2)] p <- ggplot(cities, aes(lon, lat, xend = lon_end, yend = lat_end)) + geom_spatial_point(crs = 4326) # by default, geom_spatial_segment() connects points # using the shortest distance along the face of the earth # wrapping at the date line p + geom_spatial_segment(crs = 4326) + coord_sf(crs = 3857) # to let the projection handle the dateline, # use `wrap_dateline = FALSE` (most useful for # when using `arrow`) p + geom_spatial_segment( wrap_dateline = FALSE, arrow = grid::arrow(), crs = 4326 ) + coord_sf(crs = 3995) # to ignore the roundness of the earth, use # `great_circle = FALSE` p + geom_spatial_segment( great_circle = FALSE, arrow = grid::arrow(), crs = 4326 ) + coord_sf(crs = 3995)
See also layer_spatial.Raster()
, layer_spatial.stars()
,
layer_spatial.SpatRaster()
and layer_spatial.bbox()
for implementations
for other types of spatial objects.
layer_spatial(data, mapping, ...) annotation_spatial(data, mapping, ...) ## Default S3 method: layer_spatial( data, mapping = aes(), inherit.aes = FALSE, sf_params = list(), ... ) ## Default S3 method: annotation_spatial( data, mapping = aes(), inherit.aes = FALSE, sf_params = list(), ... ) shadow_spatial(data, ...) ## Default S3 method: shadow_spatial(data, ...)
layer_spatial(data, mapping, ...) annotation_spatial(data, mapping, ...) ## Default S3 method: layer_spatial( data, mapping = aes(), inherit.aes = FALSE, sf_params = list(), ... ) ## Default S3 method: annotation_spatial( data, mapping = aes(), inherit.aes = FALSE, sf_params = list(), ... ) shadow_spatial(data, ...) ## Default S3 method: shadow_spatial(data, ...)
data |
An object that can be coerced to an sf object using st_as_sf. |
mapping |
A mapping, created using aes. |
... |
Passed to geom_sf |
inherit.aes |
Inherit aesthetics from ggplot()? |
sf_params |
Passed to st_as_sf. |
A ggplot2 layer.
library(ggplot2) load_longlake_data( which = c( "longlake_roadsdf", "longlake_depthdf", "longlake_depth_raster" ), raster_format = "terra" ) ggplot() + # annotation_spatial() layers don't train the scales, so data stays central annotation_spatial(longlake_roadsdf, size = 2, col = "black") + annotation_spatial(longlake_roadsdf, size = 1.6, col = "white") + # raster layers train scales and get projected automatically layer_spatial(longlake_depth_raster, aes(alpha = after_stat(band1)), fill = "darkblue") + scale_alpha_continuous(na.value = 0) + # layer_spatial() layers train the scales layer_spatial(longlake_depthdf, aes(col = DEPTH_M)) + # spatial-aware automagic scale bar annotation_scale(location = "tl") + # spatial-aware automagic north arrow annotation_north_arrow(location = "br", which_north = "true")
library(ggplot2) load_longlake_data( which = c( "longlake_roadsdf", "longlake_depthdf", "longlake_depth_raster" ), raster_format = "terra" ) ggplot() + # annotation_spatial() layers don't train the scales, so data stays central annotation_spatial(longlake_roadsdf, size = 2, col = "black") + annotation_spatial(longlake_roadsdf, size = 1.6, col = "white") + # raster layers train scales and get projected automatically layer_spatial(longlake_depth_raster, aes(alpha = after_stat(band1)), fill = "darkblue") + scale_alpha_continuous(na.value = 0) + # layer_spatial() layers train the scales layer_spatial(longlake_depthdf, aes(col = DEPTH_M)) + # spatial-aware automagic scale bar annotation_scale(location = "tl") + # spatial-aware automagic north arrow annotation_north_arrow(location = "br", which_north = "true")
To include a bounding box without drawing it, use shadow_spatial()
on the
original object.
## S3 method for class 'bbox' layer_spatial(data, mapping = aes(), ..., detail = 30) ## S3 method for class 'bbox' annotation_spatial(data, mapping = aes(), ..., detail = 30) ## S3 method for class 'bbox' shadow_spatial(data, ..., detail = 30)
## S3 method for class 'bbox' layer_spatial(data, mapping = aes(), ..., detail = 30) ## S3 method for class 'bbox' annotation_spatial(data, mapping = aes(), ..., detail = 30) ## S3 method for class 'bbox' shadow_spatial(data, ..., detail = 30)
data |
A bounding box generated by |
mapping |
A mapping, created using aes. |
... |
Passed to geom_sf |
detail |
Passed to |
library(ggplot2) load_longlake_data(which = c("longlake_waterdf", "longlake_depthdf")) ggplot() + layer_spatial(sf::st_bbox(longlake_waterdf)) + layer_spatial(longlake_depthdf) # use shadow_spatial() to include the geographic area of an object # without drawing it ggplot() + shadow_spatial(longlake_waterdf) + layer_spatial(longlake_depthdf)
library(ggplot2) load_longlake_data(which = c("longlake_waterdf", "longlake_depthdf")) ggplot() + layer_spatial(sf::st_bbox(longlake_waterdf)) + layer_spatial(longlake_depthdf) # use shadow_spatial() to include the geographic area of an object # without drawing it ggplot() + shadow_spatial(longlake_waterdf) + layer_spatial(longlake_depthdf)
This is intended for use with RGB(A) rasters (e.g., georeferenced imagery or photos). To work with bands as if they were columns, use df_spatial and geom_raster.
## S3 method for class 'Raster' layer_spatial( data, mapping = NULL, interpolate = NULL, is_annotation = FALSE, lazy = FALSE, dpi = 150, ... ) ## S3 method for class 'Raster' annotation_spatial(data, mapping = NULL, interpolate = NULL, ...) StatSpatialRaster StatSpatialRasterAnnotation StatSpatialRasterDf GeomSpatialRaster
## S3 method for class 'Raster' layer_spatial( data, mapping = NULL, interpolate = NULL, is_annotation = FALSE, lazy = FALSE, dpi = 150, ... ) ## S3 method for class 'Raster' annotation_spatial(data, mapping = NULL, interpolate = NULL, ...) StatSpatialRaster StatSpatialRasterAnnotation StatSpatialRasterDf GeomSpatialRaster
data |
A Raster object |
mapping |
Currently, only RGB or RGBA rasters are supported. In the future, one may be able to map specific bands to the fill and alpha aesthetics. |
interpolate |
Interpolate resampling for rendered raster image |
is_annotation |
Lets raster exist without modifying scales |
lazy |
Delay projection and resample of raster until the plot is being rendered |
dpi |
if lazy = TRUE, the dpi to which the raster should be resampled |
... |
Passed to other methods |
An object of class StatSpatialRaster
(inherits from Stat
, ggproto
, gg
) of length 3.
An object of class StatSpatialRaster
(inherits from StatSpatialRaster
, Stat
, ggproto
, gg
) of length 3.
An object of class StatSpatialRasterDf
(inherits from Stat
, ggproto
, gg
) of length 5.
An object of class GeomSpatialRaster
(inherits from Geom
, ggproto
, gg
) of length 5.
A ggplot2 layer
library(ggplot2) load_longlake_data(which = c("longlake_osm", "longlake_depth_raster")) ggplot() + layer_spatial(longlake_osm) ggplot() + layer_spatial(longlake_depth_raster) + scale_fill_continuous(na.value = NA)
library(ggplot2) load_longlake_data(which = c("longlake_osm", "longlake_depth_raster")) ggplot() + layer_spatial(longlake_osm) ggplot() + layer_spatial(longlake_depth_raster) + scale_fill_continuous(na.value = NA)
This is intended for use with RGB(A) rasters (e.g., georeferenced imagery or photos). To work with bands as if they were columns, use df_spatial and geom_raster.
## S3 method for class 'SpatRaster' layer_spatial( data, mapping = NULL, interpolate = NULL, is_annotation = FALSE, lazy = FALSE, dpi = 150, ... ) ## S3 method for class 'SpatRaster' annotation_spatial(data, mapping = NULL, interpolate = NULL, ...) StatSpatRaster StatSpatRasterAnnotation StatSpatRasterDf GeomSpatRaster
## S3 method for class 'SpatRaster' layer_spatial( data, mapping = NULL, interpolate = NULL, is_annotation = FALSE, lazy = FALSE, dpi = 150, ... ) ## S3 method for class 'SpatRaster' annotation_spatial(data, mapping = NULL, interpolate = NULL, ...) StatSpatRaster StatSpatRasterAnnotation StatSpatRasterDf GeomSpatRaster
data |
A SpatRaster object created with |
mapping |
Currently, only RGB or RGBA rasters are supported. In the future, one may be able to map specific bands to the fill and alpha aesthetics. |
interpolate |
Interpolate resampling for rendered raster image |
is_annotation |
Lets raster exist without modifying scales |
lazy |
Delay projection and resample of raster until the plot is being rendered |
dpi |
if lazy = TRUE, the dpi to which the raster should be resampled |
... |
Passed to other methods |
An object of class StatSpatialRaster
(inherits from Stat
, ggproto
, gg
) of length 3.
An object of class StatSpatRaster
(inherits from StatSpatialRaster
, Stat
, ggproto
, gg
) of length 3.
An object of class StatSpatRasterDf
(inherits from Stat
, ggproto
, gg
) of length 5.
An object of class GeomSpatRaster
(inherits from Geom
, ggproto
, gg
) of length 5.
A ggplot2 layer
library(ggplot2) load_longlake_data( which = c( "longlake_osm", "longlake_depth_raster" ), raster_format = "terra" ) ggplot() + layer_spatial(longlake_osm) ggplot() + layer_spatial(longlake_depth_raster) + scale_fill_continuous( na.value = NA, type = "viridis" )
library(ggplot2) load_longlake_data( which = c( "longlake_osm", "longlake_depth_raster" ), raster_format = "terra" ) ggplot() + layer_spatial(longlake_osm) ggplot() + layer_spatial(longlake_depth_raster) + scale_fill_continuous( na.value = NA, type = "viridis" )
This is intended for use with RGB(A) rasters (e.g., georeferenced imagery or photos). To work with bands as if they were columns, use df_spatial and geom_raster.
## S3 method for class 'stars' layer_spatial( data, mapping = NULL, interpolate = NULL, is_annotation = FALSE, lazy = FALSE, dpi = 150, options = character(0), ... ) ## S3 method for class 'stars' annotation_spatial(data, mapping = NULL, interpolate = NULL, ...) StatSpatialStars StatSpatialStarsAnnotation StatSpatialStarsDf GeomSpatialStars
## S3 method for class 'stars' layer_spatial( data, mapping = NULL, interpolate = NULL, is_annotation = FALSE, lazy = FALSE, dpi = 150, options = character(0), ... ) ## S3 method for class 'stars' annotation_spatial(data, mapping = NULL, interpolate = NULL, ...) StatSpatialStars StatSpatialStarsAnnotation StatSpatialStarsDf GeomSpatialStars
data |
A stars object |
mapping |
Currently, only RGB or RGBA rasters are supported. In the future, one may be able to map specific bands to the fill and alpha aesthetics. |
interpolate |
Interpolate resampling for rendered raster image |
is_annotation |
Lets raster exist without modifying scales |
lazy |
Delay projection and resample of raster until the plot is being rendered |
dpi |
if lazy = TRUE, the dpi to which the raster should be resampled |
options |
GDAL options for warping/resampling (see st_warp) |
... |
Passed to other methods |
An object of class StatSpatialStars
(inherits from Stat
, ggproto
, gg
) of length 3.
An object of class StatSpatialStars
(inherits from StatSpatialStars
, Stat
, ggproto
, gg
) of length 3.
An object of class StatSpatialStarsDf
(inherits from Stat
, ggproto
, gg
) of length 5.
An object of class GeomSpatialStars
(inherits from Geom
, ggproto
, gg
) of length 5.
A ggplot2 layer
library(ggplot2) load_longlake_data( which = c( "longlake_osm", "longlake_depth_raster" ), raster_format = "stars" ) ggplot() + layer_spatial(longlake_osm) ggplot() + layer_spatial(longlake_depth_raster) + scale_fill_continuous( na.value = NA, type = "viridis" )
library(ggplot2) load_longlake_data( which = c( "longlake_osm", "longlake_depth_raster" ), raster_format = "stars" ) ggplot() + layer_spatial(longlake_osm) ggplot() + layer_spatial(longlake_depth_raster) + scale_fill_continuous( na.value = NA, type = "viridis" )
Load longlake test data
load_longlake_data( env = parent.frame(), vector_format = c("sf", "sp"), raster_format = c("terra", "stars", "stars_proxy", "raster"), which = NULL )
load_longlake_data( env = parent.frame(), vector_format = c("sf", "sp"), raster_format = c("terra", "stars", "stars_proxy", "raster"), which = NULL )
env |
The environment in which to assign the objects |
vector_format , raster_format
|
The format in which objects should be loaded |
which |
An optional subset of objects to be loaded |
The Nova Scotia Topographic Database (https://geonova.novascotia.ca/) and Open Street Map (https://www.openstreetmap.org/).
load_longlake_data(which = "longlake_waterdf")
load_longlake_data(which = "longlake_waterdf")
North arrow styles
north_arrow_orienteering( line_width = 1, line_col = "black", fill = c("white", "black"), text_col = "black", text_family = "", text_face = NULL, text_size = 10, text_angle = 0 ) north_arrow_fancy_orienteering( line_width = 1, line_col = "black", fill = c("white", "black"), text_col = "black", text_family = "", text_face = NULL, text_size = 10, text_angle = 0 ) north_arrow_minimal( line_width = 1, line_col = "black", fill = "black", text_col = "black", text_family = "", text_face = NULL, text_size = 10 ) north_arrow_nautical( line_width = 1, line_col = "black", fill = c("black", "white"), text_size = 10, text_face = NULL, text_family = "", text_col = "black", text_angle = 0 )
north_arrow_orienteering( line_width = 1, line_col = "black", fill = c("white", "black"), text_col = "black", text_family = "", text_face = NULL, text_size = 10, text_angle = 0 ) north_arrow_fancy_orienteering( line_width = 1, line_col = "black", fill = c("white", "black"), text_col = "black", text_family = "", text_face = NULL, text_size = 10, text_angle = 0 ) north_arrow_minimal( line_width = 1, line_col = "black", fill = "black", text_col = "black", text_family = "", text_face = NULL, text_size = 10 ) north_arrow_nautical( line_width = 1, line_col = "black", fill = c("black", "white"), text_size = 10, text_face = NULL, text_family = "", text_col = "black", text_angle = 0 )
line_width , line_col , fill
|
Parameters customizing the appearance of the north arrow |
text_col , text_family , text_face , text_size , text_angle
|
Parameters customizing the text of the north arrow |
A Grob with npc coordinates (more or less) 0 to 1
grid::grid.newpage() grid::grid.draw(north_arrow_orienteering()) grid::grid.newpage() grid::grid.draw(north_arrow_fancy_orienteering()) grid::grid.newpage() grid::grid.draw(north_arrow_minimal()) grid::grid.newpage() grid::grid.draw(north_arrow_nautical())
grid::grid.newpage() grid::grid.draw(north_arrow_orienteering()) grid::grid.newpage() grid::grid.draw(north_arrow_fancy_orienteering()) grid::grid.newpage() grid::grid.draw(north_arrow_minimal()) grid::grid.newpage() grid::grid.draw(north_arrow_nautical())
These layers are much like their counterparts, stat_identity,
geom_point, geom_path,
and geom_polygon, except they have a crs
argument that
ensures they are projected when using coord_sf. Stats are applied to the x and y coordinates
that have been transformed.
stat_spatial_identity( mapping = NULL, data = NULL, crs = NULL, geom = "point", position = "identity", ..., show.legend = NA, inherit.aes = TRUE ) geom_spatial_point(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_path(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_polygon(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_text(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_label(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_text_repel(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_label_repel(mapping = NULL, data = NULL, crs = NULL, ...)
stat_spatial_identity( mapping = NULL, data = NULL, crs = NULL, geom = "point", position = "identity", ..., show.legend = NA, inherit.aes = TRUE ) geom_spatial_point(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_path(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_polygon(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_text(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_label(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_text_repel(mapping = NULL, data = NULL, crs = NULL, ...) geom_spatial_label_repel(mapping = NULL, data = NULL, crs = NULL, ...)
mapping |
An aesthetic mapping created with |
data |
A data frame or other object, coerced to a data.frame by |
crs |
The crs of the x and y aesthetics, or NULL to use default lon/lat crs (with a message). |
geom |
The geometry to use. |
position |
The position to use. |
... |
Passed to the combined stat/geom as parameters or fixed aesthetics. |
show.legend , inherit.aes
|
See |
cities <- data.frame( x = c(-63.58595, 116.41214, 0), y = c(44.64862, 40.19063, 89.9), city = c("Halifax", "Beijing", "North Pole") ) library(ggrepel) ggplot(cities, aes(x, y)) + geom_spatial_point(crs = 4326) + stat_spatial_identity(aes(label = city), geom = "label_repel") + coord_sf(crs = 3857)
cities <- data.frame( x = c(-63.58595, 116.41214, 0), y = c(44.64862, 40.19063, 89.9), city = c("Halifax", "Beijing", "North Pole") ) library(ggrepel) ggplot(cities, aes(x, y)) + geom_spatial_point(crs = 4326) + stat_spatial_identity(aes(label = city), geom = "label_repel") + coord_sf(crs = 3857)
Coordinate transform, propotating non-finite cases.
xy_transform(x, y, from = 4326, to = 4326, na.rm = FALSE)
xy_transform(x, y, from = 4326, to = 4326, na.rm = FALSE)
x |
The x coordinate |
y |
The y coordinate |
from |
From CRS |
to |
To CRS |
na.rm |
Warn for non-finite cases? |
A data.frame with x and y components.
xy_transform(c(1, 2, 3), c(1, 2, 3), to = 3857) xy_transform(c(1, 2, 3), c(NA, NA, NA), to = 3857) xy_transform(c(1, 2, 3), c(NA, 2, 3), to = 3857) xy_transform(c(1, 2, 3), c(1, 2, NA), to = 3857)
xy_transform(c(1, 2, 3), c(1, 2, 3), to = 3857) xy_transform(c(1, 2, 3), c(NA, NA, NA), to = 3857) xy_transform(c(1, 2, 3), c(NA, 2, 3), to = 3857) xy_transform(c(1, 2, 3), c(1, 2, NA), to = 3857)