我已经从两个gtable
对象gTree
,grob
上通过gDesc
创建了myobj
(也是myobj <- gridExtra::grid.arrange(g1,g2)
ggplot
g1
)对象g2
,现在我必须恢复我用来创建两个ggplots的数据。有没有办法正确地做到这一点?
[我已经尝试使用各种功能(例如myobj
)转换ggpubr::as_ggplot
,导致对象带有waiver()
作为$data
条目-因此在那里没有成功-并且我也席卷了所有grobs
我实际上在图中找到数据点的myobj
中的]项(看起来像这样
grobs.grobs.children.geom_point.points.5415.x1
0.04545455
),但是,仅是位置坐标$ \ in(0,1)$ w.r.t.。相应的轴。然后,我大概可以获得轴+轴范围,然后外推原始数据点。但这似乎太费力了。有没有更简单的解决方案?
不知道这是否真的导致了与我相同的对象(因为我的年龄将近2岁,但是首先:
library(ggplot)
# plot 1
g1 <- ggplot(mpg, aes(displ, cty)) + geom_point() + facet_grid(cols = vars(cyl))
# plot 2
g2 <- ggplot(mtcars, aes(mpg, wt, colour = factor(cyl))) + geom_point() + facet_grid(vars(cyl))
# create object
myobj <- gridExtra::grid.arrange(g1, g2, ncol=1)
# Now I would need some extract_data function to retrieve mpg and mtcars:
list_with_mpg_and_mtcars <- extract_data(myobj)
您不能;在此阶段(即ggplotGrob
之后),数据已被处理为图形对象,并且映射通常不可逆,就像煎蛋一样。
如果您绝望需要一些返回值,则可以检查与绘制点相对应的单个grob,例如
myobj$grobs[[2]]$grobs[[2]]$children[[3]][c('x','y')]
$x
[1] 0.525145067698259native 0.587040618955513native
[3] 0.525145067698259native 0.89651837524178native
[5] 0.819148936170213native 0.954545454545455native
[7] 0.474854932301741native 0.699226305609285native
[9] 0.648936170212766native 0.819148936170213native
[11] 0.470986460348163native
$y
[1] 0.233037353850445native 0.435264173310709native
[3] 0.425966388507938native 0.205143999442133native
[5] 0.0691638967016109native 0.12030171311685native
[7] 0.266741823760489native 0.143546175123777native
[9] 0.191197322237977native 0.0454545454545455native
[11] 0.339961879082309native