5

我用这些命令创建了下面的图:

ggplot(long.data, aes(owner,value)) + stat_summary(fun.y=mean,geom="bar",
       fill=c("deepskyblue","deepskyblue4")) + 
       stat_summary(fun.data=mean_cl_normal,geom="errorbar",position=
       position_dodge(width=.90),width=.1) +
       labs(x="",y="") + facet_grid(IV~experiment+type,scales="free_y") + 
       theme(strip.text.y = element_text(colour = 'red4'))

如果我只想更改上部 x 面(在本例中为“隐式”和“显式”级别)的文本颜色(可能还有背景颜色),我该怎么做?可能吗?我没有在 ggplot2 文档中阅读任何相关内容。

阴谋

编辑:我很抱歉造成混乱。我的目标是更改上方条带之一的文本和背景颜色,而不是刻面的颜色。

4

2 回答 2

6

您想更改strip元素的属性,而不是方面。试试下面的代码。请注意,这是一个基于随机组成的虚假数据的最小示例,因为您没有提供自己的数据供我们使用。您必须根据需要调整代码。

require(reshape)
require(ggplot2)
require(scales)

# fake data
mydf <- data.frame(val1 = runif(10, 0, 1), val2 = runif(10, 0, 1))
mydf

# reshape to long format
long.data <- melt(mydf)
long.data$facetvar <- "implicit"
long.data$facetvar[seq(1, 19, 2)] <- "explicit"
long.data

# plot
ggplot(long.data, aes(y = value, x = variable)) +
    geom_bar(position = 'dodge', stat = "identity") +
    facet_wrap (~ facetvar) +
    theme(strip.background = element_rect(fill = alpha('green', 0.3))) +
    theme(strip.text.x = element_text(colour = 'blue', size = 10))

这会产生这样的情节: 截屏

请注意,您已经等待了很长时间(按照 Stack Overflow 上 R 社区的标准)以获得答案,因为您的问题不清楚,并且您没有提供我们可以复制和粘贴的完全可重现的代码和数据我们自己的 R 装置。如果你这样做了,比我知识渊博的人会在一个小时内回答这个问题。请参阅这篇非常有用的帖子,了解如何提出下一个问题的提示。

于 2013-04-25T07:49:16.300 回答
4

我得到一个warning......但这似乎是一个更优雅的解决方案的良好起点:

ggplot(mtcars) + geom_rect(data = subset(mtcars, cyl == 4), aes(fill = cyl),xmin = -inf,xmax = Inf, ymin = -Inf,ymax = Inf, alpha = 0.05) +
  geom_point(aes(mpg, wt)) +  facet_grid(. ~ cyl)

在此处输入图像描述

于 2013-04-24T13:10:41.560 回答