第一节 折线图简单绘制
#图1
library(ggplot2)
ggplot(BOD,aes(x = Time,y = demand))+geom_line()
#图2
#将time转换为因子变量,注意必须使用group=1
BOD1 <- BOD
BOD1$Time <- factor(BOD1$Time)
ggplot(BOD,aes(x = Time,y = demand,group=1))+geom_line()
#图3
#将纵坐标调节至0为起点
ggplot(BOD,aes(x = Time,y = demand))+geom_line()+
ylim(0,max(BOD1$demand))
#或图4
ggplot(BOD,aes(x = Time,y = demand))+geom_line()+
expand_limits(y=0)
图2中,将time转换为因子变量,注意必须使用group=1
data:image/s3,"s3://crabby-images/64d10/64d10aba9a281119d8dae2f80c5f11ad503a38bb" alt=""
图3-4 分别使用ylim(), expand_limits(y=0)延长纵坐标至0
data:image/s3,"s3://crabby-images/ebc54/ebc544e37749553614ac3b49d490da7babb71137" alt=""
第二节 向折线图添加数据标记
当纵坐标呈指数变化时,我们可以对其取对数,更方便我们观察数据的变化趋势。
library(gcookbook)
#图1
ggplot(worldpop,aes(x = Year,y = Population))+geom_point()+geom_line()
#图2,对纵坐标取对数
ggplot(worldpop,aes(x = Year,y = Population))+geom_point()+geom_line()+
scale_y_log10()
data:image/s3,"s3://crabby-images/834e5/834e524fc6788816cac865d8264601fbe7234eb0" alt=""
data:image/s3,"s3://crabby-images/2875f/2875f5c56c4ebefeae748532dd4be91888e83e99" alt=""
第三节 绘制多重折线
首先,生成我们需要的数据集,使用的是plyr包中的ddplyr函数
,这个函数功能强大,感兴趣可以通过其帮助文档大致“摸一下这只象”,以后会经常遇到它。
library(plyr)
tg <- ddply(ToothGrowth,c("supp","dose"),summarise,length=mean(len))
data:image/s3,"s3://crabby-images/d2a7e/d2a7ee37c056f469d4462e8ea06958fb0d845d4f" alt=""
开始绘制多条折线图,可以将分组信息赋予线的颜色,线条的类型等
#将supp映射至颜色
ggplot(tg,aes(x = dose,y = length,colour=supp)) +
geom_line()
#将supp映射至线的类型
ggplot(tg,aes(x = dose,y = length,linetype=supp)) +
geom_line()
data:image/s3,"s3://crabby-images/ff1e7/ff1e7eefee0413bc908743b140937b66b2211a58" alt=""
data:image/s3,"s3://crabby-images/4f244/4f2442df7021212dac7a83f0edc47d60cdd94f7a" alt=""
将分组信息赋予点的颜色和形状
#可以将分组映射至fill或shape上
ggplot(tg,aes(x = dose,y = length,shape=supp)) +
geom_line()+
geom_point(size=4)
ggplot(tg,aes(x = dose,y = length,fill=supp)) +
geom_line()+
geom_point(size=4,shape=21)
data:image/s3,"s3://crabby-images/8efbd/8efbd696323ce3ee14602e718692b688c723900e" alt=""
data:image/s3,"s3://crabby-images/7f369/7f369426de661fd08c71074ef7139ad6bad8a674" alt=""
将重合的点错开,使用position_dodge()
#将重合的点错开
ggplot(tg,aes(x = dose,y = length,shape=supp)) +
geom_line(position = position_dodge(0.2))+
geom_point(position = position_dodge(0.2),size=4)
data:image/s3,"s3://crabby-images/74bbc/74bbcd8c68d4d0e238e12fadd81f2280705057f9" alt=""
第四节 修改线条样式
library(ggplot2)
ggplot(BOD,aes(x = Time,y = demand))+
geom_line(linetype="dashed",size=1,colour="blue")
data:image/s3,"s3://crabby-images/f6755/f6755f8cc014963cae8b941a3e28339f5442a5b1" alt=""
生成需要的数据集
library(plyr)
tg <- ddply(ToothGrowth,c("supp","dose"),summarise,length=mean(len))
data:image/s3,"s3://crabby-images/03586/03586b5a8b80aadb7ced7a83b337eef52fd47e33" alt=""
ggplot(tg,aes(x = dose,y = length,colour=supp))+
geom_line()+
scale_color_brewer(palette = "Set1")
data:image/s3,"s3://crabby-images/f9a34/f9a34c52bb57f5000b10181c7cced07fad086667" alt=""
第五节 修改数据标记样式
ggplot(BOD,aes(x = Time,y = demand))+
geom_line()+
geom_point(size=4, alpha=.5, shape=22, colour="darkred", fill="pink")
data:image/s3,"s3://crabby-images/3f40a/3f40a8668825ec1df6476917164111102a7b87cb" alt=""
library(plyr)
tg <- ddply(ToothGrowth,c("supp","dose"),summarise,length=mean(len))
pd <- position_dodge(0.2)
ggplot(tg,aes(x = dose,y = length,fill=supp))+
geom_line(position = pd)+
geom_point(shape=21,size=4,position = pd)+
scale_color_manual(values = c("black","white"))
data:image/s3,"s3://crabby-images/475f5/475f5261d056ae52800e0a33c6c3c9761924c7ee" alt=""
第六节 绘制面积图
面积图的绘制靠geom_area()
sunspotyear <- data.frame(
year=as.numeric(time(sunspot.year)),
sunspots=as.numeric(sunspot.year)
)
ggplot(sunspotyear,aes(x = year,y = sunspots))+
geom_area()
data:image/s3,"s3://crabby-images/52a58/52a58b24e79277738f1a6fa0f6a698865b16150d" alt=""
ggplot(sunspotyear,aes(x = year,y = sunspots))+
geom_area(colour="black",fill="blue",alpha=.2)
data:image/s3,"s3://crabby-images/6926b/6926b603ccc0045730ea4ec93940f8609c9ea966" alt=""
第七节 绘制堆叠面积图
library(gcookbook)
ggplot(uspopage,aes(x = Year,y = Thousands,fill=AgeGroup))+
geom_area()
data:image/s3,"s3://crabby-images/16b27/16b2703769d7175fe14ef56db6b95e2564eecea0" alt=""
第八节 绘制百分比堆积面积图
关键在于得到百分比数据,绘图等同于堆叠面积图
library(gcookbook)
library(plyr)
uspopage_prop <- ddply(uspopage, "Year", transform, percent = Thousands / sum (Thousands) * 100)
ggplot(uspopage_prop,aes(x = Year,y = percent,fill=AgeGroup))+
geom_area(colour="black",size=2,alpha=.4)+
scale_color_brewer(palette = "Blues", breaks = rev(levels(uspopage$AgeGroup)))
data:image/s3,"s3://crabby-images/3d76a/3d76abb0443adbf7beb69ab8cdec07a2a552aa9f" alt=""
geom_ribbon
添加置信区间
##添加置信区间
library(gcookbook)
clim <- subset(climate,Source=="Berkeley",
select = c("Year","Anomaly10y","Unc10y"))
ggplot(clim,aes(x = Year,y = Anomaly10y))+
geom_ribbon(aes(ymin=Anomaly10y-Unc10y,ymax=Anomaly10y+Unc10y),alpha=0.2)+
geom_line()
data:image/s3,"s3://crabby-images/500a5/500a51eb816a60fec93e7e4d0d4f4d12d833ccce" alt=""
geom_line
添加置信区间
#或者直接添加线作为置信区间
ggplot(clim,aes(x = Year,y = Anomaly10y))+
geom_line(aes(y=Anomaly10y-Unc10y),colour="grey30",linetype="dotted")+
geom_line(aes(y=Anomaly10y+Unc10y),colour="grey30",linetype="dotted")+
geom_line()
data:image/s3,"s3://crabby-images/6d2aa/6d2aad39d97adba399e27da0f8f0e653ef54fa6c" alt=""
网友评论