我正在创建一个绘图图表,其中每个切片的颜色是数据框中的另一个变量。这在 ggplot2 中非常简单,但是,我很难将其转换为plotly。
我的示例代码在这里:
Product <- c("Product1","Product2","Product3","Product4","Product5","Product6","Product7")
Value <- c(1000000,200002,599996,1399994,2199992,2999990,3799988)
Rating = c(0.24, 0.28, 0.17, 0.1, 0.5, 0.6, 0.34)
df <- data.frame(Product,Value, Rating)
plot_ly(df, labels = ~Product, values = ~Value, type = 'pie', textinfo = 'label+percent',
marker = list(color = ~Rating)) %>%
layout(xaxis = list(showgrid = FALSE, zeroline = FALSE, showticklabels = FALSE),
yaxis = list(showgrid = FALSE, zeroline = FALSE, showticklabels = FALSE))
看来我没有对“颜色”属性做正确的事情。我希望有一个连续的比例配色方案,最好是当评级变量接近 0 时为红色,当评级变量接近 1 时为绿色。
谢谢。
最佳答案
你可以
对数据框进行排序
sorted_df <- df[order(df$Rating),]
使用
colorRampPalette
添加自定义颜色gradient <- colorRampPalette(c('red', 'green')) sorted_df$colors <- gradient(dim(df)[1])[as.numeric(cut(sorted_df$Rating, breaks = dim(df)[1]))]
为绘图指定颜色
marker = list(colors = ~colors)
色阶可以进行一些调整。
Product <- c("Product1","Product2","Product3","Product4","Product5","Product6","Product7")
Value <- c(1000000,200002,599996,1399994,2199992,2999990,3799988)
Rating = c(0.24, 0.28, 0.17, 0.1, 0.5, 0.6, 0.34)
df <- data.frame(Product,Value, Rating)
sorted_df <- df[order(df$Rating),]
gradient <- colorRampPalette(c('red', 'green'))
sorted_df$colors <- gradient(dim(df)[1])[as.numeric(cut(sorted_df$Rating,
breaks = dim(df)[1]))]
plot_ly(sorted_df, labels = ~Product, values = ~Value, type = 'pie', textinfo = 'label+percent',
marker = list(colors = ~colors)) %>%
layout(xaxis = list(showgrid = FALSE, zeroline = FALSE, showticklabels = FALSE),
yaxis = list(showgrid = FALSE, zeroline = FALSE, showticklabels = FALSE))
关于r - Plotly - 创建具有连续色阶的饼图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50625970/