用多种颜色为轴刻度文本着色

dan*_*dan 1 r heatmap axis-labels plotly

我正在尝试绘制heatmapusingRplotly包,我希望在其中对 y 轴刻度文本的特定标签具有特定的颜色。

这是一个示例数据集:

set.seed(1)
df <- reshape2::melt(matrix(rnorm(100),10,10,dimnames = list(paste0("G",1:10),paste0("S",1:10))))
Run Code Online (Sandbox Code Playgroud)

这就是我正在尝试的:

library(plotly)
library(dplyr)
plot_ly(z=c(df$value),x=df$Var2,y=df$Var1,colors=grDevices::colorRamp(c("darkblue","gray","darkred")),type="heatmap",colorbar=list(title="Scaled Value",len=0.4)) %>%
  layout(yaxis=list(title=list(color=c(rep("darkred",5),rep("darkblue",5)))))
Run Code Online (Sandbox Code Playgroud)

它不起作用,因为我得到: 在此处输入图片说明

改变: yaxis=list(title=list(color=c(rep("darkred",5),rep("darkblue",5))))

到: yaxis=list(title=list(color=list(c(rep("darkred",5),rep("darkblue",5)))))

或者: yaxis=list(title=list(tickcolor=c(rep("darkred",5),rep("darkblue",5))))

或者: yaxis=list(title=list(tickcolor=list(c(rep("darkred",5),rep("darkblue",5)))))

似乎没有帮助。

任何的想法?

ves*_*and 6

在此处针对 Python 提出并回答了具有不同设置的类似问题:为特定 x 轴刻度设置不同的字体颜色。下面是我对 R 设置的最佳尝试。

阴谋:

在此处输入图片说明

代码:

library(plotly)
library(dplyr)

# data
set.seed(1)
df <- reshape2::melt(matrix(rnorm(100),10,10,dimnames = list(paste0("G",1:10),paste0("S",1:10))))

# plotly setup
p1 <- plot_ly(z=c(df$value),x=df$Var2,y=df$Var1,colors=grDevices::colorRamp(c("darkblue","gray","darkred")),
              type="heatmap",colorbar=list(title="Scaled Value",len=0.4)) 

p2 <- p1 %>% add_trace(xaxis='x2', showscale=FALSE)

p3 <- p2  %>% layout(xaxis=list(range=list(0,9),
                                tickvals=list(0,1,2,3,4),
                                tickfont=list(color='red')),
                     xaxis2=list(range=list(0,9), overlaying='x',
                                 ticktext = list('s9', 's10'),
                                 tickvals=list(5, 6, 7, 8, 9),
                                 tickfont=list(color='blue')))
# plot it
p3
Run Code Online (Sandbox Code Playgroud)