前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >GGplot绘制个性化热图

GGplot绘制个性化热图

作者头像
生信技能树jimmy
发布2023-09-26 20:28:15
2760
发布2023-09-26 20:28:15
举报
文章被收录于专栏:单细胞天地单细胞天地

本文内容:

  • ggplot2绘制热图
  • 热图展示方格为方块
  • 热图分面、添加标记
  • 换行长字符
  • 配色
  • 热图展示为点图

加载R包

代码语言:javascript
复制
pkgs = c('tidyverse', 'forcats', 'gtools', 'ggplot2', 'ggpubr', 'cowplot', 
         'scales', 'ggsci', 'viridis', 'hrbrthemes', 'Cairo', 'common')
# install.packages('pkgs')
inst = lapply(pkgs, library, character.only = TRUE)

读取或创建数据

代码语言:javascript
复制
strings <- paste0('C', 1:5)
data <- data.frame(
  day = 1:12,
  type.name = c(rep(c('A', 'B'), each = 6)),
  condition = c('Control Group', 'Experimental Group1', 'Experimental Group2'),
  Dilution = rep(c(1:2), each = 3),
  Dilution1 = sample(strings, 12, replace = T),
  Dilution2 = sample(strings, 12, replace = T),
  Dilution3 = sample(strings, 12, replace = T)
)

data %>%
  slice(1:3)

绘图

1、绘制热图

代码语言:javascript
复制
p <- data %>%
  gather(key, value, paste0('Dilution', 1:3)) %>%
  unite(condition, condition, Dilution, sep = ' ') %>%
  ggplot(aes(x = key, y = condition)) +
  geom_tile(aes(fill = value), color = 'white', size = 1)
p

2、调整方格为方块

代码语言:javascript
复制
p1 <- p + coord_fixed() 
p1

3、热图分面

代码语言:javascript
复制
p2 <- p1 + facet_wrap(~type.name) 
p2

4、热图添加标记

代码语言:javascript
复制
p3 <- p2 + geom_text(aes(label = value), color = 'black', size = 4)
p3

5、字符换行

代码语言:javascript
复制
p4 <- p3 + scale_y_discrete(labels = label_wrap(10))
p4

6、配色

代码语言:javascript
复制
p4 + theme_classic2(base_size = 16) + scale_fill_simpsons() +
  theme(axis.text.x = element_text (angle = 45, vjust = 1, hjust=1)) 

7、用点绘制热图

代码语言:javascript
复制
# 用点绘制热图,颜色为分类变量
data %>%
  gather(key, value, paste0('Dilution', 1:3)) %>%
  unite(condition, condition, Dilution, sep = ' ') %>%
  ggplot(aes(x = key, y = condition)) +
  coord_fixed() +
  facet_wrap(~ type.name) +
  geom_point(aes(size = value, color = value)) +
  theme_bw() +
  theme(panel.border = element_rect(fill=NA, color="black", size=1, linetype="solid")) + 
  theme(panel.grid = element_blank(),
        axis.text.x =element_text(angle =90, hjust =0.5, vjust = 0.5)) +
  theme_classic2(base_size = 16) + 
  scale_color_simpsons() +
  theme(axis.text.x = element_text (angle = 45, vjust = 1, hjust=1))

8、用点绘制热图2

代码语言:javascript
复制
# 用点绘制热图,颜色为连续变量
data.d <- data %>%
  gather(key, value, paste0('Dilution', 1:3)) %>%
  unite(condition, condition, Dilution, sep = ' ') %>%
  # charactor to factor, factor to numeric
  mutate(value = as.numeric(factor(value)))

data.d %>%
  ggplot(aes(x = key, y = condition)) + 
  coord_fixed() +
  facet_wrap(~ type.name) +
  geom_point(aes(size = value, color = value)) +
  theme_bw() +
  theme(panel.border = element_rect(fill=NA, color="black", size=1, linetype="solid")) + 
  theme(panel.grid = element_blank(),
        axis.text.x =element_text(angle =90, hjust =0.5, vjust = 0.5)) +
  theme_classic2(base_size = 16) + 
  scale_color_gradientn(colours = c('#6699CC','#FFFF99','#CC3333')) +
  theme(axis.text.x = element_text (angle = 45, vjust = 1, hjust=1))

参考

  • [ggplot2绘制个性化热图](https://zhuanlan.zhihu.com/p/442663764)
  • [ggplot2合并共享坐标轴的图片](https://aosmith.rbind.io/2019/05/13/small-multiples-plot/#using-facets-for-small-multiples)
  • [Heat map in ggplot2](https://r-charts.com/correlation/heat-map-ggplot2/#:~:text=%23%20install.packages%20%28%22ggplot2%22%29%20library%28ggplot2%29%20ggplot%28df%2C%20aes%28x%20%3D%20x%2C,to%20the%20label%20argument%20of%20the%20aes%20function.)
  • [Quick and easy ways to deal with long labels in ggplot2](https://www.andrewheiss.com/blog/2022/06/23/long-labels-ggplot/)
本文参与?腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-06-26 22:00,如有侵权请联系?cloudcommunity@tencent.com 删除

本文分享自 单细胞天地 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 加载R包
  • 读取或创建数据
  • 绘图
    • 1、绘制热图
      • 2、调整方格为方块
        • 3、热图分面
          • 4、热图添加标记
            • 5、字符换行
              • 6、配色
                • 7、用点绘制热图
                  • 8、用点绘制热图2
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
                  http://www.vxiaotou.com