R语言ggplot2漂亮的热图和配色 简单小例子
2021-04-14 本文已影响0人
小明的数据分析笔记本
偶然间在github 上发现的这个链接,示例数据和代码都有,很好的R语言学习素材 链接是 https://github.com/blmoore/blogR ,主要内容有
data:image/s3,"s3://crabby-images/55d60/55d6095bd1e5a177cd021784280ffdaf0291fcea" alt=""
光看这个可能有些枯燥,我们来看结果图
data:image/s3,"s3://crabby-images/75274/752744dd30b85f0c65663b692fd51ece7fe7143a" alt=""
data:image/s3,"s3://crabby-images/8d675/8d675c6cad45b722caaad62f840d87a62ac6cd96" alt=""
data:image/s3,"s3://crabby-images/9d36a/9d36a82e9a068d99aa9e22dbb344fc8b9f0c2a46" alt=""
data:image/s3,"s3://crabby-images/6e88c/6e88c222bb077d7fee7db312f77e814ebc836afd" alt=""
data:image/s3,"s3://crabby-images/0cb7b/0cb7ba43b2b349ee13ffddcd57d74278195d5c19" alt=""
data:image/s3,"s3://crabby-images/4f7ef/4f7ef7a6899b682cb120776c03ff63f2fb276e2c" alt=""
这些看起来是不是还挺酷炫的,接下来的推文争取把这些图片对应的代码全部重复一遍,今天重复这个热图
这个图具体的数据是什么意思暂时还没太看明白,最终用于作图的数据格式如下
data:image/s3,"s3://crabby-images/c44ea/c44ea7fc955854cde23c5915eda3cb093d5cd6f3" alt=""
前半部分准备数据的代码这里就不介绍了
data:image/s3,"s3://crabby-images/fa6f2/fa6f21fdedfecd5f755a8c119223b1758b12f62b" alt=""
准备数据的过程可能稍微有点枯燥,大家感兴趣的话可以自己研究研究
我们直接运行画图代码
加载ggplot2
library(ggplot2)
最基本的热图
ggplot(mdf, aes(y=state, x=year, fill=c)) +
geom_tile()
data:image/s3,"s3://crabby-images/8a926/8a926c9e5493968b615fbc4c0b9e91b4546e04c5" alt=""
调整热图方块的一些内容
ggplot(mdf, aes(y=state, x=year, fill=c)) +
geom_tile(colour="white",
#linewidth=2,
width=.9,
height=.9)
data:image/s3,"s3://crabby-images/35c44/35c44ba1e9ee65a9a2b1a305ca7617d769bf5ed6" alt=""
这里原来热图对应的小单元格高和宽是都可以调整的
调整热图的颜色和图例
ggplot(mdf, aes(y=state, x=year, fill=c)) +
geom_tile(colour="white",
#linewidth=2,
width=.9,
height=.9)+
theme_minimal()+
scale_fill_gradientn(colours=cols, limits=c(0, 4000),
breaks=seq(0, 4e3, by=1e3),
na.value=rgb(246, 246, 246, max=255),
labels=c("0k", "1k", "2k", "3k", "4k"),
guide=guide_colourbar(ticks=T,
nbin=50,
barheight=.5,
label=T,
barwidth=10))+
theme(legend.position = "top")
data:image/s3,"s3://crabby-images/ff003/ff003ab99825ecc360c452ca5de16e233fc8d4b2" alt=""
最终的结果
ggplot(mdf, aes(y=state, x=year, fill=c)) +
geom_tile(colour="white",
#linewidth=2,
width=.9,
height=.9)+
theme_minimal()+
scale_fill_gradientn(colours=cols, limits=c(0, 4000),
breaks=seq(0, 4e3, by=1e3),
na.value=rgb(246, 246, 246, max=255),
labels=c("0k", "1k", "2k", "3k", "4k"),
guide=guide_colourbar(ticks=T,
nbin=50,
barheight=.5,
label=T,
barwidth=10))+
#theme(legend.position = "top")+
scale_x_continuous(expand=c(0,0),
breaks=seq(1930, 2010, by=10)) +
geom_segment(x=1963, xend=1963, y=0, yend=51.5, size=.9, lineend = "round") +
labs(x="", y="", fill="") +
ggtitle("Measles") +
theme(legend.position=c(.5, -.13),
legend.direction="horizontal",
legend.text=element_text(colour="grey20"),
plot.margin=grid::unit(c(.5,.5,1.5,.5), "cm"),
axis.text.y=element_text(size=6,
#family="Helvetica",
hjust=1),
axis.text.x=element_text(size=8),
axis.line.x=element_line(colour="grey20",
size=0.5),
#axis.ticks.y=element_blank(),
#axis.ticks.x=element_blank(),
#axis.ticks.length=grid::unit(1, "cm"),
panel.grid=element_blank(),
title=element_text(hjust=-.07,
face="bold",
vjust=1)) +
annotate("text", label="Vaccine introduced",
x=1963, y=53, vjust=1, hjust=0,
size=I(3))
data:image/s3,"s3://crabby-images/448bd/448bd16e5b9fb999d5dd4aef2623ef840d89bbc0" alt=""
这个热图最终还挺漂亮的
欢迎大家关注我的公众号
小明的数据分析笔记本
小明的数据分析笔记本 公众号 主要分享:1、R语言和python做数据分析和数据可视化的简单小例子;2、园艺植物相关转录组学、基因组学、群体遗传学文献阅读笔记;3、生物信息学入门学习资料及自己的学习笔记!