# 变换坐标轴的方向ggbarplot(df2, "dose", "len", orientation = "horiz")
# 指定排列顺序ggbarplot(df2, "dose", "len", order = c("D2", "D1", "D0.5"))
# 更改填充色和边框色,并且将标签放在柱子内ggbarplot(df2, "dose", "len", fill = "steelblue", color = "black", label = TRUE, lab.pos = "in", lab.col = "white")
# 按照 x 轴"dose"的分组设定颜色ggbarplot(df2, "dose", "len", color = "dose", palette = c("#00AFBB", "#E7B800", "#FC4E07"))
ggbarplot(df3, "dose", "len", fill = "dose", color = "dose", palette = c("#00AFBB", "#E7B800", "#FC4E07"))
# 分组绘图# 构建数据df3 <- data.frame(supp=rep(c("VC", "OJ"), each=3), dose=rep(c("D0.5", "D1", "D2"),2), len=c(6.8, 15, 33, 4.2, 10, 29.5))print(df3)## supp dose len## 1 VC D0.5 6.8## 2 VC D1 15.0## 3 VC D2 33.0## 4 OJ D0.5 4.2## 5 OJ D1 10.0## 6 OJ D2 29.5
ggbarplot(df3, "dose", "len", fill = "supp", color = "supp", label = TRUE, lab.col = "white", lab.pos = "in")
# 更改排列方式ggbarplot(df3, "dose", "len", fill = "supp", color = "supp", palette = "Paired", label = TRUE, position = position_dodge())
ggbarplot(df3, "dose", "len", fill = "supp", color = "supp", palette = "Paired", label = TRUE, position = position_fill())
# 添加散点和误差——使用的是"ToothGrowth"数据集,ToothGrowth描述了维生素C对豚鼠牙齿生长的影响。3个变量60个观测值。[,1] 是len数字牙齿长度。[,2]是补充因子类型(VC或OJ)。[,3]是以毫克为单位的剂量。data("ToothGrowth")df4 <- ToothGrowthhead(df4)
# len supp dose# 1 4.2 VC 0.5# 2 11.5 VC 0.5# 3 7.3 VC 0.5# 4 5.8 VC 0.5# 5 6.4 VC 0.5# 6 10.0 VC 0.5
# 可以看出 x 轴的每一个分组都对应 y 轴上的多个取值ggbarplot(df4, x = "dose", y = "len")
# 展示每个组的均值ggbarplot(df4, x = "dose", y = "len", add = "mean")
# 添加不同类型的误差棒(mean_sd, mean_ci, median_iqr, ....),调整 label 位置,其他的误差棒类型自行探索哈~ggbarplot(df4, x = "dose", y = "len", add = "mean_se", label = TRUE, lab.vjust = -1.6)
# 添加 jitter pointsggbarplot(df4, x = "dose", y = "len", add = c("mean_se", "jitter"))
# 添加 dot 小圆点
ggbarplot(df4, x = "dose", y = "len", add = c("mean_se", "dotplot"))
# 多个分组的条形图ggbarplot(df4, x = "dose", y = "len", color = "supp", add = "mean_se", palette = c("#00AFBB", "#E7B800"), position = position_dodge())
# 高级版来啦,用到的数据集是"mtcars"data("mtcars")df5 <- mtcarsView(df5)
df5$cyl <- factor(df5$cyl) #不转化成因子的话后面画图会报错df5$name <- rownames(df5) #添加一行namehead(df5[, c("name", "wt", "mpg", "cyl")])
# name wt mpg cyl# Mazda RX4 Mazda RX4 2.620 21.0 6# Mazda RX4 Wag Mazda RX4 Wag 2.875 21.0 6# Datsun 710 Datsun 710 2.320 22.8 4# Hornet 4 Drive Hornet 4 Drive 3.215 21.4 6# Hornet Sportabout Hornet Sportabout 3.440 18.7 8# Valiant Valiant 3.460 18.1 6
# 柱状图展示不同车的速度,按cyl为分组信息进行填充颜色,颜色按nature配色方法,数值按降序排列。ggbarplot(df5, x="name", y="mpg", fill = "cyl", color = "white", palette = "npg", #杂志nature的配色 sort.val = "desc", #下降排序 sort.by.groups=FALSE, #不按组排序 x.text.angle=60)
# 组内进行排序
ggbarplot(df5, x="name", y="mpg", fill = "cyl", color = "white", palette = "aaas", #杂志Science的配色 sort.val = "asc", #上升排序,区别于desc,具体看图演示 sort.by.groups=TRUE,x.text.angle=60) #按组排序 x.text.angle=90
ggbarplot 函数 :
用法:
ggbarplot(data, x, y, combine = FALSE, merge = FALSE, color = "black", fill = "white", palette = NULL, size = NULL, width = NULL, title = NULL, xlab = NULL, ylab = NULL, facet.by = NULL, panel.labs = NULL, short.panel.labs = TRUE, select = NULL, remove = NULL, order = NULL, add = "none", add.params = list(), error.plot = "errorbar", label = FALSE, lab.col = "black", lab.size = 4, lab.pos = c("out", "in"), lab.vjust = NULL, lab.hjust = NULL, sort.val = c("none", "desc", "asc"), sort.by.groups = TRUE, top = Inf, position = position_stack(), ggtheme = theme_pubr(), ...)
参数:
data
所需的数据框 dataframe
x,y
进行作图所需的数据
combine
对于多个变量的数据是否分面。默认是FALSE
merge
对于多个变量的数据是否合并,默认是FALSE。
color
轮廓线的颜色
fill
填充色
palette
自定义颜色画板
size
设置点和轮廓线的大小
width
设置柱子的宽度,取值范围 0~1
title
设置标题
xlab
设置x轴标题,当 xlab = FALSE 时,可以将标题隐藏
ylab
设置y轴标题,当 ylab = FALSE 时,可以将标题隐藏
x.text.angle
x轴文本旋转角度
orientation
变换坐标轴的方向
facet.by
设置分组分面
panel.labs
设置分面各组的标题
short.panel.labs
是否缩写分面标题,逻辑值,默认是TRUE。
select
选择需要展示的变量
remove
移除不需要展示的变量
order
选定变量的排列顺序
add
添加图片元素:
"none", "dotplot", "jitter", "boxplot", "point", "mean", "mean_se", "mean_sd", "mean_ci", "mean_range", "median", "median_iqr", "median_mad", "median_range"
add.params
给add参数中添加的元素添加属性:olor, shape, size, fill, linetype
eg:add.params = list(color = "red")
error.plot
添加误差棒,选项有"pointrange", "linerange", "crossbar", "errorbar", "upper_errorbar", "lower_errorbar", "upper_pointrange", "lower_pointrange", "upper_linerange", "lower_linerange"。默认是"pointrange" or "errorbar".
label
设置列标签
lab.col, lab.size
设置 label 文本颜色和大小
lab.pos
设置 label 的位置,选项有:
"out" (for outside)
"in" (for inside).
Ignored when lab.vjust != NULL.
lab.vjust
垂直方向上调整 label 的位置。
Provide negative value (e.g.: -0.4) to put labels outside the bars or positive value to put labels inside (e.g.: 2).
lab.hjust
水平方向上调整 label 的位置。
sort.val
是否进行排序:
"none":无排序
"asc":升序(ascending)
"desc":降序(descending)
sort.by.groups
逻辑值,当为TRUE时,按照分组排序
top
确定要显示出来的 top elements 的数目
top elements
设置排列方式
legend.title
设置图例标题
ggtheme
设置画图主题,默认是theme_pubr()。
ggplot2 official themes: theme_gray(), theme_bw(), theme_minimal(), theme_classic(), theme_void()