8

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

对此有任何提示吗?

4

2 回答 2

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 数据,这对您的示例没有用处)。

于 2013-01-07T09:20:11.487 回答
0

就获得正确的代码而言mainGrobName,此代码将成功(并且不会通过设置来产生分散注意力的副作用print=FALSE):

grep("title", grid.ls(print=FALSE)$name, value=TRUE)
#[1] "title.2-4-2-4"

plot 对象的结构显然比 lattice 的情况更复杂,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
于 2012-12-29T03:15:18.907 回答