Nothing
#' Visualise the layout of a gtable.
#'
#' This function is a simple wrapper around [grid::grid.show.layout()] that
#' allows you to inspect the layout of the gtable.
#'
#' @param x a gtable object
#' @inheritDotParams grid::grid.show.layout
#'
#' @export
#'
#' @examples
#' gt <- gtable(widths = grid::unit(c(1, 0.5, 2), c("null", "cm", "null")),
#' heights = grid::unit(c(0.2, 1, 3), c("inch", "null", "cm")))
#' gtable_show_layout(gt)
#'
gtable_show_layout <- function(x, ...) {
check_gtable(x)
grid.show.layout(gtable_layout(x), ...)
}
gtable_layout <- function(x) {
check_gtable(x)
grid.layout(
nrow = length(x$heights), heights = x$heights,
ncol = length(x$widths), widths = x$widths,
respect = x$respect
)
}
vpname <- function(row) {
row <- unclass(row)
paste(row$name, ".", row$t, "-", row$r, "-", row$b, "-", row$l, sep = "")
}
#' @export
widthDetails.gtable <- function(x) absolute.size(gtable_width(x))
#' @export
heightDetails.gtable <- function(x) absolute.size(gtable_height(x))
#' @export
makeContext.gtable <- function(x) {
layoutvp <- viewport(layout = gtable_layout(x), name = x$name)
if (is.null(x$vp)) {
x$vp <- layoutvp
} else {
x$vp <- vpStack(x$vp, layoutvp)
}
x
}
#' @export
makeContent.gtable <- function(x) {
children_vps <- mapply(child_vp,
vp_name = vpname(x$layout),
t = .subset2(x$layout, "t"), r = .subset2(x$layout, "r"),
b = .subset2(x$layout, "b"), l = .subset2(x$layout, "l"),
clip = .subset2(x$layout, "clip"),
SIMPLIFY = FALSE
)
x$grobs <- mapply(wrap_gtableChild, x$grobs, children_vps,
SIMPLIFY = FALSE
)
setChildren(x, do.call("gList", x$grobs[order(.subset2(x$layout, "z"))]))
}
#' @export
makeContext.gTableChild <- function(x) {
if (is.null(x$vp)) {
x$vp <- x$wrapvp
} else {
x$vp <- vpStack(x$wrapvp, x$vp)
}
# A gTableChild extends an arbitrary grob class
# so allow existing makeContext() behaviour of
# original grob class to still occur
NextMethod()
}
# Return the viewport for a child grob in a gtable
child_vp <- function(vp_name, t, r, b, l, clip) {
viewport(
name = vp_name, layout.pos.row = t:b,
layout.pos.col = l:r, clip = clip
)
}
# Turn a grob into a gtableChild, and store information about the
# viewport used within the gtable
wrap_gtableChild <- function(grob, vp) {
grobTree(grob, name = vp$name, vp = vp)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.