настройка меток оси ggplot2 с различными цветами

у меня есть базовая гистограмма, которую я создал из ggplot2. Переменная y содержит как положительные, так и отрицательные значения и около половины вектор значений отрицательны. Я хотел бы настроить метки оси так, чтобы, когда значение y соответствующего X-фактора отрицательно, его метка была красной. Вот воспроизводимый пример:

#Create data
x <- c("a","b","c","d","e","f")
y <- c("10", "9","-10","11","-3","-15")
data <- data.frame(x, y)
data$y <- as.numeric(as.character(data$y))

data$category <- ifelse(as.numeric(data$y)<0, 0, 1)
data$category <- as.factor(data$category)

#Graph
library(cowplot) #theme
library(ggplot2)

ggplot(data, aes(x=x, y=y)) + 
  geom_bar(stat = "identity", aes(fill=category)) +
  theme(axis.text.x = element_text(angle = 45, hjust = 1)) +
  theme(axis.text.x = element_text(colour = "black"))

enter image description here

мне нужен способ изменить цвета меток "c", "e" и " f " на цвет моего выбирающий. Я попытался переключить theme(aes(axis.text.x=element_text(colour=Air_pricier))) но это вызвало ошибку. Спасибо заранее.

1 ответов


вы можете предоставить вектор цветов для на theme():

a <- ifelse(data$category == 0, "red", "blue")

ggplot(data, aes(x = x, y = y)) + 
    geom_bar(stat = "identity", aes(fill = category)) +
    theme(axis.text.x = element_text(angle = 45, hjust = 1, colour = a))

enter image description here