ggplot2绘图系统——扩展包ggrepel、ggsci、gganimate、ggpubr等

部分扩展包可在CRAN直接下载,有些需借助devtools包从Github下载。

1. ggrepel包

用来在图上添加文字和标签,相比geom_text和geom_label函数,能将重叠的标签分开,并添加指示短横线。

library(ggrepel)
ggplot(mtcars,aes(wt,mpg))+geom_point(color='red')+
geom_text_repel(aes(label=rownames(mtcars)),
segment.color = 'blue')+
theme_classic(base_size = 16)

2. ggsci包

肖楠作品,针对科研人员的包,满足不同杂志风格的配色,包括十几种配色方案。

基本配色函数:



Lancet配色示例。

library(ggsci)
p1 <- ggplot(subset(diamonds,carat>=2.2),aes(x=table,y=price,color=cut))+
geom_point(alpha=0.7)+
geom_smooth(method = 'loess',alpha=0.05,size=1,span=1)+
theme_bw()
a <- p1+scale_color_lancet() p2 <- ggplot(subset(diamonds,carat>2.2&depth>55&depth<70),
aes(x=depth,fill=cut))+
geom_histogram(color='black',binwidth = 1,position = 'dodge')+
theme_bw()
b <- p2+scale_fill_lancet() grid.arrange(a,b,ncol=2)



JCO配色风格示例。

c <- p1+scale_color_jco()
d <- p2+scale_fill_jco()
grid.arrange(c,d,ncol=2)

3. gganimate包

绘制动态图(将静态的png、jpeg图片转化成动态的gif文件)。

使用gganimate前,需在本机上先安装ImageMagick软件(专用于图片编辑、合成、转换及其他处理的软件)。

library(gganimate)
date <- as.character(economics$date)
economics$year <- substr(date,1,4) #提取年份
p <- ggplot(economics,aes(date,uempmed,size=unempoly,
frame=year))+#必须参数,展示每一帧名称
geom_point()
gganimate(p)
aq <- airquality
aq$date <- as.Date(paste(1973,aq$Month,aq$Day,sep = '-'))
p2 <- ggplot(aq,aes(date,Temp,frame=Month,
cumulative=TRUE))+ #叠加显示,而非单独显示每一帧
geom_line()
gganimate(p2,title_frame=FALSE)

4. ggpubr包

快速生成论文发表级的统计图形。

两两比较盒形图

library(ggpubr)
data('ToothGrowth')
df <- ToothGrowth
p <- ggboxplot(df,
x='dose',
y='len',
color = 'dose',#颜色映射变量
palette = c('#00AFBB','#E7B800','#FC4E07'), #盒形颜色取值
add = 'jitter', #点扰动
shape='dose' #扰动点形状
)
p
#代码风格更偏向于基础包,注意传入的变量都是字符串形式 #######统计学差异绘图 #定义哪些组两两比较
my_comparisons <- list(c('0.5','1'),c('1','2'),c('0.5','2'))
#添加组间比较p值
b <- p+stat_compare_means(comparisons = my_comparisons)+
stat_compare_means(label.y = 50) #p值位置 grid.arrange(p,b,ncol=2)



小提琴图

ggviolin(df,
x='dose',
y='len',
fill = 'dose',
palette = c('#00AFBB','#E7B800','#FC4E07'),
add = 'boxplot', #添加盒形图
add.params = list(fill='white'))+
#定义后添加图形的属性,这里定义盒形图填充色
stat_compare_means(comparisons = my_comparisons,
label = 'p.signif') +#以显著程度展示,而非p
stat_compare_means(label.y=50) #总体比较p值位置

条形图和滑珠图

滑珠图是条形图一种变形。

示例比较。

mtcars$name <- rownames(mtcars)
mtcars$cyl <- as.factor(mtcars$cyl) #条形图
a <- ggbarplot(mtcars,x='name',y='mpg',
fill = 'cyl',
color='white',
palette = 'lancet', #配色风格,JCO
sort.val = 'desc', #对y变量降序
sort.by.groups = FALSE, #各组不分开排列
x.text.angle=90
) #滑珠图
b <- ggdotchart(mtcars,x='name',y='mpg',
color = 'cyl',
palette = 'jco',
sorting = 'ascending', #升序排列
add = 'segments', #添加线段,使之成为滑珠图
ggtheme = theme_pubr() #图形整体风格
)
grid.arrange(a,b,ncol=2)



改善后的滑珠图。

ggdotchart(mtcars,x='name',y='mpg',
color = 'cyl',
palette = c('#00AFBB','#E7B800','#FC4E07'),
sorting = 'descending',
add = 'segments',
rotate = TRUE,
group = 'cyl', #各亚组分开
dot.size = 6, #散点大小
label = round(mtcars$mpg),#mpg值作为散点标签
font.label = list(color='white',size=9,vjust=0.5),
#定义散点其他属性
ggtheme = theme_pubr()
)

5. 其他扩展包

  • ggfortify包
  • ggforce包

    对ggplot2几何对象进行了扩展,加入arcs、curves等几何对象,更方便绘制饼图、弧形等。
  • ggradar包

    雷达图/蜘蛛图。
  • ggnetwork包

    社交网络数据可视化。

