如何用超链接提供ggplot2图?

时间:2012-12-28 14:44:18

标签: r svg ggplot2

我正在尝试用超链接提供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")

有关此的任何提示吗?

2 个答案:

答案 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