你如何在R中的多图形环境中画一条线?

gun*_*ica 10 r graph

举一个很简单的例子,mfrow=c(1,3); 每个图都是不同的直方图; 我将如何绘制abline(h=10)横跨所有 3个数字的水平线(类似于)?(即使是它们之间的边距.)显然,我可以为每个数字添加一个基线,但这不是我想要的.我可以想到一个非常复杂的方法来做到这一点,实际上只有1个数字,并使用polygon等在其中绘制每个"数字" .这将是荒谬的.有没有一个简单的方法来做到这一点?

Jos*_*ien 16

正如@joran指出的那样,网格图形系统可以更灵活地控制单个设备上多个图的排列.

在这里,我首先使用grconvertY()以"标准化设备坐标" 为单位在y轴上查询高度为50的位置.(即作为绘图设备总高度的一部分,0 =底部,1 =顶部).然后我使用网格函数:(1)推送一个viewport填充设备; (2)在返回的高度绘制一条线grconvertY().

## Create three example plots
par(mfrow=c(1,3))
barplot(VADeaths, border = "dark blue") 
barplot(VADeaths, border = "yellow") 
barplot(VADeaths, border = "green") 

## From third plot, get the "normalized device coordinates" of 
## a point at a height of 50 on the y-axis.
(Y <- grconvertY(50, "user", "ndc"))
# [1] 0.314248

## Add the horizontal line using grid
library(grid)
pushViewport(viewport())
grid.lines(x = c(0,1), y = Y, gp = gpar(col = "red"))
popViewport()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

编辑:@joran询问如何绘制从第1个绘图的y轴延伸到第3个绘图中最后一个条的边缘的线.这里有几个选择:

library(grid)
library(gridBase)
par(mfrow=c(1,3))

# barplot #1
barplot(VADeaths, border = "dark blue") 
X1 <- grconvertX(0, "user", "ndc")
# barplot #2
barplot(VADeaths, border = "yellow") 
# barplot #3
m <- barplot(VADeaths, border = "green") 
X2 <- grconvertX(tail(m, 1) + 0.5, "user", "ndc") # default width of bars = 1
Y <- grconvertY(50, "user", "ndc")

## Horizontal line
pushViewport(viewport())
grid.lines(x = c(X1, X2), y = Y, gp = gpar(col = "red"))
popViewport()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

最后,这是一种几乎等同且更普遍有用的方法.它采用了Paul Murrell在@ mdsumner答案中链接的文章中的功能grid.move.to()grid.line.to()演示:

library(grid)
library(gridBase)
par(mfrow=c(1,3))

barplot(VADeaths); vps1 <- do.call(vpStack, baseViewports())
barplot(VADeaths) 
barplot(VADeaths); vps3 <- do.call(vpStack, baseViewports())

pushViewport(vps1)
Y <- convertY(unit(50,"native"), "npc")
popViewport(3)

grid.move.to(x = unit(0, "npc"), y = Y, vp = vps1)
grid.line.to(x = unit(1, "npc"), y = Y, vp = vps3, 
             gp = gpar(col = "red"))
Run Code Online (Sandbox Code Playgroud)


jor*_*ran 6

这是我能做的最好的事情,而不用考虑更难:

par(mfrow = c(1,3),xpd = NA)

for (i in 1:3){
    x <- rnorm(200,i)
    hist(x)
    if (i == 1) segments(par("usr")[1],10,30,10)
}
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

我不确定如何在没有修补的情况下确保线路在正确的位置结束.绘制每个区域中的一个区段可以解决这个问题,但会引入高度排列正确的问题.但这可能是一个很好的起点,至少.

我猜这在网格图形中更容易,但我必须做一些研究来验证.