df <- structure(list(ID = structure(c(1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L,
2L, 2L, 2L, 3L, 3L, 3L, 3L, 3L, 3L, 4L, 4L, 4L, 4L, 4L, 4L, 5L,
5L, 5L, 5L, 5L, 5L, 6L, 6L, 6L, 6L, 6L, 6L, 7L, 7L, 7L), .Label = c("1",
"2", "3", "4", "5", "6", "7"), class = "factor"), TYPE = structure(c(1L,
2L, 3L, 4L, 5L, 1L, 2L, 3L, 4L, 5L, 6L, 1L, 2L, 3L, 4L, 5L, 6L,
1L, 2L, 3L, 4L, 5L, 6L, 1L, 2L, 3L, 4L, 5L, 6L, 1L, 2L, 3L, 4L,
5L, 6L, 1L, 2L, 3L), .Label = c("1", "2", "3", "4", "5", "6",
"7", "8"), class = "factor"), TIME = structure(c(2L, 2L, 2L,
2L, 2L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L,
2L, 2L, 2L, 2L, 1L, 1L, 1L, 1L, 1L, 1L, 2L, 2L, 2L, 2L, 2L, 2L,
1L, 1L, 1L), .Label = c("1", "5", "15"), class = "factor"), VAL = c(0.937377670081332,
0.522220720537007, 0.278690102742985, 0.967633064137772, 0.116124767344445,
0.0544306698720902, 0.470229141646996, 0.62017166428268, 0.195459847105667,
0.732876230962574, 0.996336271753535, 0.983087373664603, 0.666449476964772,
0.291554537601769, 0.167933790013194, 0.860138458199799, 0.172361251665279,
0.833266809117049, 0.620465772924945, 0.786503327777609, 0.761877260869369,
0.425386636285111, 0.612077651312575, 0.178726130630821, 0.528709076810628,
0.492527724476531, 0.472576208412647, 0.0702785139437765, 0.696220921119675,
0.230852259788662, 0.359884874196723, 0.518227979075164, 0.259466265095398,
0.149970305617899, 0.00682218233123422, 0.463400925742462, 0.924704828299582,
0.229068386601284)), .Names = c("ID", "TYPE", "TIME", "VAL"), row.names = c(NA,
-38L), class = "data.frame")
如果我创建以下绘图:
ggplot(df, aes(x=ID, y=VAL, fill=TYPE)) +
facet_wrap(~ TIME, ncol=1) +
geom_bar(position="stack") +
coord_flip()
然后我决定在不包含任何数据的分面中抑制任何因子的显示。 我已经参考了各种问题和答案,认为scale = "free"
方法是正确的方式(而非drop = TRUE
会删除与TIME
中未使用值对应的空分面),所以接下来:
ggplot(df, aes(x=ID, y=VAL, fill=TYPE)) +
facet_wrap(~TIME, ncol=1, scale="free") +
geom_bar(position="stack") +
coord_flip()
我的问题是如何防止一个分面有4个条形图而另一个分面只有3个条形图时发生的条形图缩放。在这个人为构造的例子中,效果很微妙,在我的实际数据中更糟糕。理想的输出应该是底部的分面与顶部的分面具有相同的条形宽度,并且具有ID因素1、4和6的垂直轴,因此分面的整体垂直尺寸会减小。
如果您能帮我解决为什么计数会堆叠而不是数字值的问题(现已解决),那就更好了。
悬赏更新:
如我在我的后续 问题 中所述,一个更好的解决方案似乎涉及使用 ggplot_build
和 ggplot_table
并修改 gtable 对象。我相信我可以花时间弄清楚,但我希望有人能给我提供帮助。Koshke已经发布了一些 示例。
y
而不是Y
,并且加上stat = "identity"
? - joranspace='free'
参数可以用于facet_wrap
,也许这正是你要找的。早些时候已经有一个关于此的完美问题,但用户已将其删除... - Justinfacet_wrap
不支持space="free"
。 - mindless.panda