314 lines
11 KiB
R
314 lines
11 KiB
R
|
### R code from vignette source 'grobs.Rnw'
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 1: grobs.Rnw:32-36
|
||
|
###################################################
|
||
|
library(grDevices)
|
||
|
library(grid)
|
||
|
ps.options(pointsize = 12)
|
||
|
options(width = 60)
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 2: grobs.Rnw:50-52
|
||
|
###################################################
|
||
|
gl <- linesGrob()
|
||
|
gl <- editGrob(gl, gp = gpar(col = "green"))
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 3: grobs.Rnw:66-70
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
grid.lines(name = "lines")
|
||
|
grid.edit(gPath("lines"), gp = gpar(col = "pink"))
|
||
|
grid.edit("lines", gp = gpar(col = "red"))
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 4: grobs.Rnw:86-93
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(w = .5, h = .5))
|
||
|
grid.rect(gp = gpar(col = "grey"))
|
||
|
grid.xaxis(name = "myxaxis")
|
||
|
grid.edit("myxaxis", at = 1:4/5)
|
||
|
grid.edit(gPath("myxaxis", "labels"), y = unit(-1, "lines"))
|
||
|
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 5: grobs.Rnw:105-115
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(w = .5, h = .5))
|
||
|
myplot <-
|
||
|
gTree(name = "myplot",
|
||
|
children = gList(rectGrob(name = "box", gp = gpar(col = "grey")),
|
||
|
xaxisGrob(name = "xaxis")))
|
||
|
grid.draw(myplot)
|
||
|
grid.edit("myplot::xaxis", at = 1:10/11)
|
||
|
grid.edit("myplot::xaxis::labels", label = round(1:10/11, 2))
|
||
|
grid.edit("myplot::xaxis::labels", y = unit(-1, "lines"))
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 6: grobs.Rnw:123-126
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
gt <- grid.text("Hi there")
|
||
|
grid.rect(width = unit(1, "grobwidth", gt))
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 7: grobs.Rnw:135-139
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
gt <- grid.text("Hi there", name = "sometext")
|
||
|
grid.rect(width = unit(1, "grobwidth", "sometext"))
|
||
|
grid.edit("sometext", label = "Something different")
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 8: grobs.Rnw:164-178
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
mygrob <- grob(name = "mygrob", cl = "mygrob")
|
||
|
preDrawDetails.mygrob <- function(x)
|
||
|
pushViewport(viewport(gp = gpar(fontsize = 20)))
|
||
|
|
||
|
drawDetails.mygrob <- function(x, recording = TRUE)
|
||
|
grid.draw(textGrob("hi there"), recording = FALSE)
|
||
|
|
||
|
postDrawDetails.mygrob <- function(x) popViewport()
|
||
|
|
||
|
widthDetails.mygrob <- function(x) unit(1, "strwidth", "hi there")
|
||
|
|
||
|
grid.draw(mygrob)
|
||
|
grid.rect(width = unit(1, "grobwidth", mygrob))
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 9: grobs.Rnw:196-208
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
mygtree <- gTree(name = "mygrob",
|
||
|
childrenvp = viewport(name = "labelvp",
|
||
|
gp = gpar(fontsize = 20)),
|
||
|
children = gList(textGrob("hi there", name = "label",
|
||
|
vp = "labelvp")),
|
||
|
cl = "mygtree")
|
||
|
widthDetails.mygtree <- function(x)
|
||
|
unit(1, "grobwidth", getGrob(x, "label"))
|
||
|
|
||
|
grid.draw(mygtree)
|
||
|
grid.rect(width = unit(1, "grobwidth", mygtree))
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 10: grobs.Rnw:216-221
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
fg <- frameGrob(layout = grid.layout(1, 2))
|
||
|
fg <- placeGrob(fg, textGrob("Hi there"), col = 1)
|
||
|
fg <- placeGrob(fg, rectGrob(), col = 2)
|
||
|
grid.draw(fg)
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 11: grobs.Rnw:226-242
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(layout = grid.layout(2, 2)))
|
||
|
drawIt <- function(row, col) {
|
||
|
pushViewport(viewport(layout.pos.col = col, layout.pos.row = row))
|
||
|
grid.rect(gp = gpar(col = "grey"))
|
||
|
grid.draw(fg)
|
||
|
upViewport()
|
||
|
}
|
||
|
fg <- frameGrob()
|
||
|
fg <- packGrob(fg, textGrob("Hi there"))
|
||
|
fg <- placeGrob(fg, rectGrob())
|
||
|
drawIt(1, 1)
|
||
|
fg <- packGrob(fg, textGrob("Hello again"), side = "right")
|
||
|
drawIt(1, 2)
|
||
|
fg <- packGrob(fg, rectGrob(), side = "right", width = unit(1, "null"))
|
||
|
drawIt(2, 2)
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 12: grobs.Rnw:254-263
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
fg <- frameGrob()
|
||
|
fg <- packGrob(fg, textGrob("Hi there"))
|
||
|
fg <- placeGrob(fg, rectGrob())
|
||
|
fg <- packGrob(fg, textGrob("Hello again", name = "midtext"),
|
||
|
side = "right", dynamic = TRUE)
|
||
|
fg <- packGrob(fg, rectGrob(), side = "right", width = unit(1, "null"))
|
||
|
grid.draw(fg)
|
||
|
grid.edit("midtext", label = "something much longer")
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 13: grobs.Rnw:287-311
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(layout = grid.layout(2, 2)))
|
||
|
drawIt <- function(row, col) {
|
||
|
pushViewport(viewport(layout.pos.col = col, layout.pos.row = row))
|
||
|
grid.rect(gp = gpar(col = "grey"))
|
||
|
grid.draw(gplot)
|
||
|
upViewport()
|
||
|
}
|
||
|
gplot <- gTree(x = NULL, y = NULL,
|
||
|
childrenvp = vpTree(
|
||
|
plotViewport(c(5, 4, 4, 2), name = "plotRegion"),
|
||
|
vpList(viewport(name = "dataRegion"))),
|
||
|
children = gList(
|
||
|
xaxisGrob(vp = "plotRegion::dataRegion"),
|
||
|
yaxisGrob(vp = "plotRegion::dataRegion"),
|
||
|
rectGrob(vp = "plotRegion")))
|
||
|
drawIt(1, 1)
|
||
|
gplot <- addGrob(gplot, pointsGrob(vp = "plotRegion::dataRegion"))
|
||
|
drawIt(1, 2)
|
||
|
gplot <- addGrob(gplot, pointsGrob(name = "data1", pch = 2,
|
||
|
vp = "plotRegion::dataRegion"))
|
||
|
drawIt(2, 1)
|
||
|
gplot <- removeGrob(gplot, "data1")
|
||
|
drawIt(2, 2)
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 14: grobs.Rnw:318-339
|
||
|
###################################################
|
||
|
gplot <- gTree(x = NULL, y = NULL,
|
||
|
childrenvp = vpTree(
|
||
|
plotViewport(c(5, 4, 4, 2), name = "plotRegion"),
|
||
|
vpList(viewport(name = "dataRegion"))),
|
||
|
children = gList(
|
||
|
xaxisGrob(vp = "plotRegion::dataRegion"),
|
||
|
yaxisGrob(vp = "plotRegion::dataRegion"),
|
||
|
rectGrob(vp = "plotRegion")))
|
||
|
save(gplot, file = "gplot1")
|
||
|
gplot <- addGrob(gplot, pointsGrob(vp = "plotRegion::dataRegion"))
|
||
|
save(gplot, file = "gplot2")
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(layout = grid.layout(1, 2)))
|
||
|
pushViewport(viewport(layout.pos.col = 1))
|
||
|
load("gplot1")
|
||
|
grid.draw(gplot)
|
||
|
popViewport()
|
||
|
pushViewport(viewport(layout.pos.col = 2))
|
||
|
load("gplot2")
|
||
|
grid.draw(gplot)
|
||
|
popViewport()
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 15: grobs.Rnw:350-361
|
||
|
###################################################
|
||
|
myplot <- gTree(name = "myplot",
|
||
|
children = gList(
|
||
|
rectGrob(name = "box", gp = gpar(col = "grey")),
|
||
|
xaxisGrob(name = "xaxis")))
|
||
|
myplot <- editGrob(myplot, gPath = "xaxis", at = 1:10/11)
|
||
|
myplot <- editGrob(myplot, gPath = "xaxis::labels", label = round(1:10/11, 2))
|
||
|
myplot <- editGrob(myplot, gPath = "xaxis::labels", y = unit(-1, "lines"))
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(w = .5, h = .5))
|
||
|
grid.draw(myplot)
|
||
|
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 16: grobs.Rnw:367-380
|
||
|
###################################################
|
||
|
myplot <- gTree(name = "myplot",
|
||
|
children = gList(
|
||
|
rectGrob(name = "box", gp = gpar(col = "grey")),
|
||
|
xaxisGrob(name = "xaxis")))
|
||
|
getGrob(myplot, "xaxis")
|
||
|
myplot <- editGrob(myplot, gPath="xaxis", at=1:10/11)
|
||
|
getGrob(myplot, "xaxis::labels")
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(w=.5, h=.5))
|
||
|
grid.draw(myplot)
|
||
|
grid.get("myplot")
|
||
|
grid.get("myplot::xaxis")
|
||
|
grid.get("myplot::xaxis::labels")
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 17: grobs.Rnw:401-417
|
||
|
###################################################
|
||
|
myplot <- gTree(name = "myplot",
|
||
|
children = gList(rectGrob(name = "box", gp = gpar(col = "grey")),
|
||
|
xaxisGrob(name = "xaxis")))
|
||
|
myplot <- setGrob(myplot, "xaxis", rectGrob(name = "xaxis"))
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(w = .5, h = .5))
|
||
|
grid.draw(myplot)
|
||
|
grid.set("myplot::xaxis", xaxisGrob(name = "xaxis", at = 1:3/4))
|
||
|
grid.set("myplot::xaxis::labels",
|
||
|
textGrob(name = "labels", x = unit(1:3/4, "native"),
|
||
|
y = unit(-1, "lines"), label = letters[1:3]))
|
||
|
myplot <- setGrob(grid.get("myplot"), "xaxis::labels",
|
||
|
circleGrob(name = "labels"))
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(w = .5, h = .5))
|
||
|
grid.draw(myplot)
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 18: grobs.Rnw:435-466
|
||
|
###################################################
|
||
|
drawIt <- function(row, col) {
|
||
|
pushViewport(viewport(layout.pos.col = col, layout.pos.row = row))
|
||
|
grid.rect(gp = gpar(col = "grey"))
|
||
|
grid.draw(gplot)
|
||
|
upViewport()
|
||
|
}
|
||
|
gplot <- gTree(name = "plot1",
|
||
|
childrenvp = vpTree(
|
||
|
plotViewport(c(5, 4, 4, 2), name = "plotRegion"),
|
||
|
vpList(viewport(name = "dataRegion"))),
|
||
|
children = gList(
|
||
|
xaxisGrob(name = "xaxis", vp = "plotRegion::dataRegion"),
|
||
|
yaxisGrob(name = "yaxis", vp = "plotRegion::dataRegion"),
|
||
|
rectGrob(name = "box", vp = "plotRegion")))
|
||
|
grid.newpage()
|
||
|
pushViewport(viewport(layout = grid.layout(2, 2)))
|
||
|
drawIt(1, 1)
|
||
|
grid.add("plot1", pointsGrob(0.5, 0.5, name = "data1",
|
||
|
vp = "plotRegion::dataRegion"))
|
||
|
grid.add("plot1::xaxis",
|
||
|
textGrob("X Axis", y = unit(-2, "lines"), name = "xlab"))
|
||
|
grid.edit("plot1::xaxis::xlab", y = unit(-3, "lines"))
|
||
|
gplot <- grid.get("plot1")
|
||
|
gplot <- addGrob(gplot, gPath = "yaxis",
|
||
|
textGrob("Y Axis", x = unit(-3, "lines"), rot = 90,
|
||
|
name = "ylab"))
|
||
|
drawIt(1, 2)
|
||
|
gplot <- removeGrob(gplot, "xaxis::xlab")
|
||
|
drawIt(2, 1)
|
||
|
grid.remove("plot1::data1")
|
||
|
grid.remove("plot1")
|
||
|
|
||
|
|
||
|
###################################################
|
||
|
### code chunk number 19: grobs.Rnw:474-484
|
||
|
###################################################
|
||
|
grid.newpage()
|
||
|
grid.frame(name = "myframe", layout = grid.layout(1, 2))
|
||
|
grid.place("myframe", textGrob("Hi there"), col = 1)
|
||
|
grid.place("myframe", rectGrob(), col = 2)
|
||
|
grid.newpage()
|
||
|
grid.frame(name = "frame2")
|
||
|
grid.pack("frame2", textGrob("Hi there"))
|
||
|
grid.place("frame2", rectGrob())
|
||
|
grid.pack("frame2", textGrob("Hello again"), side = "right")
|
||
|
grid.pack("frame2", rectGrob(), side = "right", width = unit(1, "null"))
|
||
|
|
||
|
|