对于以下对象:
rawData <-
structure(list(obs = c(1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L), key = structure(1:8, .Label = c("sadness",
"neutral", "contempt", "disgust", "anger", "surprise", "fear",
"happiness"), class = "factor"), value = c(2.36220472440945,
89.3700787401575, 0.393700787401575, 0.78740157480315, 0, 0.78740157480315,
0, 6.2992125984252)), .Names = c("obs", "key", "value"), row.names = c(NA,
8L), class = "data.frame")
我想在为每个条形指定颜色的同时创建一个阴谋条形图。 不幸的是,它只需要n-1种颜色,为剩余的颜色创建自己的“渐变”。
rawData %>%
group_by(obs) %>%
plot_ly(x = obs,
y = value,
type = "bar",
color = key,
colors = c("blue","grey","darkred","green","orange","black","purple"))
如果我尝试添加第8种颜色......
rawData %>%
group_by(obs) %>%
plot_ly(x = obs,
y = value,
type = "bar",
color = key,
colors = c("blue","grey","darkred","green","orange","black","purple","yellow"))
现在所有的酒吧都是黄色的。
答案 0 :(得分:4)
使用color
参数代替marker
参数。
rawData %>%
group_by(obs) %>%
plot_ly(x = obs,
y = value,
type = "bar",
color = key,
marker = list(color=c("blue","grey","darkred","green","orange","black","purple","yellow")))
答案 1 :(得分:1)
作为替代方案,您还可以使用ggplot2绘制情节图,这样可以提供您想要的效果。
p <- ggplot(data=rawData, aes(x=obs, y=value, color=key, group=key, fill=key)) + geom_bar(stat='identity', position='dodge') + scale_fill_manual(values=c("blue","grey","darkred","green","orange","black","purple","yellow")) + scale_color_manual(values=c("blue","grey","darkred","green","orange","black","purple","yellow"))
ggplotly(p)