如何在ggplot中为独立图层缩放颜色?

Mic*_*eet 3 r scale ggplot2

我有一个数据集记录了三栋建筑的能源使用情况.我有一个融化的数据框,可以从钻石集合中模仿:

data <- melt(diamonds[,c('depth','table','cut','color')],id=c('cut','color'))
Run Code Online (Sandbox Code Playgroud)

基本上,我从三个不同的建筑物(7'颜色'因素)每个月('切割')有加热('深度')和冷却('表')数据.我想在每个月的条形图中并排绘制三个建筑物(7'颜色'因子)('cut').

我希望代表冷却('表')或加热('深度')的条形根据建筑物('颜色'因子)改变它们的阴影,同时保持按月分组('切割').这是一种可视化钻石数据的坏方法,但应该适用于建筑物,因为它们的加热和冷却月份通常不会重叠.到目前为止,我有:

p <- ggplot(data,
        aes(color,value,group=cut))
p <- p + geom_bar(stat = 'identity',
              position = 'dodge',
              aes(fill = variable))
print(p)
Run Code Online (Sandbox Code Playgroud)

我尝试使用scale_fill_manual,但无法想到一个有效的策略:

colours <- c('#0000FF', '#0033FF', '#0066FF', '#FF0000', '#FF3300', '#FF6600')

p <- p + scale_fill_manual(values = colours,
                           group = data$variable)
Run Code Online (Sandbox Code Playgroud)

Bri*_*ggs 6

有些诡计,这是可能的.导出基于钻石的数据集是非常好的,但我想使用较小的数据集

set.seed(1234)
data <-
expand.grid(month = month.abb,
            building = c("Building A", "Building B", "Building C"),
            hc = c("Heating", "Cooling"))
data$value <- rnorm(nrow(data), 60, 10)
Run Code Online (Sandbox Code Playgroud)

您希望填充颜色基于变量(hc)和构建(building),因此将其设置为该交互.

ggplot(data, aes(building,value,group=month)) + 
  geom_bar(stat = 'identity',
           position = 'dodge',
           aes(fill = interaction(building, hc)))
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

我们可以选择代表不同近色调的颜色,使它们更像您想要的颜色.我使用了RColorBrewer调色板的"蓝调"和"红色"的中间部分.

colours <- c("#FC9272", "#FB6A4A", "#EF3B2C", "#9ECAE1", "#6BAED6", "#4292C6")
# library("RColorBrewer")
# colours <- c(brewer.pal(9,"Reds")[4:6], brewer.pal(9,"Blues")[4:6])
Run Code Online (Sandbox Code Playgroud)

并用于scale_fill_manual分配这些颜色.

ggplot(data, aes(building,value,group=month)) + 
  geom_bar(stat = 'identity',
           position = 'dodge',
           aes(fill = interaction(building, hc))) +
  scale_fill_manual(values=colours)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

真正的诡计在于让传奇更难以解决.我只列出了2个级别(中间建筑的颜色)并给它们不同的名称(以及图例的不同标题).

ggplot(data, aes(building,value,group=month)) + 
  geom_bar(stat = 'identity',
           position = 'dodge',
           aes(fill = interaction(building, hc))) +
  scale_fill_manual("Heating/cooling",
                    values=colours,
                    breaks=c("Building B.Heating", "Building B.Cooling"),
                    labels=c("Heating", "Cooling"))
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述