R语言绘图系列:
- R语言可视化及作图1--基础绘图(par函数,散点图,盒形图,条形图,直方图)
- R语言可视化及作图2--低级绘图函数
- R语言可视化及作图3--图形颜色选取
- R语言可视化及作图4--qplot和ggplot2美学函数
- R语言可视化及作图5--ggplot2基本要素和几何对象汇总
- R语言可视化及作图6--ggplot2之点图、条形图、盒形图、直方图、线图
- R语言可视化及作图7--ggplot2之标签、图例和标题绘制
1. 坐标轴自定义函数
1. 1:标度函数scale
在ggplot2中,坐标轴不是一个几何对象,而必须要由标度函数scale来进行调节。
例1:
library(ggplot2)
p1 <- ggplot(mpg,aes(displ,hwy))+geom_point()
p1
data:image/s3,"s3://crabby-images/1773f/1773f70b8a62ff85bee3e8f1dda7a443ac684c52" alt=""
使用scale_x_continous和scale_y_continous定义x轴和y轴标签
p1 + scale_x_continuous('Engine displacement(L)')+scale_y_continuous('Highway MPG')
data:image/s3,"s3://crabby-images/8acff/8acff302d55e345c9eff8db7b038de862120da2b" alt=""
去掉x轴标签和y轴标签
p1+labs(x=NULL,y=NULL) #xlab和ylab也是用来定义值标签,但是功能较单一。
data:image/s3,"s3://crabby-images/fbde6/fbde67fcc5bc5f233b24e5985bb6a7773dcbc92c" alt=""
限制x轴和y轴取值范围
p1+scale_x_continuous(limits = c(0,10))
data:image/s3,"s3://crabby-images/34df0/34df000a481712e69fa96b49288e1b1abc30524a" alt=""
定义x轴刻度并命名
p1+scale_x_continuous(breaks = c(2,4,6),labels = c('two','four','six'))
data:image/s3,"s3://crabby-images/57455/57455e7994b5fbf946cd7ea6fac47c98b5e7ff8b" alt=""
例2:
df <- data.frame(x=rnorm(10)*100000,y=seq(0,1,length.out=10))
p2 <- ggplot(df,aes(x,y))+geom_point()
p2
data:image/s3,"s3://crabby-images/ffcb3/ffcb3c434d8ce8dea22a66b08a8b9a4da8f24049" alt=""
把y轴刻度变成百分数形式
p2+scale_y_continuous(labels = scales::percent)
data:image/s3,"s3://crabby-images/4ae92/4ae9260a4cb14fe72be1e5d30a55d68da8fe7b7c" alt=""
例3:
针对离散型变量的操作用scale_x_discrere函数
d <- ggplot(subset(diamonds,carat>1),aes(cut,clarity))+geom_jitter()
d
data:image/s3,"s3://crabby-images/28b85/28b85064cc11d6c6140b962452d0b458c9edac78" alt=""
定义刻度
d+scale_x_discrete('Cut',labels=c('Fair'='F','Good'='G','very good'='VG','Premium'='P','Ideal'='I'))
data:image/s3,"s3://crabby-images/4447a/4447a281bbb72ba75e5c46145256752591c25e6f" alt=""
离散型变量limits选取(相当于取子集)
d+scale_x_discrete(limits=c('Fair','Ideal'))
data:image/s3,"s3://crabby-images/91ff1/91ff1b8c752310ecaf42545c0d898196060e7ff1" alt=""
例4:
ggplot(mpg,aes(reorder(manufacturer,displ),cty))+geom_point()+scale_x_discrete(labels=abbreviate)
data:image/s3,"s3://crabby-images/f986f/f986f8638f143835c032131a9c94c71666f6f38f" alt=""
1. 2:theme函数
设置坐标轴的颜色和线条等
p <- ggplot(mtcars,aes(mpg,wt))+geom_point()
p+theme(axis.title = element_text(color = 'red',size = 18),
#定义坐标轴主题
axis.line = element_line(color = 'blue'),
#定义坐标轴横线
axis.text = element_text(color = 'orange',size = 12),
#定义坐标轴刻度标签
axis.ticks=element_line(color = 'light skyblue',size = 3))
data:image/s3,"s3://crabby-images/8c795/8c795a4759fc0f1651d5f2fc6a8ac9204fe0186f" alt=""
除了标度函数可以自定义坐标轴外,theme()函数也有相应的功能。下表列出了theme()函数中关于坐标轴的一些参数及其用法
参数 | 用法 | 功能 |
---|---|---|
axis.title | 接受函数element_text() | 定义图形坐标轴主题的样式 |
axis.title.x/y | 接受函数element_text() | 分别定义x,y轴的主题样式 |
axis.text | 接受函数element_text() | 定义坐标轴刻度标签样式 |
axis.text.x/y | 接受函数element_text() | 定义x,y轴刻度标签样式 |
axis.ticks | 接受函数element_text() | 定义坐标轴刻度样式 |
axis.ticks.x/y | 接受函数element_text() | 定义x,y轴刻度样式 |
axis.line | 接受函数element_text() | 定义坐标轴横线样式 |
axis.line.x/y | 接受函数element_text() | 定义x,y轴横线样式 |
2. 坐标系转换函数
2.1:极坐标转换函数coord_polar()
library(ggplot2)
a <- ggplot(data=subset(diamonds,color=='E'),aes(factor('E'),fill=cut))+geom_bar()
a #绘制普通的堆叠条图
data:image/s3,"s3://crabby-images/a6fc1/a6fc123b18d32262303eb2a2a1c6d2655e3a2055" alt=""
b <- ggplot(data=subset(diamonds,color=='E'),aes(factor('E'),fill=cut))+geom_bar()+
coord_polar()
b #使用 coord_polar()进行极坐标转换
data:image/s3,"s3://crabby-images/eb813/eb8133dea9fda4e7ffa19cceb245320486a8c7fb" alt=""
c <- ggplot(data=subset(diamonds,color=='E'),aes(factor('E'),fill=cut))+geom_bar()+
coord_polar(theta = 'y')
c
data:image/s3,"s3://crabby-images/6b73f/6b73fd77ec0143f77b7f5928db7254718600e764" alt=""
c+theme(axis.text = element_blank(),
axis.title = element_blank(),
axis.ticks = element_blank(),
panel.background = element_blank(),#去图形背景
panel.grid = element_blank()#去图形背景网格线
)
data:image/s3,"s3://crabby-images/8a9e0/8a9e0098ffa7085e6d92acea9d040b6f70bd53c9" alt=""
2.2:坐标轴转换函数: coord_flip()
在笛卡尔坐标系上进行flip
dsmall <- diamonds[sample(1:nrow(diamonds),1000),]
a <- ggplot(dsmall,aes(color,price))+geom_boxplot(fill='darkgreen')+
coord_flip()
a
data:image/s3,"s3://crabby-images/aa0fb/aa0fbaa6d4438eedcf6585f3a1a6741e311bbcb9" alt=""
dsmall <- diamonds[sample(1:nrow(diamonds),1000),]
a <- ggplot(dsmall,aes(color,price))+geom_boxplot(fill='darkgreen')+
coord_flip()
a
data:image/s3,"s3://crabby-images/54890/5489040546b390d2e9fec068960c29b3dd6650e1" alt=""
网友评论