grid.ls {grid} | R Documentation |
List the names of grobs or viewports
Description
Return a listing of the names of grobs or viewports.
This is a generic function with methods for grobs (including gTrees) and viewports (including vpTrees).
Usage
grid.ls(x=NULL, grobs=TRUE, viewports=FALSE, fullNames=FALSE,
recursive=TRUE, print=TRUE, flatten=TRUE, ...)
nestedListing(x, gindent=" ", vpindent=gindent)
pathListing(x, gvpSep=" | ", gAlign=TRUE)
grobPathListing(x, ...)
Arguments
x |
A grob or viewport or For print functions, this should be the result of a call to
|
grobs |
A logical value indicating whether to list grobs. |
viewports |
A logical value indicating whether to list viewports. |
fullNames |
A logical value indicating whether to embellish object names with information about the object type. |
recursive |
A logical value indicating whether recursive structures should also list their children. |
print |
A logical indicating whether to print the listing or a function that will print the listing. |
flatten |
A logical value indicating whether to flatten the listing. Otherwise a more complex hierarchical object is produced. |
gindent |
The indent used to show nesting in the output for grobs. |
vpindent |
The indent used to show nesting in the output for viewports. |
gvpSep |
The string used to separate viewport paths from grob paths. |
gAlign |
Logical indicating whether to align the left hand edge of all grob paths. |
... |
Arguments passed to the |
Details
If the argument x
is NULL
, the current contents
of the grid display list are listed (both viewports and grobs).
In other words, all objects representing the current scene
are listed.
Otherwise, x
should be a grob or a viewport.
The default behaviour of this function is to print information about the grobs in the current scene. It is also possible to add information about the viewports in the scene. By default, the listing is recursive, so all children of gTrees and all nested viewports are reported.
The format of the information can be controlled via the print
argument, which can be given a function to perform the formatting.
The nestedListing
function produces a line per grob or
viewport, with indenting used to show nesting. The pathListing
function produces a line per grob or viewport, with viewport paths
and grob paths used to show nesting. The grobPathListing
is a simple derivation that only shows lines for grobs. The user
can define new functions.
Value
The result of this function is either a "gridFlatListing"
object (if flatten
is TRUE
) or a "gridListing"
object.
The former is a simple (flat) list of vectors. This is convenient, for example, for working programmatically with the list of grob and viewport names, or for writing a new display function for the listing.
The latter is a more complex hierarchical object (list of lists), but it does contain more detailed information so may be of use for more advanced customisations.
Author(s)
Paul Murrell
See Also
Examples
# A gTree, called "parent", with childrenvp vpTree (vp2 within vp1)
# and child grob, called "child", with vp vpPath (down to vp2)
sampleGTree <- gTree(name="parent",
children=gList(grob(name="child", vp="vp1::vp2")),
childrenvp=vpTree(parent=viewport(name="vp1"),
children=vpList(viewport(name="vp2"))))
grid.ls(sampleGTree)
# Show viewports too
grid.ls(sampleGTree, viewports=TRUE)
# Only show viewports
grid.ls(sampleGTree, viewports=TRUE, grobs=FALSE)
# Alternate displays
# nested listing, custom indent
grid.ls(sampleGTree, viewports=TRUE, print=nestedListing, gindent="--")
# path listing
grid.ls(sampleGTree, viewports=TRUE, print=pathListing)
# path listing, without grobs aligned
grid.ls(sampleGTree, viewports=TRUE, print=pathListing, gAlign=FALSE)
# grob path listing
grid.ls(sampleGTree, viewports=TRUE, print=grobPathListing)
# path listing, grobs only
grid.ls(sampleGTree, print=pathListing)
# path listing, viewports only
grid.ls(sampleGTree, viewports=TRUE, grobs=FALSE, print=pathListing)
# raw flat listing
str(grid.ls(sampleGTree, viewports=TRUE, print=FALSE))