R语言与医学统计图形-【28】ggplot2扩展包ggrepel、ggsci、gganimate、ggpubr的更多相关文章

  1. R语言与医学统计图形-【26】ggplot2主题函数

    ggplot2绘图系统--主题函数 1. theme函数 theme_*系列函数提供了9种不同的风格. theme_grey/gray/bw/linedraw/light/minimal/classi ...

  2. R语言与医学统计图形-【27】ggplot2图形组合、字体、保存

    ggplot2绘图系统--图形组合.字体选择.保存输出 1.图形组合 一页多图在基础包中利用par和layout函数来切分画布. ggplot2是先铺好网格背景,再进行绘图,所以要通过切分网格背景来实 ...

  3. R语言与医学统计图形【1】par函数

    张铁军,陈兴栋等 著 R语言基础绘图系统 基础绘图包之高级绘图函数--par函数 基础绘图包并非指单独某个包,而是由几个R包联合起来的一个联盟,比如graphics.grDevices等. 掌握par ...

  4. R语言与医学统计图形【8】颜色的选取

    R语言基础绘图系统 基础绘图包之低级绘图函数--内置颜色. 1.内置颜色选取 功能657种内置颜色.colors() 调色板函数:palette(), rgb(), rainbow(). palett ...

  5. R语言与医学统计图形【6】低级绘图函数

    R语言基础绘图系统 基础绘图包之低级绘图函数--定义坐标轴.图例.文本 低级绘图函数:本身不具备图形绘制能力,只是在已有图形基础上添加元素. 函数 功能 arrows 添加箭头 axis 坐标轴 bo ...

  6. R语言与医学统计图形【5】饼图、条件图

    R语言基础绘图系统 基础图形--饼图.克利夫兰点图.条件图 6.饼图 pie(rep(1,26),col=rainbow(26), labels = LETTERS[1:26], #标签 radius ...

  7. R语言与医学统计图形【4】直方图、金字塔图

    R语言基础绘图系统 基础图形--直方图.金字塔图 3.直方图 参数设置及比较. op <- par(mfrow=c(2,3)) data <- rnorm(100,10,5) hist(d ...

  8. R语言与医学统计图形【3】条形图、误差图

    R语言基础绘图系统 基础图形--条形图.误差图 3.条形图 barplot接收的数据是矩阵而非数据框. data <- sample(c(50:80),5) barplot(data,col=h ...

  9. R语言与医学统计图形【2】散点图、盒形图

    R语言基础绘图系统 基础图形--散点图.盒形图 plot是一个泛型函数(generic method),对于不同的数据绘制不同的图形. par函数的大部分参数在plot中通用. 1.散点图 plot绘 ...

随机推荐

  1. linux系统上国际化失败

    文章目录 一.需求: 二.出现的问题 三.代码结构 1.配置文件中的配置 2.java代码中的使用 四.解决方案 一.需求: 最近项目中有这么一个需求,当用户当前的语言环境是 中文时,导出的 exce ...

  2. 你一定不知道的Unsafe用法

    Unsafe是什么 首先我们说Unsafe类位于rt.jar里面sun.misc包下面,Unsafe翻译过来是不安全的,这倒不是说这个类是不安全的,而是说开发人员使用Unsafe是不安全的,也就是不推 ...

  3. Spring:所有依赖项注入的类型

    一.前言 Spring文档严格只定义了两种类型的注入:构造函数注入和setter注入.但是,还有更多的方式来注入依赖项,例如字段注入,查找方法注入.下面主要是讲使用Spring框架时可能发生的类型. ...

  4. 实验 1: SDN拓扑实践

    (图片和文档是自己写的,因为在CSDN也写了,所以会有自己的水印) 一.实验目的 能够使用源码安装Mininet: 能够使用Mininet的可视化工具生成拓扑: 能够使用Mininet的命令行生成特定 ...

  5. 有关fgetc配合feof逐行读取文件最后一行读取两遍的错觉?

    最近在做一个wifiap设置的接口,用户首先获取到当前wifi 热点的ssid 和pwd,然后修改,保存. 获取信息的时候是fopen对应的hostapd.conf文件,逐行读取,查找匹配的参数. 修 ...

  6. Atcoder 题目泛做

    我思维越来越菜了,这样下去感觉要退役了. 听说Atcoder的题练思维?那就试着做一做吧. 坚持每天一两道吧.(很有可能咕掉.) AGC036 官方题解 ---A-Triangle          ...

  7. CentOS 7 tmpwatch 2.11 版本变更,移除 cronjob 任务

    老版本(RHEL6) tmpwatch 原理 在 RHEL6 上,/tmp 目录的清理工作通常是交给 tmpwatch 程序来完成的,tmpwatch 的工作机制是通过 /etc/cron.daily ...

  8. 简单理解函数声明(以signal函数为例)

    这两天遇到一些声明比较复杂的函数,比如signal函数,那我们先简单说说signal函数的用法:(参考<c陷阱与缺陷>) [signal:几乎所有c语言程序的实现过程中都要用到signal ...

  9. 实验1:SDN拓扑拓扑实验

    一.实验目的 能够使用源码安装Mininet: 能够使用Mininet的可视化工具生成拓扑: 能够使用Mininet的命令行生成特定拓扑: 能够使用Mininet交互界面管理SDN拓扑: 能够使用Py ...

  10. Ubuntu20.04配置Java开发环境

    Ubuntu20.04配置Java开发环境 JDK 1.8 安装 下载地址 下载后进行解压 tar -xvzf jdk-8u301-linux-x64.tar.gz 配置环境变量 gedit ~/.b ...