张铁军,陈兴栋等 著

R语言基础绘图系统

基础绘图包之高级绘图函数——par函数

基础绘图包并非指单独某个包,而是由几个R包联合起来的一个联盟,比如graphics、grDevices等。

掌握par函数(作为20个主要统计图形函数之一)的主要参数。?par

  • adj 微调图中字符位置。adj=c(x,y),相对左下角坐标点,一般不超过1。

  • bg 绘图区域背景色。par(bg="green")

  • bty 设置图形边框样式。包含o, l , 7, c, u, ]可选。

bty <- c('o', 'l' , '7', 'c', 'u', ']')
par(mfrow=c(3,2)) #切分画布
for(i in 1:6){
par(bty=bty[i])
plot(1:5,main=paste("the bty is",bty[i],sep = ':'))
}
  • cex 设置图上元素,如文字或符号的缩放倍数。plot(1:5, cex=1:5)。衍生参数:cex.lab, cex.main, cex.sub, cex.axis.

  • col 设置元素颜色。

  • family 文本字体。包括serif, sans, mono, symbol。如par(family='serif')即为医学科研论文中常用的times new roman字体。

  • font 字体样式。包括1, 2, 3, 4分别为正常,粗体,斜体和粗斜体。

  • las 坐标轴刻度标签样式。包括0,1,2,3,分别为平行于坐标轴,水平,垂直于坐标轴,垂直。

  • lty 线条样式。包括0,1,2,3,4,5,6,分别为不划线,实线,虚线,点线,点划线,长划线,点长划线。

  • lwd 线条宽度。用法类似cex。注意:当在par函数中使用lwd时,图形中所有元素(如线条,坐标轴,边框等)的线宽都会改变;若只需图中线条宽度变化,需将lwd加入绘图函数中。

#全局设置线宽
par(mfrow=c(2,3))
for(i in 1:6){
par(lty=i,lwd=i) #设置不同线型和线宽
plot(1:5,type = 'l',main = paste('the lty is',i,sep = ':'),
sub = paste('the lwd is',i,sep = ':'))
} #仅设置线条宽度
plot(rnorm(50),type = 'l',lwd=2,main = "图中线条宽度为默认的2倍")
  • mar和mai 设置图形边界空白宽度,用于控制绘图面积大小。接受4个数值向量,分别为图形下、左、上、右的边界宽度。前者默认c(5,4,4,2)+0.1,单位为线宽,后者单位为英寸。

  • mfrow和mfcol 画布切割。2个元素,几行几列组合。

  • mgp 坐标轴到画布边缘的距离。后接3个元素分别表示坐标轴标题、刻度标签、坐标轴线到图形的距离,默认mgp=c(3,1,0)

  • pch 点的形状。包括25种,即1-25,其中15-20可进行颜色填充。


plot(rep(1:5,times=5),rep(1:5,each=5),pch=1:25,
cex=1.5, bty='l', xlim = c(1,5.4),
xlab = '',ylab = '',main = '25种不同点型') #低级绘图函数,图中添加文本
text(rep(1:5,times=5)+0.15,rep(1:5,each=5),
labels = 1:25, col = 'red')
  • srt 图中字符串旋转角度。
plot(1:25,pch=1)
text(x=c(5,10,20),y=c(7,15,10),col = 'red',
labels = c("R","China","Love"),
srt=30)
  • tck和tcl 设置坐标轴刻度线的高度。tck是与图形宽度和高度的比例值(-1到1之间),tcl是与文本行高的比例值。负值表坐标轴刻度向外,正值表示向内。
par(mfrow=c(1,2))
plot(1:10,tck=0.03,main = 'tck=0.03') #刻度线朝内
plot(1:10,tck=-0.03,main = 'tck=-0.03') #刻度线朝外
  • usr 限定画布大小,usr=c(x1,x2,y1,y2),分别表示x轴左、右极限,y轴的下、上极限的矩形区域。

  • xaxt和yaxt 设置坐标轴样式,默认标准样式为s。若不需要坐标轴或需自定义坐标轴,可设置n,即不绘制刻度及标签,但仍有一条刻度线。

  • xlog和ylog 坐标轴取值log转换。

  • fig 取值fig=c(x1,x2,y1,y2),配合new=TRUE参数,用于在当前图形上添加新的图形。

x <- rnorm(1000)
#QQ图
qqnorm(x)
#添加正态拟合线
qqline(x,col="red")
#设置参数,新图形位置
op <- par(fig=c(0.02,0.5,0.5,0.98),new=TRUE)
#0.02表示新图形左边框与原图左边框的距离是原图宽度的2%
#0.5表示新图形右边框与原图左边框的距离是原图宽度的50%
#0.5表示新图形下边框......下................高度的50%
#0.98表示.....上..........下......................98% #绘制新图形直方图
hist(x,probability = T,col = 'light blue',
xlab='',ylab='',main = '',axes = F)
#添加概率密度曲线
lines(density(x),col="red",lwd=2)
#新图形加边框
box()
#释放par参数
par(op)
  • xpd 设置绘图区域大小。包括TRUE, FALSE, NA,FALSE代表绘图区域,即图形中点线条等元素所占面积;TRUE代表图形区域,即图形占地面积;NA代表设备区域,即Rstudio中的plots窗口面积。

坐标轴、标题等元素在图形区域,而非绘图区域。这个参数作用就是实现设定绘图区域大小,方面我们在绘图区域外部添加额外内容。

par(omi=c(0.1,0.1,0.2,0.2),mai=c(2,2,1,2),xpd=NA)
#omi参数定义图形区域与设备区域间的距离(英寸)。
#mai参数定义绘图区域与图形区域间的距离(英寸)。
plot(1:10)
text(3,-5,'绘图区域外添加的文字')
text(-0.5,12,'A',cex = 3,family='serif')

