过去完美工作的旧代码不再适用于0.9.3。这个问题与使用小平面,自由音阶和坐标翻转有关。
这是一种重现方式:
数据集:d.csv:
"Priority","Owner","Project"
"Medium","owner7","Team4"
"Medium","owner1","Team1"
"Low","","Team3"
"High","owner6","Team3"
"Medium","","Team4"
"Medium","owner3","Team1"
"Medium","owner2","Team1"
"Medium","owner5","Team2"
"Low","owner4","Team2"
"Critical","","Team2"
"Medium","owner2","Team1"
"High","","Team4"
代码:
data <- read.csv(file="d.csv",head=TRUE)
attach(data)
p3 <- ggplot(data,aes(x=Owner,fill=Priority))+
geom_bar(aes(y=..count..)) +
facet_wrap(~ Project, nrow=2, scales="free") +
opts(legend.position="none")
这会创建一个多面图,但我需要翻转轴。以前,添加coord_flip()可以解决这个问题,但现在新的ggplot不允许一起使用自由缩放和coord_flip。还有其他方法可以转动小平面轴吗?自由秤对我很重要。谢谢你的任何指示。
答案 0 :(得分:1)
这是我第二次或第三次遇到这个问题。我发现我可以通过定义自定义geom来破解我自己的解决方案。
geom_bar_horz <- function (mapping = NULL, data = NULL, stat = "bin", position = "stack", ...) {
GeomBar_horz$new(mapping = mapping, data = data, stat = stat, position = position, ...)
}
GeomBar_horz <- proto(ggplot2:::Geom, {
objname <- "bar_horz"
default_stat <- function(.) StatBin
default_pos <- function(.) PositionStack
default_aes <- function(.) aes(colour=NA, fill="grey20", size=0.5, linetype=1, weight = 1, alpha = NA)
required_aes <- c("y")
reparameterise <- function(., df, params) {
df$width <- df$width %||%
params$width %||% (resolution(df$x, FALSE) * 0.9)
OUT <- transform(df,
xmin = pmin(x, 0), xmax = pmax(x, 0),
ymin = y - .45, ymax = y + .45, width = NULL
)
return(OUT)
}
draw_groups <- function(., data, scales, coordinates, ...) {
GeomRect$draw_groups(data, scales, coordinates, ...)
}
guide_geom <- function(.) "polygon"
})
这只是从ggplot2 github复制geom_bar代码,然后切换 x 和 y 引用,在标准笛卡尔协调器中制作水平条形图。
请注意,必须使用position='identity'
,也可能stat='identity'
才能使用此功能。如果您需要使用身份以外的位置,那么您必须对collide function进行eddit才能使其正常工作。
答案 1 :(得分:1)
2016年末更新:coord_flip
,facet_grid
和scales="free"
的此错误已在ggplot2
的开发版本中得到修复。您可以使用
install.packages("devtools")
devtools::install_github("hadley/ggplot2")
注意,根据您的需要同时尝试free_x
和free_y
,因为当您翻转坐标时,x
和y
的含义并不总是很清楚。< / p>
答案 2 :(得分:0)
看起来你正在请求的内容(如果我正确地理解了这个问题)之前已经提交给开发人员,他们将不会实现它。见这里:
https://github.com/hadley/ggplot2/issues/95
所以我想你需要找到一个解决方法。这是一个应该有效的快速想法:
使用facet_grid
代替“facet_wrap”,然后coord_flip()应该有效。然后将图片保存为pdf(或svg),并在某种矢量图形软件中重新排列图表 - 我建议使用Inkscape ...