ggplot - geom_bar 子组堆叠
ggplot - geom_bar with subgroups stacked
我正在尝试在 ggplot 中创建一个图形,其中 Round1 和 Round2 之间存在分隔,同时能够区分 Round2 中的茶点池。我正在尝试在不使用 facet wrap 或 grid 的情况下解决演示问题。
data.frame(Var1=c("old+","old+","old+","middle", "middle", "middle", "young", "young", "young"),
Round=c(1,2,2,1,2,2,1,2,2),
Refreshment=c(0,0,2,0,0,2,0,0,2),
Round_Refr=c(1.0,2.0,2.2,1.0,2.0,2.2,1.0,2.0,2.2),
pertotal=c(0.199, 0.196, 0.031, 0.459, 0.461, 0.020, 0.342, 0.343, 0.032))
我得到的最接近的是这个 - 然而它正在将每个类别(轮次和年龄组作为 X 轴上的不同组)并在第二轮之上添加茶点轮,而不是将其视为如果它是回合的一部分。
ggplot(data, aes(x = (interaction(Round,Var1)), y = pertotal)) +
geom_bar(aes(fill = Round_Refr),stat = "identity",color="white")+
scale_y_continuous(labels=percent)+ xlab("category")+
ylab("Percent of ")+ labs(fill = "Round")+
ggtitle("Plot")+
theme(plot.title = element_text(hjust = 0.5)
你知道有什么方法可以让它看起来更像下图吗?他们仍然按年龄/轮次分组,并且 Round2 的茶点池与其他受访者之间存在界限。
这是可能的,但需要一点 sleight-of-hand。您需要使用连续的 x 轴并将其标记为离散轴。这需要一些数据操作:
library(tidyverse)
data %>%
mutate(category = as.numeric(interaction(Round,Var1)),
category = category + (category %% 2)/5 - 0.1,
Round_cat = factor(Round_Refr, labels = c("1", "2", "Break")),
Round_cat = factor(Round_cat, c("Break", "1", "2"))) %>%
group_by(Var1, Round) %>%
mutate(pertotal = ifelse(Round == 2 & Refreshment == 0,
pertotal - pertotal[Round_Refr > 2], pertotal)) %>%
ggplot(aes(x = category, y = pertotal)) +
geom_col(aes(fill = Round_cat), color="white")+
scale_y_continuous(labels=scales::percent)+
scale_x_continuous(breaks = c(1.5, 3.5, 5.5),
labels = levels(factor(data$Var1))) +
xlab("category")+
ylab("Percent of ")+
labs(fill = "Round")+
ggtitle("Plot")+
scale_fill_brewer(palette = "Set1") +
theme_light(base_size = 16) +
theme(plot.title = element_text(hjust = 0.5))
我正在尝试在 ggplot 中创建一个图形,其中 Round1 和 Round2 之间存在分隔,同时能够区分 Round2 中的茶点池。我正在尝试在不使用 facet wrap 或 grid 的情况下解决演示问题。
data.frame(Var1=c("old+","old+","old+","middle", "middle", "middle", "young", "young", "young"),
Round=c(1,2,2,1,2,2,1,2,2),
Refreshment=c(0,0,2,0,0,2,0,0,2),
Round_Refr=c(1.0,2.0,2.2,1.0,2.0,2.2,1.0,2.0,2.2),
pertotal=c(0.199, 0.196, 0.031, 0.459, 0.461, 0.020, 0.342, 0.343, 0.032))
我得到的最接近的是这个 - 然而它正在将每个类别(轮次和年龄组作为 X 轴上的不同组)并在第二轮之上添加茶点轮,而不是将其视为如果它是回合的一部分。
ggplot(data, aes(x = (interaction(Round,Var1)), y = pertotal)) +
geom_bar(aes(fill = Round_Refr),stat = "identity",color="white")+
scale_y_continuous(labels=percent)+ xlab("category")+
ylab("Percent of ")+ labs(fill = "Round")+
ggtitle("Plot")+
theme(plot.title = element_text(hjust = 0.5)
你知道有什么方法可以让它看起来更像下图吗?他们仍然按年龄/轮次分组,并且 Round2 的茶点池与其他受访者之间存在界限。
这是可能的,但需要一点 sleight-of-hand。您需要使用连续的 x 轴并将其标记为离散轴。这需要一些数据操作:
library(tidyverse)
data %>%
mutate(category = as.numeric(interaction(Round,Var1)),
category = category + (category %% 2)/5 - 0.1,
Round_cat = factor(Round_Refr, labels = c("1", "2", "Break")),
Round_cat = factor(Round_cat, c("Break", "1", "2"))) %>%
group_by(Var1, Round) %>%
mutate(pertotal = ifelse(Round == 2 & Refreshment == 0,
pertotal - pertotal[Round_Refr > 2], pertotal)) %>%
ggplot(aes(x = category, y = pertotal)) +
geom_col(aes(fill = Round_cat), color="white")+
scale_y_continuous(labels=scales::percent)+
scale_x_continuous(breaks = c(1.5, 3.5, 5.5),
labels = levels(factor(data$Var1))) +
xlab("category")+
ylab("Percent of ")+
labs(fill = "Round")+
ggtitle("Plot")+
scale_fill_brewer(palette = "Set1") +
theme_light(base_size = 16) +
theme(plot.title = element_text(hjust = 0.5))