科研论文中版面图(panel plot)的应用:即一张画布分布多张图。

#上下排布
#图A,上半边绘图区域
par(omi=rep(0,4),mai=c(3.5,1,1,1),xpd=NA)
plot(1:10)
text(-0.5,12,'A',cex = 2,family='serif')
#图B,下半边绘图区域
par(new=TRUE,mai=c(1,1,3.5,1))
plot(1:10)
text(-0.5,12,'B',cex=2,family='serif') #左右排布
#mai下左上右
#图A,左半边绘图区域
par(omi=rep(0,4),mai=c(1,1,1,5),xpd=NA)
plot(1:10)
text(-0.5,12,'A',cex = 2,family='serif')
#图B,右半边绘图区域
par(new=TRUE,mai=c(1,5,1,1))
plot(1:10)
text(-0.5,12,'B',cex=2,family='serif')
  • ask 逻辑参数。设为TRUE时,一次展示一张画布显示一张图。若为FALSE,所有图一闪而过。

以上par函数的22个参数较为常用。大部分可直接在高级绘图函数中使用,等同par()使用;部分参数只能在par中设置和使用,包括ask, fig, fin ,lheight, mai, mar, mfcol, mfrow, mfg, new, oma, omd, omi, pin, plt, ps, pty, usr, xlog, ylog

注意:

par函数对图形参数的改变是永久性的,即在R关闭前,par函数对每张图都起作用。以下方法解决永久性改变问题:

  • 1.将所有参数保存为一个实名对象,待图形绘制完毕后,再释放实名对象。
op <- par(fig=c(0.02,0.5,0.5,0.98),new=TRUE)
hist(x,probability = T,col = 'light blue',
xlab='',ylab='',main = '',axes = F)
lines(density(x),col="red",lwd=2)
box()
#释放par参数
par(op)
  • 2.图形绘制完成后,调用dev.off关闭绘图框。

R语言与医学统计图形【1】par函数的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

    R语言基础绘图系统 基础绘图包之低级绘图函数--气泡图.一页多图.背景网格.添加线条和散点.数学表达式 4.气泡图 symbols是高级绘图函数,可在图上添加标记,标记的形状包括:circles,sq ...

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

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

  8. R语言与医学统计图形-【28】ggplot2扩展包ggrepel、ggsci、gganimate、ggpubr

    ggplot2绘图系统--扩展包ggrepel.ggsci.gganimate.ggpubr等 部分扩展包可在CRAN直接下载,有些需借助devtools包从Github下载. 1. ggrepel包 ...

  9. R语言与医学统计图形-【33】生存曲线、森林图、曼哈顿图

    1.生存曲线 基础包survival+扩展包survminer. survival包内置肺癌数据集lung. library(survival) library(survminer) str(lung ...

随机推荐

  1. Scrum Meeting 0509

    零.说明 日期:2021-5-9 任务:简要汇报两日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 两日内已完成的任务 后两日计划完成的任务 qsy PM&前端 测试 测试 cyy ...

  2. 计算机网络传输层之TCP拥塞控制(慢开始与拥塞避免、快重传和快恢复)

    文章转自:https://blog.csdn.net/weixin_43914604/article/details/105532044 学习课程:<2019王道考研计算机网络> 学习目的 ...

  3. MyBatis源码分析(六):Spring整合分析

    一.Mybatis-Spring源码结构 二.Myabtis交给Spring管理的组件 1. dataSource 数据源 配置一个数据源,只要是实现了javax.sql.DataSource接口就可 ...

  4. Node.js躬行记(13)——MySQL归档

    当前我们组管理着一套审核系统,除了数据源是服务端提供的,其余后台管理都是由我们组在维护. 这个系统就是将APP中的各类社交信息送到后台,然后有专门的审核人员来判断信息是否合规,当然在送到后台之前已经让 ...

  5. 神经网络 感知机 Perceptron python实现

    import numpy as np import matplotlib.pyplot as plt import math def create_data(w1=3,w2=-7,b=4,seed=1 ...

  6. hdu 5172 GTY's gay friends(线段树最值)

    题意: GTY有n个朋友,站成一排,每个人有一个特征值ai. 有m个询问.每次询问给两个数L,R.问你[L,R](即aL...aR)是否是1..(R-L+1)的一个全排列. 是输出YES,否则输出NO ...

  7. Python之模块导入(不看会后悔系列)

    看到这个标题猜想大家内心OS: 什么辣鸡水文,划走划走~ 别急有干货! 静态导入(照顾新人) 假设现在有两个文件a,b在不同目录,b文件想引用a文件中的函数: # test_module/sub_mo ...

  8. 羽夏看Win系统内核——驱动篇

    写在前面   此系列是本人一个字一个字码出来的,包括示例和实验截图.由于系统内核的复杂性,故可能有错误或者不全面的地方,如有错误,欢迎批评指正,本教程将会长期更新. 如有好的建议,欢迎反馈.码字不易, ...

  9. java注解@Transactional事务类内调用不生效问题及解决办法

    @Transactional 内部调用例子 在 Spring 的 AOP 代理下,只有目标方法由外部调用,目标方法才由 Spring 生成的代理对象来管理,这会造成自调用问题.若同一类中的其他没有@T ...

  10. 问题 L: Yougth的最大化

    题目描述 Yougth现在有n个物品的重量和价值分别是Wi和Vi,你能帮他从中选出k个物品使得单位重量的价值最大吗? 输入 有多组测试数据 每组测试数据第一行有两个数n和k,接下来一行有n个数Wi和V ...