如何用R语言ggforce包画饼状图
发表于:2025-02-04 作者:千家信息网编辑
千家信息网最后更新 2025年02月04日,这篇文章将为大家详细讲解有关如何用R语言ggforce包画饼状图,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。image.png最近在看论文 Phas
千家信息网最后更新 2025年02月04日如何用R语言ggforce包画饼状图
这篇文章将为大家详细讲解有关如何用R语言ggforce包画饼状图,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
最近在看论文 Phased diploid genome assemblies and pan-genomes provide insights into the genetic history of apple domestication 今天的笔记记录的是论文中Figure2图b中的饼图的画法
第一步还是准备数据ggplot2画拼图我个人认为相对是比较麻烦的,而且要实现上图这种各个部分能够分开的好像不太好实现。之前找饼状图的资料的时候发现了
ggforce
这个包,用他来做饼图相对方便很多,今天的内容主要用这个包里的函数来实现
数据只需要两列就可以了
第一次用ggforce这个包还是需要先安装install.packages("ggforce")
最基本的饼图代码如下df1<-read.csv("pieplot/AA.csv",header = T)
df1
ggplot()+
geom_arc_bar(data=df1,
stat = "pie",
aes(x0=0,y0=0,r0=0,r=2,
amount=value,fill=Var,
explode=c(0.05,0.05,0.05,0)),
)
关键还可以把中间给弄成空心的
ggplot()+
geom_arc_bar(data=df1,
stat = "pie",
aes(x0=0,y0=0,r0=1,r=2,
amount=value,fill=Var,
explode=c(0.05,0.05,0.05,0)),
)
接下来是简单的美化,最后拼图就好了做饼状图用到的函数是
geom_arc_bar()
,这个函数里参数的作用之前录制过视频大家可以参考一下
library(ggforce)
df1<-read.csv("pieplot/AA.csv",header = T)
df1
df2<-edit(df1)
p1<-ggplot()+
geom_arc_bar(data=df1,
stat = "pie",
aes(x0=0,y0=0,r0=0,r=2,
amount=value,fill=Var,
explode=c(0.05,0.05,0.05,0)),
)+
scale_fill_manual(values = c("#80c97f","#a68dc8",
"#ffc000","#c00000"))+
annotate("text",x=0,y=-2.2,label="32.72%")+
annotate("text",x=-1.6,y=1.5,label="36.76%",angle=50)+
annotate("text",x=1.6,y=1.5,label="30.52%",angle=-50)+
theme_void()+
theme(legend.position = "none",
plot.title = element_text(hjust = 0.5,face="italic"))+
labs(title = "GDDH13")
p2<-ggplot()+
geom_arc_bar(data=df1,
stat = "pie",
aes(x0=0,y0=0,r0=0,r=2,
amount=value,fill=Var,
explode=c(0.05,0.05,0.05,0)),
)+
scale_fill_manual(values = c("#80c97f","#a68dc8",
"#ffc000","#c00000"))+
annotate("text",x=0,y=-2.2,label="32.72%")+
annotate("text",x=-1.6,y=1.5,label="36.76%",angle=50)+
annotate("text",x=1.6,y=1.5,label="30.52%",angle=-50)+
theme_void()+
theme(legend.position = "none",
plot.title = element_text(hjust = 0.5,face="italic"))+
labs(title = "GDDH13")
p3<-ggplot()+
geom_arc_bar(data=df2,
stat = "pie",
aes(x0=0,y0=0,r0=0,r=2,
amount=value,fill=Var,
explode=c(0.05,0.05,0.05,0.05)),
)+
scale_fill_manual(values = c("#80c97f","#a68dc8",
"#ffc000","#c00000"))+
annotate("text",x=0.5,y=-2.2,label="32.72%")+
annotate("text",x=-1.6,y=1.5,label="16.76%",angle=50)+
annotate("text",x=-2.2,y=0.5,label="30%",angle=80)+
annotate("text",x=1.6,y=1.5,label="30.52%",angle=-50)+
theme_void()+
theme(legend.position = "none",
plot.title = element_text(hjust = 0.5,face="italic"))+
labs(title = "GDDH13")
p3
library(cowplot)
plot_grid(p1,p2,p3,ncol = 2,nrow=2)
这样是没有图例的,我想到的办法是重新做一个图,拼接到右下角作为图例
df4<-data.frame(x=1,y=c(1,2,3,4),label=c("A","B","C","D"))
p4<-ggplot(df4,aes(x=x,y=y))+
geom_text(aes(x=x+0.2,y=y,label=label))+
geom_point(aes(color=label),show.legend = F,size=4)+
theme_void()+
ylim(-8,8)+xlim(-1,3)+
scale_color_manual(values = c("#80c97f","#a68dc8",
"#ffc000","#c00000"))
plot_grid(p1,p2,p3,p4,ncol = 2,nrow=2)
最终的效果如下
关于如何用R语言ggforce包画饼状图就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
内容
函数
语言
图例
数据
文章
更多
知识
篇文章
论文
还是
参考
不错
接下来
上图
个人
代码
作用
关键
办法
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全导论测试题
ie中设置代理服务器
买苹果电话刷数据库
网络安全法定
usdabase数据库
教委信息中心网络安全预案
sql数据库断电后丢失
无锡网络技术支持哪家好
数据库英文管理系统英文
湖北第十届网络安全知识
校园网络安全小短句
服务器上的cpu哪里买
常用ntp服务器
网络技术能自学吗
嘻哈小说软件开发
电力公司网络安全保障专项
士官学校信息网络技术
ensp的网络安全访问控制策略
个人电脑能做云服务器吗
手机为啥总显示未连接服务器
韦若琛 网络安全
平板设置时间和服务器相同
db2查询数据库表的大小
灵璧软件开发专业
慧迪软件开发
做网络技术支持还是驻厂运维
黑龙江哪里租服务器好云空间
sql数据库怎么插入记录
熊猫四川麻将软件开发者
网络安全威胁主题来自哪里