第三章:图形初阶_《R语言实战》笔记

R绘图基础.png

plot()是R中为对象作图的一个泛型函数(它的输出将根据所绘制对象类型的不同而变化)

1.图形函数

可以通过图形函数的选项来自定义一幅图形的多个特征。

  • 可以通过par()函数和高级绘图函数直接提供的参数进行修改
    par()函数
opar=par(no.readonly=TRUE)#复制当前的图形参数设置
par(lty=2,pch=17)#修改参数——par(optionname=value,optionname=name,.....)
plot(dose,drugA,type="b")#绘制图形
par(opar)#还原设置

高级绘图函数直接提供的参数——指定选项仅对这幅图形本身有效,而且并不是所有的高级绘图函数都允许指定全部可能的图形函数

plot(dose,drugA,type="b",lty=2,pch=17)
1.1符号和线条

pch参数:

lty参数:
1.2颜色

可以通过颜色下标、颜色名称、十六进制的颜色值、RGB值或HSV值来指定颜色

  • R中有许多创建连续型颜色向量的函数:
    rainbow()
    heat.colors()
    terrain.colors()
    topo.colors()
    cm.colors()
> n=10
> mycolors=rainbow(n)#生成10种连续的彩虹型颜色
> barplot(rep(1,n),col=mycolors)
image.png
  • RColorBrewer包同样可以创建颜色
> library(RColorBrewer)
> n <- 7
> mycolors <- brewer.pal(n, "Set1")#
> barplot(rep(1,n), col=mycolors)
image.png
  • 使用gray()函数生成多阶灰度色
> mygrays=gray(0:10/10)
> pie(rep(1,n),labels=mygrays,col=mygrays)
> pie(rep(1,10),labels=mygrays,col=mygrays)
image.png
1.3文本属性
1.4图形尺寸与边界尺寸

2.添加文本、自定义坐标轴和图例

  • title()函数,可以为图形添加标题和坐标轴标签
2.1坐标轴:使用axis()来创建自定义的坐标轴

axis()函数参数

自定义坐标轴实例

x <- c(1:10)
y <- x
z <- 10/x
opar <- par(no.readonly=TRUE)
par(mar=c(5, 4, 4, 8) + 0.1)#增加边界大小
plot(x, y, type="b",pch=21, col="red",yaxt="n", lty=3, ann=FALSE)
#绘制x对y的图形,其中ann=FALSE可以移除高级函数中包含的默认标题和标签
lines(x, z, type="b", pch=22, col="blue", lty=2)#添加x对1/x的直线
axis(2, at=x, labels=x, col.axis="red", las=2)#绘制自己的坐标轴
axis(4, at=z, labels=round(z, digits=2),col.axis="blue", las=2, cex.axis=0.7, tck=-.01)
mtext("y=1/x", side=4, line=3, cex.lab=1, las=2, col="blue")#添加标题和文本
title("An Example of Creative Axes",xlab="X values",ylab="Y=X")
par(opar)
2.2参考线

abline()可以用来为图形添加参考线

2.3添加图例

使用legend()函数进行图例的添加
> dose <- c(20, 30, 40, 45, 60)
> drugA <- c(16, 20, 27, 40, 60)
> drugB <- c(15, 18, 25, 31, 40)
> opar <- par(no.readonly=TRUE)
> par(lwd=2, cex=1.5, font.lab=2)#增加线条、文本、符号、标签的宽度或大小
> plot(dose, drugA, type="b", pch=15, lty=1, col="red", ylim=c(0, 60),main="Drug A vs. Drug B",xlab="Drug Dosage", ylab="Drug Response")
> lines(dose, drugB, type="b",pch=17, lty=2, col="blue")
> abline(h=c(30), lwd=1.5, lty=2, col="gray" )
> legend("topleft", inset=.05, title="Drug Type", c("A","B"), lty=c(1, 2), pch=c(15, 17), col=c("red", "blue"))
#添加图例
2.4文本标注

可以通过text()和mtext()函数将文本添加到图形上
text(location,"text to place",pos....)
mtext("text to place",side,line=n,....)


attach(mtcars)
plot(wt, mpg,main="Mileage vs. Car Weight",xlab="Weight", ylab="Mileage",pch=18, col="blue")
text(wt, mpg,row.names(mtcars),cex=0.6, pos=4, col="red")
#其中wt、mpg是坐标信息
detach(mtcars)

3.图形的组合

函数par()和layout()可以容易地组合多幅图形到一张图里面
par():

> opar <- par(no.readonly=TRUE)
> par(mfrow=c(2,2))
#mfrow=c(2,2)表示建立2行2列排列的四个排列图形,mfrow=c(3,1)表示建立3行1列的三个排列图形。
#mfrow按行填充,mfcol按列填充
> plot(wt,mpg, main="Scatterplot of wt vs. mpg")
> plot(wt,disp, main="Scatterplot of wt vs. disp")
> hist(wt, main="Histogram of wt")
> boxplot(wt, main="Boxplot of wt")
> par(opar)
> detach(mtcars)

layout():

attach(mtcars)
layout(matrix(c(1, 1, 2, 3), 2, 2, byrow = TRUE),widths=c(3, 1), heights=c(1, 2))
#layout()的调用形式为layout(mat),mat是一个矩阵。layout(matrix(c(1,1,2,3))表示建立一个两行两列的矩阵,其中,第一行是图形1,第二行是图形2和3
#widths=各列宽度值组成的一个向量,heights=各行高度值组成的一个向量
hist(wt)
hist(mpg)
hist(disp)
detach(mtcars)

图形布局的精细控制

使用fig()函数对图形布局进行精细控制

opar <- par(no.readonly=TRUE)
par(fig=c(0, 0.8, 0, 0.8))#将下面的图限制在横向范围0-0.8,纵向范围0-0.8
plot(mtcars$wt, mtcars$mpg,xlab="Miles Per Gallon",ylab="Car Weight")
par(fig=c(0, 0.8, 0.55, 1), new=TRUE)#将下面的图限制在横向0-0.8,纵向0.55-1
boxplot(mtcars$wt, horizontal=TRUE, axes=FALSE)
par(fig=c(0.65, 1, 0, 0.8), new=TRUE#将下面的图限制在横向0。65-1,纵向0-0.8
boxplot(mtcars$mpg, axes=FALSE)                                                                                                                  
mtext("Enhanced Scatterplot", side=3, outer=TRUE, line=-3)
par(opar)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 221,198评论 6 514
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,334评论 3 398
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 167,643评论 0 360
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,495评论 1 296
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,502评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,156评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,743评论 3 421
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,659评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,200评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,282评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,424评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,107评论 5 349
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,789评论 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,264评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,390评论 1 271
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,798评论 3 376
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,435评论 2 359

推荐阅读更多精彩内容