ggplot文字标签设置之ggrepel包

在很多作图中,我们都涉及过添加标签,例如火山图,一般都是用ggrepel中的geom_text_repel函数。
构建一个散点图。


library(ggplot2)
library(ggrepel)
setwd("C:/Users/tq199/Desktop")
A <- read.csv("A.csv", header = T)

ggplot(A, aes(x=rank, y=avg_log2FC)) + 
  geom_point(size=3, color='#DC050C')+
  theme_bw()+
  theme(panel.grid.major=element_blank(),
        panel.grid.minor=element_blank(),
        axis.title = element_text(colour = 'black', size = 15),
        axis.text = element_text(colour = 'black', size = 12))+
  labs(x='Rank', y='Log2FC')
image.png

需要标签的点整理一个单独的文件,直接使用geom_text_repel,设置下箭头、大小、字体等等。但是我们会发现一个问题,那就是有些标签不会显示(显示不全),这是因为太多导致重复了。

B <- read.csv("B.csv", header = T)

ggplot(A, aes(x=rank, y=avg_log2FC)) + 
  geom_point(size=3, color='#DC050C')+
  geom_point(data = A[abs(A$avg_log2FC)<0.5,], 
             stroke = 0.5, size=3, shape=16, color="grey50",alpha =0.4)+
  theme_bw()+
  theme(panel.grid.major=element_blank(),
        panel.grid.minor=element_blank(),
        axis.title = element_text(colour = 'black', size = 15),
        axis.text = element_text(colour = 'black', size = 12))+
  labs(x='Rank', y='Log2FC')+
  geom_text_repel(data=B, aes(label=X), color="black", size=4, fontface="italic", 
                  arrow = arrow(ends="first", length = unit(0.01, "npc")), box.padding = 0.2,
                  point.padding = 0.3, segment.color = 'black', segment.size = 0.3, force = 1, max.iter = 3e3)
image.png

在很多文章中,我们发现别人的标签排列很整齐,这里只需要设置两个小参数即可。第一direction设置y轴对齐,nudge_x设置指示线长一点即可。


B1 <- B[B$avg_log2FC>0,]
B2 <- B[B$avg_log2FC<0,]


ggplot(A, aes(x=rank, y=avg_log2FC)) + 
  geom_point(size=3, color='#DC050C')+
  geom_point(data = A[abs(A$avg_log2FC)<0.5,], 
             stroke = 0.5, size=3, shape=16, color="grey50",alpha =0.4)+
  theme_bw()+
  theme(panel.grid.major=element_blank(),
        panel.grid.minor=element_blank(),
        axis.title = element_text(colour = 'black', size = 15),
        axis.text = element_text(colour = 'black', size = 12))+
  labs(x='Rank', y='Log2FC')+
  geom_text_repel(data=B1, aes(label=X), color="black", size=4, fontface="italic", 
                  size=3, segment.size=0.5, nudge_x=500, direction="y", hjust=0)+
  geom_text_repel(data=B2, aes(label=X), color="black", size=4, fontface="italic", 
                 size=3, segment.size=0.5, nudge_x=-1000, direction="y", hjust=0)

图片

最后,如果需要标注的点比较散,也可以使用x对齐。


B3 <- B2[abs(B2$avg_log2FC)>1.2,]
ggplot(A, aes(x=rank, y=avg_log2FC)) + 
  geom_point(size=3, color='#DC050C')+
  geom_point(data = A[abs(A$avg_log2FC)<0.5,], 
             stroke = 0.5, size=3, shape=16, color="grey50",alpha =0.4)+
  theme_bw()+
  theme(panel.grid.major=element_blank(),
        panel.grid.minor=element_blank(),
        axis.title = element_text(colour = 'black', size = 15),
        axis.text = element_text(colour = 'black', size = 12))+
  labs(x='Rank', y='Log2FC')+
  geom_text_repel(data=B3, aes(label=X), color="black", size=4, fontface="italic", 
                  size=3, segment.size=0.5, nudge_x=-1000, direction="x", hjust=0)

参数

大部分geom_text()的参数都适用于geom_text_repel(),除了以下几个:

hjust
vjust
position
check_overlap

ggrepel包为geom_text_repel()与geom_label_repel()提供了特有的参数设置:

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

下面举个栗子来详细了解这些参数的图形效果

set.seed(42)
ggplot(mtcars)+ geom_point(aes(wt, mpg, color=factor(cyl)), size=3)+
geom_text_repel(aes(wt, mpg, color=factor(cyl),
label=rownames(mtcars), angle=ifelse(mtcars$cyl==4, 90, 0)),
size=4, family="Times", fontface="bold",
box.padding=unit(0.5, "lines"), point.padding=unit(1.6, "lines"),
segment.color = "#cccccc", segment.size = 0.5,
arrow = arrow(length=unit(0.01, "npc")),force = 1, max.iter = 3e3,
nudge_x = ifelse(mtcars$cyl==6, 2, 0), nudge_y = ifelse(mtcars$cyl==6, 9, 0))+
scale_color_discrete(name="cyl")+
scale_x_continuous(expand = c(0.5, 0))+
scale_y_continuous(expand = c(0.25, 0))+
theme_classic(base_size = 16)
image.png

参考
ggplot文字标签设置(geom_text_repel函数)的一个小例子
R语言可视化学习笔记之ggrepel包

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容