R:ggplot geom_bar/col

导读

以模拟数据为案例,总结ggplot柱形图绘图参数。内容如下方目录所示,一共包含1-9个部分。

目录:
一 输入数据
二 画图:基础调整
1 初始图
2 X轴排序
3 count列排序
4 XY轴标签
三 主题调整
1 经典主题(无框、无网格、透明背景)
2 BW主题(黑框、网格、透明背景)
3 自定义(黑框、无网格、透明背景)
四 颜色调整
1 数值取色
2 渐变色
3 RColorBrewer取色
4 分组字符取色
5 自定义柱色
6 柱边取色
7 自定义柱边色
五 Legend调整
1 修改legend title和text
2 移动legend(下方)
六 柱形调整
1 柱边粗细
2 柱间宽度/间距
3 翻转90度
七 字体调整
1 X Y Legend 标题加粗、加大
2 X Y Legend 文本加粗、加大
八 XY轴调整
1 坐标轴范围
2 柱距X轴距离
3 坐标轴线粗细
4 外框粗细
5 坐标轴刻度粗细
九 添加更多元素
1 加数字(大小、位置、颜色、字体)
2 加点(型号、大小、颜色)
3 加直线(线型、颜色、粗细)

一、输入数据(含分组)

count = rep(1:4, 3)
group = paste("color", rep(1:3, each=4), sep="_")
data = data.frame(count, group)

二、画图:基础调整

1 初始图
library(ggplot2)
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity")
2 X轴排序
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data)))
3 count列排序
tmp = data[order(data$count, decreasing=F),]
ggplot(tmp, mapping=aes(x=rownames(tmp), y=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(tmp)))
4 XY轴标签
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count")

三、主题调整

1 经典主题(无框、无网格、透明背景)
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_classic()
2 BW主题(黑框、网格、透明背景)
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw()
3 自定义(黑框、无网格、透明背景)
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme(panel.grid=element_blank(), panel.background=element_rect(color="black", fill="transparent"))

更多参考:https://ggplot2.tidyverse.org/reference/ggtheme.html

四、颜色调整

1 数值取色
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=count)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw()
2 渐变色
colors <- colorRampPalette(c("red", "black"))(12)
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity", fill=colors) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw()
3 RColorBrewer取色
library(RColorBrewer)
ggplot(data, mapping=aes(x=rownames(data), y=count)) +
geom_bar(stat="identity",  fill=brewer.pal(12, "Set3")) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw()
4 分组字符取色
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw()
5 自定义柱色
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw() +
scale_fill_manual(
    values=c("color_1"="red", "color_2"="green", "color_3"="blue"), 
    labels=c("red", "green", "blue"))
6 柱边取色
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw()
7 自定义柱边色
ggplot(data, mapping=aes(x=rownames(data), y=count, color=group)) +
geom_bar(stat="identity", fill="grey") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count") +
theme_bw() +
scale_color_manual(
    values=c("color_1"="red", "color_2"="green", "color_3"="blue"), 
    labels=c("red", "green", "blue"))

五、Legend调整

1 修改legend title和text
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
scale_fill_manual(
    values=c("color_1"="red", "color_2"="green", "color_3"="blue"), 
    labels=c("G1", "G2", "G3"))
2 移动legend(下方)
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom")

六、柱形调整

1 柱边粗细
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black", size=2) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom")
2 柱间宽度/间距
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black", width=1) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom")
3 翻转90度
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
coord_flip()

七、字体调整

1 X Y Legend 标题加粗、加大
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
theme(legend.title=element_text(face="bold", size=20)) +
theme(axis.title.x=element_text(face="bold", size=20)) +
theme(axis.title.y=element_text(face="bold", size=20))
2 X Y Legend 文本加粗、加大
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
theme(legend.text=element_text(face="bold", size=20)) +
theme(axis.text.x=element_text(face="bold", size=20)) +
theme(axis.text.y=element_text(face="bold", size=20))

八、XY轴调整

