R语言画热图时如何实现图例legend过多超出画图边界
这篇文章将为大家详细讲解有关R语言画热图时如何实现图例legend过多超出画图边界,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
为钟山等地区用户提供了全套网页设计制作服务,及钟山网站建设行业解决方案。主营业务为成都网站建设、成都网站设计、钟山网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
示例代码
test = matrix(rnorm(200), 20, 10)
test[1:10, seq(1, 10, 2)] = test[1:10, seq(1, 10, 2)] + 3
test[11:20, seq(2, 10, 2)] = test[11:20, seq(2, 10, 2)] + 2
test[15:20, seq(2, 10, 2)] = test[15:20, seq(2, 10, 2)] + 4
colnames(test) = paste("Test", 1:10, sep = "")
rownames(test) = paste("Gene", 1:20, sep = "")
annotation_col<-data.frame(group=factor(c(rep("A",5),rep("B",5))))
rownames(annotation_col)<-paste0("Test",1:10)
library(pheatmap)
pheatmap(test,cluster_rows = F,cluster_cols = F,
annotation_col = annotation_col)
但是如果添加多组注释信息的话,他的图例是从上到下依次排列,如果太多图例就会超过绘图边界,比如
annotation_col<-data.frame(group=factor(c(rep("A",5),rep("B",5))),
group_1=factor(LETTERS[1:10]),
group_2=factor(letters[1:10]),
group_3=factor(rep(c("CT1","CT2"),5)))
rownames(annotation_col)<-paste0("Test",1:10)
pheatmap(test,cluster_rows = F,cluster_cols = F,
annotation_col = annotation_col)
我有四个图例需要展示,但是这张图只出现了3个
当然可以通过增加图片的高度让第四个图例显示出来
但是如果注释信息再多也不能够一直拉长图片高度呀!
有一个办法是更改图例的大小,但是没有找到参数来调节。
还有一个办法是:现在图例的单列,能不能改为多列显示?也没有找到参数调节
还有一个办法是不用这个函数了,换ComplexHeatmap包中的Heatmap函数 示例代码
mat = matrix(rnorm(100), 10)
rownames(mat) = paste0("R", 1:10)
colnames(mat) = paste0("C", 1:10)
library(ComplexHeatmap)
Heatmap(mat)
column_ha = HeatmapAnnotation(foo1 = runif(10),
foo2=rep(c("A","B"),5),
foo3=rep(letters[1:5],2),
foo4=LETTERS[1:10],
foo5=letters[1:10],
foo6=LETTERS[1:10])
column_ha
Heatmap(mat,top_annotation = column_ha,
cluster_columns = F,
cluster_rows = F)
他的图例自动就换为两列了
关于“R语言画热图时如何实现图例legend过多超出画图边界”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
网页名称:R语言画热图时如何实现图例legend过多超出画图边界
文章分享:http://hbruida.cn/article/jipcds.html