R/latticeRaster.R

Defines functions yscale.raster.NSsubticks yscale.raster.NS xscale.raster.NSsubticks xscale.raster.NS xscale.raster.EWsubticks xscale.raster.EW degreeLabelsEW2 yscale.raster.subticks xscale.raster.subticks yscale.raster xscale.raster lpolygon.SpatVector llines.SpatVector lpoints.SpatVector

Documented in llines.SpatVector lpoints.SpatVector lpolygon.SpatVector xscale.raster xscale.raster.subticks yscale.raster yscale.raster.subticks

## Points, lines and polygons with SpatVector
## Contributed by Alexandre Courtiol
lpoints.SpatVector <- function(x, ...) {
  if (is.null(x)) return(NULL)
  xy <- terra::crds(x, df = TRUE)
  lattice::lpoints(xy, ...)
}

llines.SpatVector <- function(x, ...) {
  if (is.null(x)) return(NULL)
  xy <- terra::crds(x, list = TRUE)
  names(xy) <- c("x", "y")
  lattice::llines(xy, ...)
}

lpolygon.SpatVector <- function(x, rule = "evenodd", ...) {
  if (is.null(x)) return(NULL)
  xy <- terra::crds(x, list = TRUE)
  for (i in seq_along(xy)) {
    for (j in seq_along(xy[[i]])) {
        lattice::lpolygon(x = xy[[i]][[j]][[1]],
                          y = xy[[i]][[j]][[2]],
                          rule = rule,
                          ...)
    }
  }
}

##Customization of lattice
xscale.raster <- function(lim, ...){
  ans <- xscale.components.default(lim, ...)
  ans$top=FALSE
  ans}

yscale.raster <- function(lim, ...){
  ans <- yscale.components.default(lim, ...)
  ans$right=FALSE
  ans}


xscale.raster.subticks <- function(lim, ...){
  ans <- xscale.components.subticks(lim, ...);
  ans$top=FALSE;
  ans}

yscale.raster.subticks <- function(lim, ...){
  ans <- yscale.components.subticks(lim, ...)
  ans$right=FALSE
  ans}

degreeLabelsEW2 <- function(x){
    x <- ifelse(x < -180, x + 360, x)
    x <- ifelse(x > 180, x - 360, x)
    pos = sign(x) + 2
    if (any(x == -180)) 
        pos[x == -180] = 2
    if (any(x == 180)) 
        pos[x == 180] = 2
    dir = c("*W", "", "*E")
    paste(abs(x), "*degree", dir[pos])    
    }

xscale.raster.EW <- function(lim, ...){
  ans <- xscale.components.default(lim, ...)
  labs <- as.numeric(ans$bottom$labels$labels)
  ans$bottom$labels$labels <- parse(text=degreeLabelsEW2(labs))
  ans$top=FALSE  
  ans}

xscale.raster.EWsubticks <- function(lim, ...){
    ans <- xscale.components.subticks(lim, ...)
    idx <- (ans$bottom$labels$labels!=' ')
    labs <- as.numeric(ans$bottom$labels$labels[idx])
    ans$bottom$labels$labels[idx] <- parse(text=degreeLabelsEW2(labs))
    ans$top=FALSE  
    ans}

xscale.raster.NS <- function(lim, ...){ ## useful for hovmoller
  ans <- xscale.components.default(lim, ...)
  labs <- as.numeric(ans$bottom$labels$labels)
  ans$bottom$labels$labels <- parse(text=degreeLabelsNS(labs))
  ans$top=FALSE  
  ans}

xscale.raster.NSsubticks <- function(lim, ...){
  ans <- xscale.components.subticks(lim, ...)
  idx <- (ans$bottom$labels$labels!=' ')
  labs <- as.numeric(ans$bottom$labels$labels[idx])
  ans$bottom$labels$labels[idx] <- parse(text=degreeLabelsNS(labs))
  ans$top=FALSE  
  ans}

yscale.raster.NS <- function(lim, ...){
  ans <- yscale.components.default(lim, ...)
  labs <- as.numeric(ans$left$labels$labels)
  ans$left$labels$labels <- parse(text=degreeLabelsNS(labs))
  ans$right=FALSE  
  ans}

yscale.raster.NSsubticks <- function(lim, ...){
  ans <- yscale.components.subticks(lim, ...)
  idx <- (ans$left$labels$labels!=' ')
  labs <- as.numeric(ans$left$labels$labels[idx])
  ans$left$labels$labels[idx] <- parse(text=degreeLabelsNS(labs))
  ans$right=FALSE  
  ans}

Try the rasterVis package in your browser

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

rasterVis documentation built on Nov. 2, 2023, 5:25 p.m.