R/sp_create_envelope.R

Defines functions sp_create_envelope

Documented in sp_create_envelope

#' Function to create a rectangular polygon envelope, usually used for filtering. 
#' 
#' @param envelope A vector with the length of 4 containing the extent of the 
#' envelope to be used as a bounding box. The order is: xmin, xmax, ymin, ymax.
#' Watch out when using latitude and longitude, the order is longitude, 
#' longitude, then latitude, latitude.
#' 
#' @param projection A proj4 string. Default is the WGS84 string. 
#' 
#' @author Stuart K. Grange
#' 
#' @return Spatial polygon. 
#' 
#' @export
sp_create_envelope <- function(envelope, projection = projection_wgs84()) {
  
  # Could this use raster::extent? 
  
  # Create matrix from vector; the order matters
  matrix <- matrix(
    c(
      envelope[1], 
      envelope[3], 
      envelope[1], 
      envelope[4], 
      envelope[2], 
      envelope[4], 
      envelope[2], 
      envelope[3]
    ), 
    ncol = 2, 
    byrow = TRUE
  )
  
  # Promote matrix to spatial data
  polygon <- Polygon(matrix)
  polygon <- Polygons(list(polygon), ID = "1")
  
  # Spatial class with projection
  polygon <- SpatialPolygons(list(polygon))
  
  # Give projection
  if (!is.na(projection)) {
    polygon <- sp_transform(polygon, projection, warn = FALSE)
  }
  
  # Return
  return(polygon)
  
}
skgrange/gissr documentation built on Feb. 24, 2024, 2:55 p.m.