R 语言学习教程,从入门到精通,R 绘图饼图(22)

server/2024/9/23 11:20:06/

1、R 绘图 饼图

R 语言提供来大量的库来实现绘图功能。
饼图,或称饼状图,是一个划分为几个扇形的圆形统计图表,用于描述量、频率或百分比之间的相对关系。
R 语言使用 pie() 函数来实现饼图,语法格式如下:

pie(x, labels = names(x), edges = 200, radius = 0.8,clockwise = FALSE, init.angle = if(clockwise) 90 else 0,density = NULL, angle = 45, col = NULL, border = NULL,lty = NULL, main = NULL,)

x: 数值向量,表示每个扇形的面积。
labels: 字符型向量,表示各扇形面积标签。
edges: 这个参数用处不大,指的是多边形的边数(圆的轮廓类似很多边的多边形)。
radius: 饼图的半径。
main: 饼图的标题。
clockwise: 是一个逻辑值,用来指示饼图各个切片是否按顺时针做出分割。
angle: 设置底纹的斜率。
density: 底纹的密度。默认值为 NULL。
col: 是表示每个扇形的颜色,相当于调色板。
绘制饼状图要做这些准备:反映数量的向量、各部分的标签、各部分的颜色(可选)。
接下来我们绘制一个简单的饼图:

# 数据准备
info = c(1, 2, 4, 8)
# 命名
names = c("Google", "Nhooo", "Taobao", "Weibo")
# 涂色(可选)
cols = c("#ED1C24","#22B14C","#FFC90E","#3f48CC")
# 绘图
pie(info, labels=names, col=cols)

执行绘图程序,会在当前目录下生存一个 PDF 文件(Rplots.pdf),打开文件可以看到图形效果如下:
在这里插入图片描述
我们也可以使用 png()、jpeg()、bmp() 函数设置输出的文件格式为图片:

# 数据准备
info = c(1, 2, 4, 8)
# 命名
names = c("Google", "Nhooo", "Taobao", "Weibo")
# 涂色(可选)
cols = c("#ED1C24","#22B14C","#FFC90E","#3f48CC")
# 设置输出图片
png(file='nhooo-pie.png', height=300, width=300)
# 绘图
pie(info, labels=names, col=cols)

接下来我们给饼图设置标题,中文字体需要设置字体参数 family=‘GB1’,也可以自己设置字体库,详细参考:R 绘图 - 中文支持。

# 数据准备
info = c(1, 2, 4, 8)
# 命名
names = c("Google", "Nhooo", "Taobao", "Weibo")
# 涂色(可选)
cols = c("#ED1C24","#22B14C","#FFC90E","#3f48CC")
# 计算百分比
piepercent = paste(round(100*info/sum(info)), "%")
# 绘图
pie(info, labels=piepercent, main = "网站分析", col=cols, family='GB1')
# 添加颜色样本标注
legend("topright", names, cex=0.8, fill=cols)

在这里插入图片描述
如果要绘制 3D 的饼图,可以使用 plotrix 库的 pie3D() 函数,使用前我们需要先安装:

install.packages("plotrix", repos = "https://mirrors.ustc.edu.cn/CRAN/")
# 载入 plotrix
library(plotrix)
# 数据准备
info = c(1, 2, 4, 8)# 命名
names = c("Google", "Nhooo", "Taobao", "Weibo")# 涂色(可选)
cols = c("#ED1C24","#22B14C","#FFC90E","#3f48CC")# 设置文件名,输出为 png
png(file = "3d_pie_chart.png")# 绘制 3D 图,family 要设置你系统支持的中文字体库
pie3D(info,labels = names,explode = 0.1, main = "3D 图",family = "STHeitiTC-Light")

http://www.ppmy.cn/server/104983.html

相关文章

《第二十七章 性能优化 - 内存优化》

一、引言 在 Android 应用开发中,性能优化是至关重要的一环。良好的性能不仅能提升用户体验,还能减少应用崩溃的概率。其中,内存优化是性能优化的关键部分。在本章中,我们将重点探讨如何避免内存泄漏以及进行图片内存优化。 二、避…

TOMCAT-企业级WEB应用服务器

一 WEB技术 1.1 HTTP协议和B/S 结构 HTTP(HyperText Transfer Protocol)协议即超文本传输协议,是用于在万维网(WWW)上传输超文本内容的基础协议。 一、HTTP 协议的特点 1、简单快速 客户向服务器请求服务时&#…

ARM架构的BootLoader详解——对于Linux与Baremetal(裸机MCU)

BootLoader(引导加载器)是启动嵌入式系统时执行的第一个程序,位于固件中。它主要负责初始化系统硬件、加载操作系统,并将控制权转移到操作系统的启动过程。 关于Linux 引导加载程序的引入 嵌入式Linux系统从软件角度可以分为四…

探索Edge-TTS与WebSocket集成:打造实时语音交互系统

本文为实现 WebSocket 将文本转换为语音并返回 Base64 数据给 Vue 客户端【干货】 在本文中,我们将构建一个简单的系统,该系统能够接收文本输入,通过 Microsoft Edge 的文本到语音服务(Edge TTS)转换为语音&#xff0c…

element组件封装

1.上传组件 <!--文件上传组件--> <template><div class"upload-file"><el-uploadref"fileUpload"v-if"props.type default":action"baseURL other.adaptationUrl(props.uploadFileUrl)":before-upload"h…

如何有效地学习数据科学

在当今这个信息爆炸的时代&#xff0c;数据科学作为一门跨学科领域&#xff0c;正日益受到广泛关注。无论是学术研究还是商业应用&#xff0c;数据科学都发挥着举足轻重的作用。然而&#xff0c;对于初学者来说&#xff0c;如何有效地学习数据科学成为了一个挑战。本文将分享一…

在scss中如何使用hover(Vue项目)

在Vue项目中使用SCSS时&#xff0c;可以在样式标签中添加lang"scss"属性来启用SCSS。然后可以在样式中定义hover效果。 以下是一个简单的例子&#xff1a; <template> <div class"my-element"> Hover over me! </div> </template&…

Redis核心技术

Redis是什么 Redis是以键值对&#xff0c;kv的形式存储的NoSQL数据库。它支持多种数据类型&#xff0c;能进行多种操作&#xff0c;如get&#xff0c;put&#xff0c;delete&#xff0c;scan,它的键值对保存在内存&#xff0c;使用网络框架访问&#xff0c;单线程&#xff0c;…