推广

清明节后第一天从画一张图开始

iseeyu2年前 (2024-02-21)推广121

11.png

来吧,这个图的复现不见得简单,不信大家可以尝试一下:

首先来学习一下ggrepel包

用法是geom_text(label)_repel(aes(x,y,label=,….)),text和label的区别我在这里就不多说了,大家都应该知道
我们主要来学习一下参数:

segment.color:连接点与标签的线段的颜色
segment.size:线段的粗细
segment.alpha:线段的透明度
box.padding:文本框周边填充
point.padding:点周围填充
arrow:grid:arrow提供的箭头
force:强制性将重叠文本散开
max.oter:最大迭代次数
nudge_x/y:标签开始位置在坐标轴的移动距离
direction:允许标签的方向,x、y or both

接下来我们要开始这张图的复现了。

首先加载包

library(ggplot)
library(repel)

文件的准备

图片.png

是不是很熟悉??? 就是Seurat的差异分析的结果

为了复现这张图,我们需要对数据进行一定的处理
添加P值标签和label

x$label = ifelse(x$p_val_adj < 0.01 , "adjusted P-val < 0.01","adjusted P-val >= 0.01")
y  =   0.00001
x$gene = ifelse(x$p_val_adj < y , x$gene_name,"")

数据里多了两列label和gene

接下来,我们要画图了

p = ggplot(x,aes(x$cluster,x$avg_logFC,color = x$label,size = 1)) + geom_jitter()

图片.png

添加标签

p = p + geom_text_repel(aes(x$cluster,x$avg_logFC,label = x$gene))

图片.png

gene的标签太多了,我们适当减少一点

y = 0.0000000000001
ggplot(x,aes(x$cluster,x$avg_logFC,color = x$label)) + geom_jitter(size = 0.5) + geom_text_repel(aes(x$cluster,x$avg_logFC,label = x$gene))

图片.png

但是大家发现了没有,gene的标签字体是红色,我们需要黑色

ggplot(x,aes(x$cluster,x$avg_logFC,color = x$label)) + geom_jitter(size = 0.5) + geom_text_repel(aes(x$cluster,x$avg_logFC,label = x$gene,color = 'black'))

图片.png

可见,设置color不听指挥,这是什么原因呢?听过我讲R语言课程的同学应该知道,绘图对象对我们后续的操作产生了干扰,我们需要调整一下

p = ggplot(x) + geom_jitter(aes(x$cluster,x$avg_logFC,color = x$label),size= 0.8) + geom_text_repel(aes(x$cluster,x$avg_logFC,label = x$gene))

图片.png

添加主题

 p = p + theme_classic()

图片.png

我们先把点的颜色调整和图一致

p = p + scale_color_manual(values = c('red','black'))

图片.png

接下来我们要绘制一些细节了

p  = p + labs(x= 'Cluster',y = 'avgerage logFC', color = '')+ theme(axis.line.x = element_blank(),axis.text.x = element_blank(),axis.ticks.x = element_blank())

然后是图例点的大小和位置(根据自己的需求进行调整)

p = p +guides(color = guide_legend(override.aes = list(size = 5))) + theme(legend.position = c(0.9,0.9))

图片.png

然后调节各个文本的大小

p = p+ theme(axis.title = element_text(size = 15,family = 'font'),axis.text = element_text(size = 10),legend.text = element_text(size = 10))

图片.png

接下来就要加柱子了

对数据集新加一列,这部分什么作用,我就不多说了,大家自己琢磨一下吧

x$bar  = 0
for (i in 0:11){
  x[which(x$cluster == as.numeric(i)),][1,11] = 0.4
}
x$bar_1 = 0
for (i in 0:12){
  x[which(x$cluster == as.numeric(i)),][1,12] = -0.4
}

好,添加柱子

