R/strwidth2xlim.R

Defines functions strwidth2xlim

Documented in strwidth2xlim

#  strwidth2xlim: Calculates xlim for adding labels to positions ##
#'
#' Calculate horizontal limit in user coordinates for adding labels
#'
#' Calculates the x-axis limits when adding (long) labels to a plot
#'
#' @param x numeric vector of horizontal coordinates
#'
#' @param xstring character vector, specifying text to be written
#'
#' @param pos position specifier for text; values of `1`, `2`,
#'   `3`, and `4`, respectively, indicate positions below, to
#'   the left of, above, and to the right of the coordinates
#'
#' @param offset offset of the label from the coordinate in fractions of
#'     a character width
#'
#' @param ... additional text parameters from `par`, such as `cex`
#'
#' @details
#' See `text` for details on `pos` and `offset`.
#'
#' @importFrom graphics strwidth
#' @export
#' @return
#' Minimum and maximum x-axis limits for adding horizontal text
#'
#' @author
#' Aimee Teo Broman
#'
#' @examples
#' x <- runif(15,-1,1)*10
#' xlabs <- sapply(sample(1:20,15,replace=TRUE),
#'          function(a) paste(LETTERS[1:a], collapse=""))
#' ## Labels to the left ##
#' xlims <- strwidth2xlim(x,xlabs,pos=2)
#' plot(x,1:length(x),xlim=xlims)
#' text(x,1:length(x),xlabs,pos=2)
#' ## Labels to the right ##
#' xlims <- strwidth2xlim(x,xlabs,pos=4,cex=0.7)
#' plot(x,1:length(x),xlim=xlims)
#' text(x,1:length(x),xlabs,pos=4,cex=0.7)
#'
#' @seealso [graphics::text()]
strwidth2xlim <- function(x,xstring, pos=4, offset=0.5,...){
    xwid <- (strwidth(xstring,units="inches", ...)+
             offset*par("cin")[1])/par("pin")[1]
    xmax <- max(x,na.rm=TRUE)
    xmin <- min(x,na.rm=TRUE)
    x1 <- x-xmax
    x2 <- x-xmin
    if(pos==2) return(c(min(x1/(1-xwid)),0)+xmax)
    if(pos==4) return(c(0, max(x2/(1-xwid)))+xmin)
    if(pos %in% c(1,3))
        return(c(min(x1/(1-0.5*xwid))+xmax,max(x2/(1-0.5*xwid))+xmin))
}

Try the broman package in your browser

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

broman documentation built on July 8, 2022, 5:07 p.m.