请帮我找到一种通用方法,将文本放置在距离绘图区域右侧恒定的距离,如下图所示。由于情节区域在右侧较窄,不幸的是,当前的放置计算将文本定位得太靠左。请注意,文本是右对齐的。
我的最后一个想法:如果我们知道在x = 1和x = 2之间的厘米距离,我们可以很容易地计算出位置。不幸的是,显然not that easy可以达到那个距离。
仅供参考:我不打算标记这些线条。
library(ggplot2)
library(reshape)
library(gridExtra)
df = data.frame(x =(1:3),One=c(12, 8, 13),Two=c(13, 7, 11),Three=c(11, 9, 11))
df.melt = melt(df, id.vars="x")
xmax = max(df.melt$x); xmin = min(df.melt$x)
ymax = max(df.melt$value); ymin = min(df.melt$value)
dfa = data.frame(x=(xmax-xmin)*1.15+xmin, y=c(11,12,13.5), ann=c("10.1|","1.1|","Texttexttext|"))
dfa.melt = melt(dfa, id.vars=c("x","ann"))
p = ggplot() +
geom_line(data=df.melt, aes(x=x, y=value, color=variable), show_guide=F) +
geom_text(data=dfa.melt, aes(x=x, y=value, hjust = 1, label=ann), size=3) +
coord_cartesian(xlim=c(xmin,xmax), ylim=c(ymin,ymax))
p1 = p + theme(plot.margin=unit(c(1,3,0,0),"cm"), axis.text.y=element_text(size=10))
p2 = p + theme(plot.margin=unit(c(1,3,0,3),"cm"), axis.text.y=element_text(size=35))
p1c <- ggplot_gtable(ggplot_build(p1))
p1c$layout$clip[p1c$layout$name=="panel"] <- "off"
p2c <- ggplot_gtable(ggplot_build(p2))
p2c$layout$clip[p2c$layout$name=="panel"] <- "off"
grid.arrange(p1c, p2c, ncol=2)
答案 0 :(得分:3)
因为所有内容都已命名,所以可以访问 使用的情节的任何组成部分 网格功能。
问题是ggplot2在绘制绘图时会创建许多视口和凹凸。所以改变这个情节并不容易。 我还注意到,每次执行绘图时,grobs和视口的名称都会发生变化。所以我尝试通过一些标准(这里深度= 4)
来获取视口#Get the viewports:
scene.vps <- grid.ls(viewports=T,grobs=F)
scene.flat <- as.data.frame(do.call('cbind',scene.vps))
vps <- subset(scene.flat ,vpDepth == '4')$name[1:2]
vps <- as.character(vps)
# modify the plot by grid.text
depth <- downViewport(vps[1])
grid.text("1.1|",x=unit(1, "npc") - unit(1, "mm"),
y=unit(1, "npc") - unit(20, "mm"),
just=c("right", "top"))
grid.text("10.1|",x=unit(1, "npc") - unit(1, "mm"),
y=unit(1, "npc") - unit(60, "mm"),
just=c("right", "top"))
grid.text("Texttexttext|",x=unit(1, "npc") - unit(10, "mm"),
y=unit(1, "npc") -unit(2,'mm'),
just=c("right", "top"))
upViewport(depth) # come back to the root viewport
depth <- downViewport(vps[2])
grid.text(...