跟着Nature Genetics学画图~ggplot2画堆积柱
2021-01-20 本文已影响0人
小明的数据分析笔记本
data:image/s3,"s3://crabby-images/5dc95/5dc95871d5e866a550463e02680a83ddb8836e44" alt=""
最近在看论文 Phased diploid genome assemblies and pan-genomes provide insights into the genetic history of apple domestication(高水平论文看起来还真是吃力!)看懂一点记一点吧。今天的笔记记录的是论文中Figure2图d中的堆积柱形图的画法,(本来今天的推文也计划将右侧的散点图拼接到堆积柱形图的右侧的内容也记一下的,但是实现的时候遇到一些问题,暂时还没有重复出来,等到有办法了再来记录)
data:image/s3,"s3://crabby-images/a5390/a53905b151730e91121c689e8e795996d230b535" alt=""
做堆积柱形图参考 https://www.datanovia.com/en/blog/how-to-create-a-ggplot-stacked-bar-chart-2/
第一步准备数据
数据总共三列,
需要示例数据可以直接在文末留言
data:image/s3,"s3://crabby-images/7f660/7f660000e38102ee0de6a1cf036537619b66c6b0" alt=""
读入数据
df<-read.csv("NG_stacked_barplot_example.csv",
header = T)
head(df)
基本的堆积柱形图
library(ggplot2)
ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))
data:image/s3,"s3://crabby-images/fbea8/fbea854e050f4782148c960284b20ca9f79fe946" alt=""
旋转图形
ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))+
coord_flip()
data:image/s3,"s3://crabby-images/4e902/4e9020a0bdcfc74b603901191241f71d20955c51" alt=""
更改图例的位置到最底部
ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))+
coord_flip()+
theme(legend.justification = c(0,0))
data:image/s3,"s3://crabby-images/34e2f/34e2fe7465d48d61fee7ca496deca7136f8a1bdb" alt=""
更改配色
ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))+
coord_flip()+
theme(legend.justification = c(0,0))+
scale_fill_manual(values = c("#6cc396","#9896ca"))
data:image/s3,"s3://crabby-images/06ec5/06ec5af37e91fc2a97098349aec6de11f71dfdef" alt=""
更改坐标轴的标题
ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))+
coord_flip()+
theme(legend.justification = c(0,0))+
scale_fill_manual(values = c("#6cc396","#9896ca"))+
labs(x=expression(paste(italic("M. domestica"),
" accession")),
y="Fraction of nuclear genome")
data:image/s3,"s3://crabby-images/e0909/e09090afdc4ce759c2e7bf7efc37ad135d9d9f63" alt=""
将y轴的标题离文字标签远一点
ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))+
coord_flip()+
theme(legend.justification = c(0,0),
axis.title.y = element_text(vjust=5),
plot.margin = unit(c(0.1,0.1,0.1,0.5),"cm"))+
scale_fill_manual(values = c("#6cc396","#9896ca"))+
labs(x=expression(paste(italic("M. domestica"),
" accession")),
y="Fraction of nuclear genome")
data:image/s3,"s3://crabby-images/3096a/3096a7c97d10e21135746e439e4d23db956ebaa9" alt=""
简单美化,去掉灰色背景,去掉网格线,更改一些图例的字体
library(ggplot2)
library(Cairo)
p1<-ggplot(df,aes(x=x,y=y))+
geom_col(aes(fill=Origin))+
coord_flip()+
theme_bw()+
theme(legend.justification = c(0,0),
axis.title.y = element_text(vjust=5),
plot.margin = unit(c(0.1,0.1,0.1,0.5),"cm"),
panel.grid = element_blank(),
legend.text = element_text(family = "Comic Sans MS"))+
scale_fill_manual(values = c("#6cc396","#9896ca"))+
labs(x=expression(paste(italic("M. domestica"),
" accession")),
y="Fraction of nuclear genome")
ggsave("Rplot10.pdf",p1,device = cairo_pdf)
data:image/s3,"s3://crabby-images/1c158/1c158f4a9b8a899421989d4a71321518df217e83" alt=""
但是这里遇到一个问题是:如何将图例的字体更改为斜体呢?暂时还没有想到比较好的办法
欢迎大家关注我的公众号
小明的数据分析笔记本