如何解决水平粘贴ggplot对象
我正在尝试将 16 个不同的图粘贴到一个具有公共 x 轴的图
我成功地使用 grid.draw() 单独制作、绘制和粘贴了图形
但我无法以连续的方式变换 x 轴或至少去除每个图形之间的空间
我附上了一些代码来说明图表是如何制作的。
plot1 = ggplot(map_snp %>% filter( chr == chr[1] ),aes(x=POS)) +
geom_histogram( binwidth = 2,col=palette[2],fill=palette[2],alpha = .2) +
xlab("Chromosome 1") +
ylab("SNP count") +
theme_bw() +
theme(axis.text.x = element_text(angle = 0,colour = "black"),text=element_text(family="Times New Roman",size = 12),panel.border = element_blank(),panel.grid.major = element_blank(),panel.grid.minor = element_blank(),axis.line.y = element_line(colour = "black"),axis.line.x = element_line(colour = "black"))
par_plots <- list()
for (i in list_par) {
par_plots[[i]] = ggplot(map_snp %>% filter( chr == i ),aes(x=POS)) +
geom_histogram( binwidth = 2,col= palette[3],fill= palette[3],alpha = .2) +
xlab(paste0(i)) +
theme_bw() +
theme(axis.text.x = element_text(angle = 0,axis.line.y = element_blank(),axis.title.y = element_blank(),axis.text.y = element_blank(),axis.ticks.y = element_blank(),axis.line.x = element_line(colour = "black"))
}
impar_plots <- list()
for (i in list_impar) {
impar_plots[[i]] = ggplot(map_snp %>% filter( chr == i ),col= palette[2],alpha = .2) +
xlab(paste0(i)) +
theme_bw() +
theme(axis.text.x = element_text(angle = 0,axis.line.x = element_line(colour = "black"))
}
grid.newpage()
png(paste("./snp_map.png"),width = 15*4.5,height = 8,res = 320,units = "cm",pointsize = 12,bg = "white")
grid.draw(cbind(ggplotGrob(plot1),ggplotGrob(par_plots$`Chromosome 2`),ggplotGrob(impar_plots$`Chromosome 3`),ggplotGrob(par_plots$`Chromosome 4`),ggplotGrob(impar_plots$`Chromosome 5`),ggplotGrob(par_plots$`Chromosome 6`),ggplotGrob(impar_plots$`Chromosome 7`),ggplotGrob(par_plots$`Chromosome 8`),ggplotGrob(impar_plots$`Chromosome 9`),ggplotGrob(par_plots$`Chromosome 10`),ggplotGrob(impar_plots$`Chromosome 11`),ggplotGrob(par_plots$`Chromosome 12`),ggplotGrob(impar_plots$`Chromosome 13`),ggplotGrob(par_plots$`Chromosome 14`),ggplotGrob(impar_plots$`Chromosome 15`),ggplotGrob(par_plots$`Chromosome 16`),size = "last"))
dev.off()
单核苷酸多态性图
解决方法
我可以去掉大部分边界,但不能全部去掉。这里使用来自 diamonds
的内置 ggplot2
数据集的示例。
par_plots <- list()
cuts = unique(diamonds$cut)
for (c in as.numeric(cuts)) {
par_plots[[c]] = ggplot(diamonds %>% filter(as.numeric(cut) == c),aes(x = price)) +
geom_histogram() +
scale_x_continuous(expand = expansion(0)) +
xlab(paste0(i)) +
theme_classic() +
theme(axis.text.x = element_text(angle = 0,colour = "black"),text=element_text(family="Times New Roman",size = 12),plot.margin = unit(c(0,0),"cm"),panel.border = element_blank(),panel.grid.major = element_blank(),panel.grid.minor = element_blank(),axis.line.y = element_blank(),axis.title.y = element_blank(),axis.text.y = element_blank(),axis.ticks.y = element_blank(),axis.line.x = element_line(colour = "black"))
}
library(grid)
grid.newpage()
# png(paste("./snp_map.png"),width = 15*4.5,height = 8,res = 320,units = "cm",pointsize = 12,bg = "white")
grid.draw(cbind(ggplotGrob(par_plots[[1]]),ggplotGrob(par_plots[[2]]),ggplotGrob(par_plots[[3]]),ggplotGrob(par_plots[[4]])))
dev.off()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。