本文整理至ggtreeExtra文档,仅用于学习
作者:Shuangbin Xu and GuangChuang Yu
链接:https://bioconductor.org/packages/devel/bioc/vignettes/ggtreeExtra/inst/doc/ggtreeExtra.html
1 安装依赖(R4.1.1)
ggExtra release version
if (!requireNamespace("BiocManager", quietly=TRUE))
install.packages("BiocManager")
BiocManager::install("ggtreeExtra")
BiocManager::install("ggstar")
BiocManager::install("knitr") # 仅用于读文件
# 加载依赖
library(ggtreeExtra)
library(ggstar)
library(ggtree)
library(ggplot2)
library(treeio)
library(ggnewscale)
library(knitr) # 仅用于读文件
2 输入文件
# 树,文件路径
trfile <- system.file("extdata", "tree.nwk", package="ggtreeExtra")
# 点,文件路径
tippoint1 <- system.file("extdata", "tree_tippoint_bar.csv", package="ggtreeExtra")
# 第一圈,文件路径
ring1 <- system.file("extdata", "first_ring_discrete.csv", package="ggtreeExtra")
# 第二圈,文件路径
ring2 <- system.file("extdata", "second_ring_continuous.csv", package="ggtreeExtra")
3 base tree
tree <- read.tree(trfile)
data = fortify(tree)
head(data)
data:image/s3,"s3://crabby-images/8db8b/8db8b1b7584c448464f9be75eb18bd7a20ea12a5" alt=""
p <- ggtree(tree, layout="fan", open.angle=10, size=0.5)
p
data:image/s3,"s3://crabby-images/5f257/5f2574ca4a176f0e74581a60c7aa8bedbaa9581c" alt=""
add star
dat1 <- read.csv(tippoint1)
knitr::kable(head(dat1))
data:image/s3,"s3://crabby-images/03a60/03a6070137a2f5300627815e42f40349acce33fe" alt=""
p2 <- p +
geom_fruit(
data=dat1,
geom=geom_star,
mapping=aes(y=ID, fill=Location, size=Length, starshape=Group),
position="identity",
starstroke=0.2
) +
scale_size_continuous(
range=c(1, 3), # the range of size.
guide=guide_legend(
keywidth=0.5,
keyheight=0.5,
override.aes=list(starshape=15),
order=2
)
) +
scale_fill_manual(
values=c("#F8766D", "#C49A00", "#53B400", "#00C094", "#00B6EB", "#A58AFF", "#FB61D7"),
guide="none"
) +
scale_starshape_manual(
values=c(1, 15),
guide=guide_legend(
keywidth=0.5,
keyheight=0.5,
order=1
)
)
p2
data:image/s3,"s3://crabby-images/abc60/abc600008cadb533f52d3f0d9e373666f148e6ab" alt=""
add heatmap
dat2 <- read.csv(ring1)
knitr::kable(head(dat2))
data:image/s3,"s3://crabby-images/6814a/6814af5b4d426dfbcf0b5e9b4a3ffb0c5f4c6582" alt=""
data:image/s3,"s3://crabby-images/f8a28/f8a28bdd6eb83129a3fdc37071ba6b63aa63c7e2" alt=""
p3 <- p2 +
new_scale_fill() +
geom_fruit(
data=dat2,
geom=geom_tile,
mapping=aes(y=ID, x=Pos, fill=Type),
offset=0.08, # The distance between external layers, default is 0.03 times of x range of tree.
pwidth=0.25 # width of the external layer, default is 0.2 times of x range of tree.
) +
scale_fill_manual(
values=c("#339933", "#dfac03"),
guide=guide_legend(keywidth=0.5, keyheight=0.5, order=3)
)
p3
data:image/s3,"s3://crabby-images/8347c/8347ca071032548c5cfb537cf3e2411d06b5faf9" alt=""
dat3 <- read.csv(ring2)
knitr::kable(head(dat3))
data:image/s3,"s3://crabby-images/8ebef/8ebef74b35e332f486a58e76abaa1e9d4a4df635" alt=""
data:image/s3,"s3://crabby-images/9ec8f/9ec8f5db8e00a4a817730d7ab7750069231cc0c8" alt=""
p4 <- p3 +
new_scale_fill() +
geom_fruit(
data=dat3,
geom=geom_tile,
mapping=aes(y=ID, x=Type2, alpha=Alpha, fill=Type2),
pwidth=0.15,
axis.params=list(
axis="x", # add axis text of the layer.
text.angle=-45, # the text angle of x-axis.
hjust=0 # adjust the horizontal position of text of axis.
)
) +
scale_fill_manual(
values=c("#b22222", "#005500", "#0000be", "#9f1f9f"),
guide=guide_legend(keywidth=0.5, keyheight=0.5, order=4)
) +
scale_alpha_continuous(
range=c(0, 0.4), # the range of alpha
guide=guide_legend(keywidth=0.5, keyheight=0.5, order=5)
)
p4
data:image/s3,"s3://crabby-images/24d1f/24d1fe4dc236593f38a531a212bd8001efaaefb1" alt=""
add bar
p5 <- p4 +
new_scale_fill() +
geom_fruit(
data=dat1,
geom=geom_bar,
mapping=aes(y=ID, x=Abundance, fill=Location), #The 'Abundance' of 'dat1' will be mapped to x
pwidth=0.4,
stat="identity",
orientation="y", # the orientation of axis.
axis.params=list(
axis="x", # add axis text of the layer.
text.angle=-45, # the text size of axis.
hjust=0 # adjust the horizontal position of text of axis.
),
grid.params=list() # add the grid line of the external bar plot.
) +
scale_fill_manual(
values=c("#F8766D", "#C49A00", "#53B400", "#00C094", "#00B6EB", "#A58AFF", "#FB61D7"),
guide=guide_legend(keywidth=0.5, keyheight=0.5, order=6)
) +
theme(#legend.position=c(0.96, 0.5), # the position of legend.
legend.background=element_rect(fill=NA), # the background of legend.
legend.title=element_text(size=7), # the title size of legend.
legend.text=element_text(size=6), # the text size of legend.
legend.spacing.y = unit(0.02, "cm") # the distance of legends (y orientation).
)
p5
data:image/s3,"s3://crabby-images/7ca80/7ca802052478383b2940b8b159809233017c9e22" alt=""
模拟树和注释文件
set.seed(1024)
# generate a tree contained 100 tip labels.
tr <- rtree(100)
# generate three datasets, which are the same except the third column name.
dt <- data.frame(id=tr$tip.label, value=abs(rnorm(100)), group=c(rep("A",50),rep("B",50)))
df <- dt
dtf <- dt
colnames(df)[[3]] <- "group2"
colnames(dtf)[[3]] <- "group3"
data:image/s3,"s3://crabby-images/96169/961695134900d92a00f9dd50ee4710dc246991ae" alt=""
base
test_p <- ggtree(tr, layout="fan", open.angle=0)
test_p
data:image/s3,"s3://crabby-images/658d3/658d3606eff25eda130e66903d423340afbc6c4e" alt=""
add bar one
test_p1 <- test_p +
geom_fruit(
data=dt,
geom=geom_bar,
mapping=aes(y=id, x=value, fill=group),
orientation="y",
stat="identity"
) +
new_scale_fill()
test_p1
data:image/s3,"s3://crabby-images/92c6e/92c6e9ab43f1f85158277c6f2362defd7212a59a" alt=""
add bar two
test_p2 <- test_p1 +
geom_fruit_list(
geom_fruit(
data = df,
geom = geom_bar,
mapping = aes(y=id, x=value, fill=group2),
orientation = "y",
stat = "identity"
),
scale_fill_manual(values=c("blue", "red")), # To map group2
new_scale_fill(), # To initialize fill scale.
geom_fruit(
data = dt,
geom = geom_star,
mapping = aes(y=id, x=value, fill=group),
size = 2.5,
color = NA,
starstroke = 0
)
) +
new_scale_fill()
test_p2
data:image/s3,"s3://crabby-images/52cd7/52cd7e46168587b2f7711488bef1a1ef16221b7a" alt=""
add bar three
test_p3 <- test_p2 +
geom_fruit(
data=dtf,
geom=geom_bar,
mapping = aes(y=id, x=value, fill=group3),
orientation = "y",
stat = "identity"
) +
scale_fill_manual(values=c("#00AED7", "#009E73"))
test_p3
data:image/s3,"s3://crabby-images/e32da/e32da861ab2a44ce323cfb2673419ed68250b552" alt=""
data:image/s3,"s3://crabby-images/a72ba/a72ba86cd5ce8fd6dc54ec6648494a4deebb2bff" alt=""
data:image/s3,"s3://crabby-images/fde67/fde67563a614c7025e08a120201b211e30053c36" alt=""
网友评论