我正在尝试使用ggplot创建几个图形.这些图是一系列条形图,它们一起描述了一条线以及例子 (BTW,是的,我意识到调色板是丑陋的,它是色盲友好的,这对我的观众很重要)
我的问题是我需要制作其中的几个图表,并希望颜色在所有图形中保持一致.由于"Type"变量在我将要使用的几个数据集中以不同的顺序出现,我需要为每种类型手动设置颜色.我认为这个问题:如何在ggplot2直方图中手动填充颜色会得到答案,但是当我尝试时,它会将图例中的名称更改为颜色的十六进制定义,但颜色本身会返回到ggplot的默认值调色板.
这是我到目前为止的代码:
cbbPalette <- c("#000000", "#E69F00", "#56B4E9", "#009E73", "#F0E442", "#0072B2", "#D55E00", "#CC79A7")
ggplot()+
scale_fill_manual(values=cbbPalette)+
geom_bar(data=subset(eten, Type=="Waste Wood"), aes(x=Tprod, y=acost, fill=cbbPalette[1], width=MGGEY+25), stat="identity")+
geom_bar(data=subset(eten, Type=="Agricultural Residue"), aes(x=Tprod, y=acost, fill=cbbPalette[2], width=MGGEY+25), stat="identity")+
geom_bar(data=subset(eten, Type=="Forest Residue"), aes(x=Tprod, y=acost, fill=cbbPalette[3], width=MGGEY+25), stat="identity")+
geom_bar(data=subset(eten, Type=="Herbaceous Energy Crop"), aes(x=Tprod, y=acost, fill=cbbPalette[4], width=MGGEY+25), stat="identity")+
geom_bar(data=subset(eten, Type=="MSW"), aes(x=Tprod, y=acost, fill=cbbPalette[5], width=MGGEY+25), stat="identity")+
scale_y_continuous("Average Cost", labels = dollar, expand=c(0,0))+
scale_x_continuous("Million Gallons of Gasoline Equivalent", expand=c(0,0))+
theme(legend.position="bottom", panel.background=element_rect(colour = NA, fill = "white"), axis.line=element_line(), panel.grid.major.y=element_line(colour="black"), panel.grid.minor=element_blank())
Run Code Online (Sandbox Code Playgroud)
我的R专业水平相当低,所以我可能会遗漏一些简单的东西,但我不能让它独立工作.在此先感谢您的帮助.
更新:我无意中粘贴了不正确的代码版本,"填充"命令又回到了我最好的猜测.这里有一个示例数据集.
我猜你已经看过这里显示的ggplot色盲示例了吗?如果没有您的数据,我只能推测您的geom_bar调用会产生关于应用填充更改的层的歧义,因为您对ggplot的初始调用没有aes参数.尝试将所有数据移动到单个数据帧中,并在初始调用ggplot时引用它,例如,
ggplot(df, aes(x=cond, y=yval)) +
geom_bar() +
scale_fill_manual(values=cbbPalette)
Run Code Online (Sandbox Code Playgroud)
其中df是包含数据的数据框,而aes是变量之间的映射.这使得ggplot明确表示你希望geom_bar的填充颜色与df中的数据相对应.有一些方法可以使用当前的代码,但它们对于创建标准条形图是非常规的.
Jay B. Martin的回答并没有完全回答这个问题。所以虽然这个问题已经很老了,但这里有一个解决方案供将来参考。我们为一个可重复的例子制作了一些数据:
color_table <- tibble(
Land_cover = c("Agriculture", "Forest", "Ocean", "Lake", "Populated"),
Color = c("yellow", "darkgreen", "blue4", "lightblue", "maroon3")
)
df <- data.frame(
Region = c(rep(1,5), rep(2,5)),
Area_no = c(1,2,3,4,5,1,2,3,4,5),
Land_cover = c("Agriculture", "Forest", "Agriculture", "Agriculture", "Lake",
"Lake", "Populated", "Populated", "Ocean", "Populated"),
Square_km = c(10,15,7,12,3, 5,30,20,40,10)
)
Run Code Online (Sandbox Code Playgroud)
所以,我们想用df为每个 制作一个图表Region,其中Land_cover由 给出的正确颜色表示color_table。首先,我们必须确保Land_cover数据集中的df变量是一个因子变量,其顺序与我们要放在每种土地覆盖类型上的颜色相同。我们通过使用以下命令来做到这一点color_table:
df$Land_cover <- factor(df$Land_cover, levels = color_table$Land_cover)
Run Code Online (Sandbox Code Playgroud)
现在,使用正确颜色进行绘图的最简单方法是,正如 Jay B. Martin 在评论中所建议的那样,使用 facet_grid() 或 facet_wrap():
ggplot(df, aes(x = Area_no, y = Square_km, fill = Land_cover)) +
geom_col() +
scale_fill_manual(values = color_table$Color) +
facet_grid(.~Region)
Run Code Online (Sandbox Code Playgroud)
但是如果你想为每个 Region 制作一个单独的图怎么办?例如,您想将每个图保存为一个单独的文件。
如果我们基本上做一个小循环,选择数据的一个子集并重用我们上面使用的代码(除了facet_grid),我们显然会得到错误的颜色(此处显示的是区域 2):
for (region in 1:2){
gg <- ggplot(subset(df, Region %in% region), aes(x = Area_no, y = Square_km, fill =
Land_cover)) +
geom_col() +
scale_fill_manual(values = color_table$Color)
ggsave(paste0("Areas_region_", region, ".png"), width = 5, height = 3)
}
Run Code Online (Sandbox Code Playgroud)
有两种方法可以获得正确的颜色:
添加drop = FALSE内部scale_fill_manual是迄今为止最简单的。然后您将获得 corrcet 颜色,图例将显示所有可能的类别,而不仅仅是图中的类别:
for (region in 1:2){
gg <- ggplot(subset(df, Region %in% region), aes(x = Area_no, y = Square_km, fill =
Land_cover)) +
geom_col() +
scale_fill_manual(values = color_table$Color, drop = FALSE)
ggsave(paste0("Areas_region_", region, ".png"), width = 5, height = 3)
}
Run Code Online (Sandbox Code Playgroud)
如果由于某种原因您不希望图例显示所有可能的类别(例如,如果它们的数量很大),则需要为每个图选择正确的颜色:
library(magrittr)
for (region in 1:2){
df_plot <- subset(df, Region %in% region)
actual_cover <- df_plot$Land_cover %>% as.numeric() %>% table() %>% names() %>% as.numeric()
gg <- ggplot(df_plot, aes(x = Area_no, y = Square_km, fill = Land_cover)) +
geom_col() +
scale_fill_manual(values = color_table$Color[actual_cover])
ggsave(paste0("Areas_region_", region, "ver3.png"), width = 5, height = 3)
}
Run Code Online (Sandbox Code Playgroud)
我们在这里实际做的是制作一个向量actual_cover,其中包含当前绘图中实际使用的颜色(编号 1-6)。因此,图例仅包含图中存在的类别,而颜色仍然正确。
| 归档时间: |
|
| 查看次数: |
36585 次 |
| 最近记录: |