1 坐标轴范围
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_classic() +
theme(legend.position="bottom") +
ylim(c(0, 6))
2 柱距X轴距离
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_classic() +
theme(legend.position="bottom") +
scale_y_continuous(expand=c(0, 0))
3 坐标轴线粗细
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_classic() +
theme(legend.position="bottom") +
scale_y_continuous(expand=c(0, 0.1)) +
theme(axis.line = element_line(size = 2))
4 外框粗细
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_classic() +
theme(legend.position="bottom") +
scale_y_continuous(expand=c(0, 0.1)) +
theme(panel.background=element_rect(color="black", size=2))
5 坐标轴刻度粗细
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_classic() +
theme(legend.position="bottom") +
scale_y_continuous(expand=c(0, 0.1)) +
theme(axis.ticks = element_line(size = 2))

九、添加更多元素

1 添加标签(大小、位置、颜色、字体)
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
geom_text(aes(label = count, y = count/2), size=5, color="white", family="serif")
2 加点(型号、大小、颜色)
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
geom_point(pch=21, aes(fill=group), color="black", size=2) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
geom_text(aes(label = count, y = count/2), size=5)
3 加直线(线型、颜色、粗细)
ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
geom_point(pch=21, aes(fill=group), color="black", size=2) +
geom_line(aes(group=group), linetype="dashed", color="skyblue", size=2) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
geom_text(aes(label = count, y = count/2), size=5)
4 添加误差棒(宽度)

geom_errorbar(aes(ymax=x+sd,ymin=x-sd))

ggplot(data, mapping=aes(x=rownames(data), y=count, fill=group)) +
geom_bar(stat="identity", color="black") +
geom_point(pch=21, aes(fill=group), color="black", size=2) +
scale_x_discrete(limits=factor(rownames(data))) +
labs(x="Sample", y="Number of Count", fill="Group") +
theme_bw() +
theme(legend.position="bottom") +
geom_text(aes(label = count, y = count/2), size=5) +
geom_errorbar(aes(ymax = count+0.1, ymin = count-0.1), width=0.2)
5 添加X轴分组

给geom_bar geom_errorbar geom_text添加分组:position=position_dodge(1)
个人文件取色,配色:scale_fill_manual(values=value, labels=label)

文件准备:

color = read.table("group_color.list", header=F, comment.char="")
# 从个人文件中取色
data2 = data.frame(data, color=as.character(unique(data$count)))

个人文件取色:

value = c()
label = c()
for(i in 1:length(unique(data$count)))
{
    label = c(label, as.character(data2$color)[i])
    value = c(value, as.character(color[,1])[i])
}

绘图:

ggplot(data2, aes(x=group, fill=color, y=count))+
geom_bar(stat="identity", position=position_dodge(1)) +
labs(x='', y='Count', fill="Color") +
scale_y_continuous(limits=c(0, max(data[,1])+max(data[,1])/2), expand=c(0, 0)) +
theme_classic() +
geom_errorbar(aes(ymax=count+0.5, ymin=count-0.5), width=0.2, position=position_dodge(1)) +
scale_fill_manual(values=value, labels=label) +
geom_text(aes(label=count, y=count+2*0.5), position=position_dodge(1))

一组柱形图参数

ggplot(alpha, aes(x=id, y=alpha, fill=source)) +
  geom_col(position="stack") +
  theme_classic() +
  scale_fill_manual(values = c("Colon"="#00BA38",
                               "Stool"="#F8766D",
                               "Ileum"="#619CFF")) +
  theme(legend.text=element_text(size=15),
        legend.title=element_text(face='bold', size=20)) +
  labs(x="", 
       y="Shannon index", 
       fill="Source") +
  theme(title = element_text(size = 15, face="bold")) +
  scale_y_continuous(expand = c(0, 0),
                     limits = c(0, 5)) +
  theme(axis.title = element_text(size = 25),
        axis.text.y = element_text(size = 18),
        axis.line = element_line(size = 1),
        axis.ticks = element_line(size = 1)) +
  theme(axis.text.x = element_text(angle = 60, 
                                 hjust = 1, 
                                 size = 20,
                                 color = alpha$color))
更新于2020.9.17😀😀
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,826评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,968评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,234评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,562评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,611评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,482评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,271评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,166评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,608评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,814评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,926评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,644评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,249评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,866评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,991评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,063评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,871评论 2 354

推荐阅读更多精彩内容