2025-01-12 04:36:52 +08:00

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"))