1、Aesthetic mappings
library(ggplot2)
p <- ggplot(mtcars, aes(x = mpg, y = wt))
p + geom_point()
data:image/s3,"s3://crabby-images/ee056/ee056652188596650ce79bebcc7b13602173e772" alt=""
p + geom_point(aes(colour = factor(cyl))) #cyl为整型
#Add aes(colour = factor(cyl)) =====> aes(x = mpg, y = wt, colour = factor(cyl))
data:image/s3,"s3://crabby-images/6db3f/6db3f7137b20709a6819b7b9cfb4a6b691b8c1ac" alt=""
p + geom_point(aes(y = disp)) #将y轴的数据更改为disp,但要注意y轴标签名不会更改
#Override aes(y = disp) ======> aes(x = mpg, y = disp) 覆盖
#Remove aes(y = NULL) ======> aes(x = mpg) 删除
data:image/s3,"s3://crabby-images/ef4f8/ef4f830dbd89961d3e8017742ff4a9c1179cbbb9" alt=""
关于颜色设置有两种方式: Setting vs Mapping
Mapping: aes(colour = cut)
Setting: colour = "blue"
# Setting
p + geom_point(colour = "green")
data:image/s3,"s3://crabby-images/49fcf/49fcfaceb014c4a2b034c4d579cddbe171c24508" alt=""
# Mapping
p + geom_point(aes(colour = "green"))
data:image/s3,"s3://crabby-images/7a555/7a555420ea6d6e015b7943b748c636fee7793acc" alt=""
# Mapping
#倘若希望为指定的颜色
p + geom_point(aes(colour = I("green")))
# 因为Mapping默认的是一组向量,颜色为内部默认的颜色
data:image/s3,"s3://crabby-images/3099c/3099cde8ef2c6b4f7bf1ddd6165051a045674cea" alt=""
分组 grouping
分组和分面都用于对数据分组,便于观察各自的规律、趋势和模式,不同的是,分组是把图形绘制到一个大的图形中,通过美学特征来区分,而分面是把图形绘制到不同的网格中。
library(nlme) #nlme包中有许多数据集
dat <- Oxboys
data:image/s3,"s3://crabby-images/acedb/acedbad9119edbe6e65a58c8670d83a3273b3c2c" alt=""
p <- ggplot(dat, aes(age, height, group = Subject)) + geom_line()
p
#按照Subject来分组,那些下面应该有26条线,注意分组的依据应当是因子类型
data:image/s3,"s3://crabby-images/7c897/7c8970e0d29bf11896fe7be22aca6c4f803ed097" alt=""
p <- ggplot(dat, aes(age, height, group = 1)) + geom_line()
p
# group = 1则不论1改为多大的值,下图中都只会有一条线,相当于分为一组,不加group和group = 1等同
data:image/s3,"s3://crabby-images/e7158/e7158dc379ddd523dae3196b03d5391696611464" alt=""
#Different groups on different layers 即将在不同的图层中设置分组
p <- ggplot(dat, aes(age, height, group = Subject)) + geom_line()
p + geom_smooth(aes(group = Subject), method = "lm", se = F)
data:image/s3,"s3://crabby-images/d0b9c/d0b9c33e98f406237bcb8424e7d9276cab4b3b10" alt=""
p <- ggplot(dat, aes(age, height, group = Subject)) + geom_line()
p + geom_smooth(aes(group = 1), method = "lm", se = F, size = 2)
#不加group和group = 1等同 ,相当于把所有组当作一个整体来构建smooth
data:image/s3,"s3://crabby-images/7155a/7155a404f9f5d0bb9c074d98de53fc9423f0df7e" alt=""
p <- ggplot(dat, aes(age, height, group = 1)) + geom_line()
p + geom_smooth(aes(group = Subject), method = "lm", se = F)
data:image/s3,"s3://crabby-images/c0fa7/c0fa7b4cb8d6d863e2679d7a976e615d41bd49c0" alt=""
p <- ggplot(dat, aes(age, height, group = 1)) + geom_line()
p + geom_smooth(aes(group = 1), method = "lm", se = F)
data:image/s3,"s3://crabby-images/b0fe5/b0fe5bab40f7d924d11e5d5ede578d4abd99dd10" alt=""
boysbox <- ggplot(Oxboys, aes(Occasion, height)) + geom_boxplot() #Occasion为因子类型
boysbox
data:image/s3,"s3://crabby-images/2a84c/2a84c12e66efc21cc5b20a419c0e9bcc618c9a50" alt=""
boysbox + geom_line(aes(group = Subject),colour = "green")
data:image/s3,"s3://crabby-images/c3f90/c3f90df0b050b839d8c707558d21008e91c6c7d0" alt=""
2、Position adjustments
ggplot(diamonds,
aes(clarity, fill = cut)) + geom_bar(position = "stack")
data:image/s3,"s3://crabby-images/e570f/e570fcaca9ae68583e543f2df6b3c22b625fea9c" alt=""
ggplot(diamonds,
aes(clarity, fill = cut)) + geom_bar(position = "fill")
data:image/s3,"s3://crabby-images/f7dd0/f7dd04201228087196614229cd7c04fe8cff7d48" alt=""
ggplot(diamonds,
aes(clarity, fill = cut)) + geom_bar(position = "dodge")
data:image/s3,"s3://crabby-images/cfac4/cfac4adc939c77aed7bcdf8158cdc4646b40ba33" alt=""
ggplot(diamonds,
aes(clarity, price, colour = cut)) + geom_point(position = "jitter")
data:image/s3,"s3://crabby-images/18531/1853176af4f40fce310dbe4b2c03a52388f78a17" alt=""
ggplot(diamonds,
aes(clarity, price, colour = cut)) + geom_point(position = "identity")
data:image/s3,"s3://crabby-images/8921b/8921b53e0e1cda217e90d9abd7a69253d9421be4" alt=""
网友评论