p = p+ geom_bar(aes(x$cluster,x$bar,fill = as.factor(x$cluster)),stat= 'identity') +scale_fill_discrete(guide =F) + geom_bar(aes(x$cluster,x$bar_1,fill = as.factor(x$cluster)),stat= 'identity') +scale_fill_discrete(guide =F)

图片.png

好,马上就要大功告成了。
设置一下颜色梯度

defined_cols = c('#e6194b', '#3cb44b', '#ffe119', '#4363d8', '#f58231', '#911eb4', '#46f0f0', '#f032e6', '#bcf60c', '#fabebe', '#008080', '#e6beff', '#9a6324')
p = p + scale_fill_manual(values = defined_cols,guide = F)

图片.png

好,更进一步了,接下来就是添加文本

###创建数据集
x = c(0,1,2,3,4,5,6,7,8,9,10,11,12)
y = c(0,0,0,0,0,0,0,0,0,0,0,0,0)
label = x
zhao = data.frame(x,y,label)
p = p + geom_text(data= zhao,aes(zhao$x,zhao$y,label=zhao$label),size = 10)

图片.png

到此为止,我们大功告成

生活很好,有你更好

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://0291.com.cn/post/56689.html

相关文章

教你四步优化好一个新浪博客。

教你四步优化好一个新浪博客。

  新浪博客,一个国内人气旺盛,集明星草根于一身的互动社区,自上线以来新浪博客依靠自身特性与经营,做到了今天的中文综合得分最高的博客门户,此外新浪博客也是广大站长热爱的一个平台,拥有着新浪天然的公信力,可谓一个不可多得的外链沃土。看到不少人在用新浪博客做推广,包括培训界有名的狗小云等,今天笔者带大...

分享文章标题如何优化,有何技巧。

分享文章标题如何优化,有何技巧。

网页的Title在浏览器最左边最顶部的位置显示的地方,我们知道,标题是被搜索引擎当作确定当前网页主题的最主要的参数,也是seo中最重要的内部因素。目前常见的搜索引擎中,显示的标题一般是60个字符,也就是30个汉字,如果你的网页标题超过30个字,那后面的就会截断,这个请大家注意控制一下。而文章内容页...

淘宝seo怎么优化排名(seo排名优化是什么)

淘宝seo怎么优化排名(seo排名优化是什么)

做生意首先要选择产品,因为产品将决定着店铺的成交额。产品质量决定着店铺的DSR,买家评价等方面。产品指数也决定着店铺的后续发展。...

谈谈网站排名点击

谈谈网站排名点击

那我们该做黑帽吗?是一点也不建议,虽然也不排斥。只是希望大家能够看清楚自己的网站定位,你是否是想要认认真真的做一个网站,希望它长久,还是为了短暂的排名争取拿短暂的昙花一现? 你如果有了答案,那我们就分两步谈谈,黑帽直接看下面。白帽就要远离网站作弊,而常言道常在路边走,哪有不湿鞋。黑帽白帽很多手...

拒绝emo!100条温柔治愈的正能量句子

拒绝emo!100条温柔治愈的正能量句子

1、人生漫长转瞬即逝,有人见尘埃,有人见星辰。 —— 《月亮与六便士》2、有自制力的人,才配谈自由。3、风筝,只有逆风时才能寻找到自己的方向。4、清醒温柔知进退,努力上进且优秀5、我习惯了孤单,也爱上了寂寞。 —— 李宫俊《李宫俊是谁》6、当泪的潮涌渐渐退远,理想的岛屿就会...

网站设计是否成功看哪几点。

网站设计是否成功看哪几点。

网站设计是否成功看哪几点? 判断一个网站设计是否成功,很难有统一的标准,毕竟,有些喜欢科技感,有些喜欢朴素,有些人喜欢华丽,有些喜欢简单,但是无论网站是什么性质什么行业的,无论是商业网站还是公益网站, 无论是企业网站还是个人网站。以下几点可以用作判断网站设计是否成功。 1、是否符合网站...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片