R可视化学习-- (8) 环形柱状图

简介: 柱状图可谓是论文最常见的图表了,但有时候这种笔直排列一排的柱状图用腻了, 换种呈现方式(比如拐个弯)也可换个心情嘛,今天就先来介绍俩种构建环形柱状图的方法,分别基于ggplot2和其他的R包来绘制。

数据创建处理

Category = paste0("category", "_", 1:9)
Percent <- c(81, 77, 70, 69, 69, 68, 62, 62, 61)
Result <-data.frame(Category,Percent)
# 设置各Categroy名称
Result$Category <-
  paste0(Result$Category," - ",Result$Percent,"%")
# 设置因子水平 
Result$Category <-
  factor(Result$Category, 
         levels=rev(Result$Category))

作图

ggplot(Result, aes(x = Category, y = Percent,
                               fill = Category)) + 
  geom_bar(width = 0.9, stat="identity") + 
  coord_polar(theta = "y") +
  xlab("") + ylab("") +
  ylim(c(0,100)) +
  ggtitle("Top 9 Categories") +
  geom_text(data = Result, hjust = 1, size = 3,
            aes(x = Category, y = 0, label = Category)) +
  theme_minimal() +
  theme(legend.position = "none",
        panel.grid.major = element_blank(),
        panel.grid.minor = element_blank(),
        axis.line = element_blank(),
        axis.text.y = element_blank(),
        axis.text.x = element_blank(),
        axis.ticks = element_blank())

b87b6ecbe3dd009730162dd9ceabdbf.png

此时发现一个问题,环最中间的Category_9俨然已经变成了一个饼图形状了,都不能称之为柱状图了,所以如何将他变为空心呢?

很简单,我们增添一些数据即可~

len <- 4
df2 <- data.frame(Category = letters[1:len], Percent = rep(0, len), 
                  Category2 = rep("", len))
Result$Category2 <- Result$Category
# 合并数据
Result <- rbind(Result, df2)
Result$Category <-
  factor(Result$Category, 
         levels=rev(Result$Category))
ggplot(Result, aes(x = Category, y = Percent,
                               fill = Category2)) + 
  geom_bar(width = 0.9, stat="identity") + 
  coord_polar(theta = "y") +
  xlab("") + ylab("") +
  ylim(c(0,100)) +
  geom_text(data = Result, hjust = 1, size = 3,
            aes(x = Category, y = 0, label = Category2)) +
  theme_minimal() +
  theme(legend.position = "none",
        panel.grid.major = element_blank(),
        panel.grid.minor = element_blank(),
        axis.line = element_blank(),
        axis.text.y = element_blank(),
        axis.text.x = element_blank(),
        axis.ticks = element_blank())

57e393c3cde8aa015c670afa20feb1d.png

此时可以发现,内层的数据已经变成柱子形状,若感觉空心较大,调整len的个数即可控制了~~

其他方法—circlize包

72bf9973078e64c219c42b89538a7b5.png

Circlize包

circlize包可谓是做环状图神器,有时间会再深入学习这个包,因为发现该包的网址里也有类似的图形, 这里记录学习一下,有兴趣的可以去原网址学习下:https://jokergoo.github.io/circlize_book/book/  ,真的炒鸡详细,各类圈图应有尽有,只是代码不太ggplot,参数较多,额看你们自己了 ~~~

代码如下:

library(circlize)
color = rev(rainbow(length(Percent)))
circos.par("start.degree" = 90, cell.padding = c(0, 0, 0, 0))
circos.initialize("a", xlim = c(0, 100)) # 'a` just means there is one sector
circos.track(ylim = c(0.5, length(Percent)+0.5), track.height = 0.8, 
             bg.border = NA, panel.fun = function(x, y) {
               xlim = CELL_META$xlim
               circos.rect(rep(0, 9), 1:9 - 0.45, Percent, 1:9 + 0.45,
                           col = color, border = "white")
               circos.text(rep(xlim[1], 9), 1:9, 
                           paste(Category, " - ", Percent, "%"), 
                           facing = "downward", adj = c(1.05, 0.5), cex = 0.8) 
               breaks = seq(0, 85, by = 5)
               circos.axis(h = "top", major.at = breaks, labels = paste0(breaks, "%"), 
                           labels.cex = 0.6)
             })

f299b0cb66faea53d115ce8300986de.png

感觉比ggplot还好看一些,且外环添加上了百分比,细节满满,更多参数设置自己探索吧就~~

相关文章
XP-CLR分析笔记丨检测不同种群之间由于选择引起的差异信息,群体遗传学经典方法
XP-CLR分析笔记丨检测不同种群之间由于选择引起的差异信息,群体遗传学经典方法
|
7月前
|
数据采集 自然语言处理 并行计算
128_自我监督变体:SimCLR for Text - 推导对比学习的文本应用,代码实现无标注预训练的独特目标
在大型语言模型快速发展的今天,自我监督学习已成为训练高质量模型的核心技术。然而,传统的掩码语言建模(MLM)和因果语言建模(CLM)方法存在一些局限性,如计算效率低下和上下文利用不充分等问题。对比学习作为一种新兴的自我监督学习范式,通过学习相似性和差异性来提取数据的内在表示,为语言模型预训练提供了新的思路。
346 2
|
安全 Ubuntu Linux
Metasploit Pro 4.22.7-2025042101 发布 - 专业渗透测试框架
Metasploit Pro 4.22.7-2025042101 (Linux, Windows) - 专业渗透测试框架
351 5
Metasploit Pro 4.22.7-2025042101 发布 - 专业渗透测试框架
|
Java 开发者
Java“NoSuchElementException”问题解决
“NoSuchElementException”是Java编程中常见的异常之一,通常发生在尝试从集合或迭代器中获取不存在的元素时。本文将介绍该异常的原因、常见场景及解决方法,帮助开发者有效应对这一问题。
1192 5
|
Java
Java“NumberFormatException”解决
当尝试将字符串转换为数字时,若字符串格式不正确,则会抛出“NumberFormatException”。解决方法:1. 检查字符串是否为空或仅包含空白字符;2. 确保字符串中的字符都是数字;3. 使用异常处理捕获并处理该异常。
1005 1
|
数据处理
时间序列分析实战(一):时序平稳性和白噪声检验
时间序列分析实战(一):时序平稳性和白噪声检验
|
算法 数据可视化 安全
R语言Kmeans聚类、PAM、DBSCAN、AGNES、FDP、PSO粒子群聚类分析iris数据结果可视化比较
R语言Kmeans聚类、PAM、DBSCAN、AGNES、FDP、PSO粒子群聚类分析iris数据结果可视化比较
|
数据可视化 数据挖掘 Python
跟着Molecular Plant学作图:R语言circlize包画圈图展示基因组的一些特征补充添加图例
跟着Molecular Plant学作图:R语言circlize包画圈图展示基因组的一些特征补充添加图例
|
存储 移动开发 Python
从Scanpy的Anndata对象提取信息(适用于单细胞转录组且涉及h5文件读写)
从Scanpy的Anndata对象提取信息(适用于单细胞转录组且涉及h5文件读写)

热门文章

最新文章