Здравствуйте, у меня есть набор данных ниже:
gene_symbol <- c("DADA", "SDAASD", "SADDSD", "SDADD")
panel <- c("growth", "growth", "big", "small")
ASDDA <- c("normal", "over", "low", "over")
ASDDb <- c("normal", "over", "low", "over")
ASDDAf <- c("normal", "over", "low", "over")
Gene_states22 <- data.frame(gene_symbol, panel, ASDDA, ASDDb, ASDDAf)
Чего я хочу достичь, кроме создания тепловой карты с помощью:
library(plotly)
library(ggplot2); library(reshape2)
g <- melt(Gene_states22, id.vars = c("gene_symbol","panel"))
p1 <- ggplot(g, aes(gene_symbol,variable)) +
geom_tile(aes(fill = value), colour = "grey50") +
scale_fill_manual(values=c("white", "red", "blue"))+
labs(title = "Heatmap",x = "gene_symbol",y="sample",fill="value")+
theme(title = element_text(family = "sans serif",
size = 14,
face = "bold"),
axis.title = element_text(family = "sans serif",
size = 16,
face = "bold",
color = "black"),
axis.text = element_text(family = "sans serif",
size = 11),
axis.title.y = element_text(margin = margin(t = 0, r = 25, b = 0, l = 25)),
panel.background = element_rect(fill = NA),
panel.grid.major = element_line(colour = "grey50"))
p1
ggplotly(p1)%>%
layout(autosize = F,
width = 1450,
height = 600,
hoverlabel = list(bgcolor = "white",
font = list(family = "sans serif",
size = 9,
color = "black")))
- это сгруппировать мои значения в соответствии с panel
.Например:
здесь есть вторая ось x, которая группирует значения по «Механическому», «Электрическому», «Гидравлическому».Я хочу сделать то же самое с panel
.Обратите внимание, что график должен быть интерактивным, и поэтому я использую ggplotly()
Мне удалось использовать ответ @aosmith, но результат немного уродлив