R/orient-filter.R

Defines functions wk_counterclockwise wk_clockwise wk_orient_filter wk_orient

Documented in wk_clockwise wk_counterclockwise wk_orient wk_orient_filter

#' Orient polygon coordinates
#'
#' @inheritParams wk_handle
#' @param direction The winding polygon winding direction
#'
#' @return `handleable` with consistently oriented polygons, in `direction`
#'   winding order.
#' @export
#'
#' @examples
#' wk_orient(wkt("POLYGON ((0 0, 1 0, 1 1, 0 1, 0 0))"))
#' wk_orient(
#'   wkt("POLYGON ((0 0, 0 1, 1 1, 1 0, 0 0))"),
#'   direction = wk_clockwise()
#' )
#'
wk_orient <- function(handleable, ..., direction = wk_counterclockwise()) {
  result <- wk_handle(
    handleable,
    wk_orient_filter(wk_writer(handleable), direction),
    ...
  )
  result <- wk_restore(handleable, result, ...)
  result <- wk_set_geodesic(result, wk_is_geodesic(handleable))
  wk_set_crs(result, wk_crs(handleable))
}

#' @rdname wk_orient
#' @export
wk_orient_filter <- function(handler, direction = wk_counterclockwise()) {
  stopifnot(direction %in% c(wk_clockwise(), wk_counterclockwise()))

  new_wk_handler(
    .Call(
      wk_c_orient_filter_new,
      as_wk_handler(handler),
      as.integer(direction)[1]
    ),
    "wk_orient_filter"
  )
}

#' @rdname wk_orient
#' @export
wk_clockwise <- function() {
  -1L
}

#' @rdname wk_orient
#' @export
wk_counterclockwise <- function() {
  1L
}

Try the wk package in your browser

Any scripts or data that you put into this service are public.

wk documentation built on Oct. 22, 2023, 9:07 a.m.