如果只有一个绘图有轴标签,如何创建多个绘图,每个绘图具有相同的绘图区域大小?

eip*_*i10 8 graphics layout plot r

我想在1x3布局中绘制三个图形.只有第一个图形需要有垂直轴标签,但我希望所有三个绘图区域的大小完全相同.如果没有或所有图表都有轴标签,这将没有问题.但是,当一个有轴标签而另外两个没有时,如何让所有三个图形大小相同?我试图在基本图形中执行此操作,因为这是我最熟悉的,但如果它们提供更好的方法来解决我的问题,我会很乐意使用grid或ggplot2.

这是一些假数据,我的绘图代码和情节本身:

# Fake Data
data = structure(list(y1 = 1:5, y2 = c(1.2, 2.4, 3.6, 4.8, 6), y3 = c(1.44, 
2.88, 4.32, 5.76, 7.2)), .Names = c("y1", "y2", "y3"), 
row.names = c("I needed 12 units for financial aid", 
              "I couldn't find any other open classes",
              "I might be adding a major or minor", 
              "The class seemed interesting", "The class fit into my schedule"
), class = "data.frame")

# Plotting code
par(mar=c(5,15,4,1))
par(mfrow=c(1,3))
barplot(data$y1,names.arg=row.names(data), horiz=TRUE,las=1, +
        xlim=c(0,8), main="Group 1")
par(mar=c(5,1,4,1))
barplot(data$y2,names.arg=row.names(data), horiz=TRUE,las=1, +
        axisnames=FALSE, xlim=c(0,8), main="Group 2")
barplot(data$y3,names.arg=row.names(data), horiz=TRUE,las=1, +
        axisnames=FALSE, xlim=c(0,8), main="Group 3")

# Reset plot options back to defaults
par(mfrow=c(1,1)
par(mar=c(5,4,4,2)+0.1)
Run Code Online (Sandbox Code Playgroud)

[ 更新:我选择了最直接回答我的问题的答案,这是基本图形,但我建议同时查看其他解决方案,因为它们展示了如何在lattice和中执行相同的操作ggplot2.

在此输入图像描述

Gre*_*now 8

对于基本图形,您希望使用外边距而不是常规边距.只需更换第一par(mar=c(5,15,4,1))par(oma=c(0,15,0,0))和去除第二呼叫到par与该地块将采取等于空间(和轴标签会粘到左侧的外缘).


Aar*_*ica 7

使用基本图形的最简单方法可能是使它们全部没有y轴标签,然后将标签分别添加到所有三个标签左侧的附加面板中.

但是这样的任务是为什么lattice(以及ggplot为此)发明的原因之一.你也可以考虑一个dotplot,特别是如果你是William Cleveland的粉丝.

library(reshape2)
d2 <- data
d2$q <- rownames(d2)
d2 <- melt(d2, measure.vars=1:3, id.vars=4)
d2$q <- factor(d2$q, levels=rownames(data))

library(lattice)
barchart(q ~ value|variable, data=d2)
dotplot(q ~ value|variable, data=d2)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述 在此输入图像描述


jor*_*ran 6

我可以用一些东西拼凑起来layout,但是使用ggplot2的分面功能来做它会更快:

data$grp <- rownames(data)
datam <- melt(data,id.vars = "grp")
ggplot(datam,aes(x = grp,y = value)) + 
    facet_wrap(~variable,nrow = 1) + 
    geom_bar(stat = "identity") + 
    coord_flip()
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述