我正在尝试用超链接提供ggplot2图:
这有效:
library(gridSVG)
library(lattice)
xyplot(mpg~wt, data=mtcars, main = "Link to R-project home")
mainGrobName <- grep("main", grid.ls()[[1]], value=TRUE)
grid.hyperlink(mainGrobName, "http://www.r-project.org")
gridToSVG("HyperlinkExample.svg")
这不是:
p = ggplot(mtcars, aes(wt, mpg)) + geom_point()+ labs(title="link")
print(p)
mainGrobName <- grep("title", grid.ls()[[1]], value=TRUE)
grid.hyperlink(mainGrobName, "http://www.r-project.org")
gridToSVG("HyperlinkExample.svg")
有关此的任何提示吗?
答案 0 :(得分:4)
我问过gridSVG包的作者之一Simon Potter: 这是他的(工作)答案:
我建议您在这里尝试开发版本:
http://r-forge.r-project.org/R/?group_id=1025
它包含一个专门用于处理gTables(以及ggplot2图形)的解决方法。
因此,尝试让您的示例正常工作,启动一个新的R会话并运行以下代码:
install.packages("gridSVG", repos="http://R-Forge.R-project.org")
library(gridSVG)
library(ggplot2)
(p <- ggplot(mtcars, aes(wt, mpg)) + geom_point() + labs(title="link"))
titleGrobName <- grep("title", grid.ls(print=FALSE)$name, value=TRUE)
grid.hyperlink(titleGrobName, "http://www.r-project.org/")
gridToSVG("HyperlinkExample.svg", "none", "none")
这里唯一真正的区别是给予gridToSVG()的附加参数。这主要是为了将输出减少到只有SVG文件和HTML包装器(否则你也会得到一些JSON数据,这对你的例子没用。)
答案 1 :(得分:0)
只要获得正确的mainGrobName
此代码即可成功(并且不会通过设置print=FALSE
来创建令人分心的副作用):
grep("title", grid.ls(print=FALSE)$name, value=TRUE)
#[1] "title.2-4-2-4"
绘图对象的结构显然比格子情况更复杂,并且gridToSVG默认不捕获它:
grep("title", grid.ls()$name, value=TRUE)
#--------------------
GRID.gTableParent.125
background.1-5-6-1
spacer.4-3-4-3
panel.3-4-3-4
grill.gTree.103
panel.background.rect.94
panel.grid.minor.y.polyline.96
panel.grid.minor.x.polyline.98
panel.grid.major.y.polyline.100
panel.grid.major.x.polyline.102
geom_point.points.90
panel.border.zeroGrob.91
axis-l.3-3-3-3
axis.line.y.zeroGrob.113
axis
axis-b.4-4-4-4
axis.line.x.zeroGrob.107
axis
xlab.5-4-5-4
ylab.3-2-3-2
title.2-4-2-4
这也是有趣的输出,但我没有看到如何让gridToSVG将其转换为有用的HTML对象:
grid.ls( print=pathListing )$name