当前位置: 首页 > news >正文

R语言绘图-3-Circular-barplot图

0. 参考:

https://r-graph-gallery.com/web-circular-barplot-with-R-and-ggplot2.html

1. 说明:

利用 ggplot 绘制 环状的条形图 (circular barplot),并且每个条带按照数值大小进行排列。

2 绘图代码:

注意:绘图代码中的字体为 “Times New Roman”,如果没有这个字体的话,可以更换为其他字体,或者用下面代码加载改字体:

## 加载字体
library(extrafont)
font_import(pattern = "Times New Roman")
loadfonts()
## 绘图
library(stringr)
library(dplyr)
library(geomtextpath)
library(ggplot2)## 加载原始数据集
hike_data <- readr::read_rds(url('https://raw.githubusercontent.com/rfordatascience/tidytuesday/master/data/2020/2020-11-24/hike_data.rds')) ## 如果不能加载数据,就通过链接把 hike_data.rds 下载下来,然后再通过 readr::read_rds() 加载数据
#hike_data <- readr::read_rds("/Users/zhiyuanzhang/Downloads/hike_data.rds")
hike_data$region <- as.factor(word(hike_data$location, 1, sep = " -- "))## 分组统计 region 的数目
plot_df <- hike_data %>%group_by(region) %>%summarise(n = n())## 新增一列 location,将其转化为 factor,顺序为region数目生序排列
plot_df$location = factor(plot_df$region, levels = c(levels(reorder(plot_df$region, plot_df$n))))## 绘图
ggplot(plot_df) +## 绘制横线geom_hline(aes(yintercept = y), data.frame(y = c(0,1,3.5) * 100), ## 根据 location 数目的最大值设定范围(可理解为 y 的范围)color = "lightgrey",) +## 绘制条形图geom_col(aes(x = reorder(location, n),y = n,fill = location),position = "dodge2",show.legend = FALSE, ## 不显示图例alpha = .9) +## 自定义每个条形图的填充色scale_fill_manual(values=c("red", "orange", "yellow", "green", "cyan", "blue", "purple", "brown", "gray", "pink", "darkgreen"), labels=c(levels(plot_df$location)),name="Location") + ## 有图例的话,图例的名称为 Location## 绘制线段geom_segment(aes(x = reorder(location, n),y = 0,xend = reorder(location, n),yend = 350 ## 和上面一样,根据数目进行调整),linetype = "dashed",color = "gray") +## 变成环形图coord_polar() +## 添加文本注释,同时保证文本的方向是和环的方向一致的geom_textpath(aes(x = location, y=n, label = n), hjust=0.5, vjust=1, colour = "Black",family="Times New Roman", size=5) +## 添加文本注释,代替坐标轴中文本geom_textpath(aes(x = location, y=350, label = location), hjust=0.5, vjust=2, colour = "Black",family="Times New Roman", size=6) + ## y 指定文本位置## 构造一个内环scale_y_continuous(limits = c(-50, 350),expand = c(0, 0)) +## 添加标题labs(title = "Example of circular barplot") +## 修改主题theme(## 设置全部文本的字体text = element_text(family = "Times New Roman", face="bold"),## 设置标题的字体plot.title = element_text(size = 25, hjust = 0.5),## 将画布背景设置为白色,并去掉画布的线panel.background = element_rect(fill = "white", color = "white"),panel.grid = element_blank(),panel.grid.major.x = element_blank(),## 设置坐标轴axis.title = element_blank(),axis.ticks = element_blank(),axis.text.y = element_blank(),axis.text.x = element_blank(), ## 将 x 轴文本设为空,用上面 geom_textpath 添加的文本做替换## 设置图例(如果有的话,因为上面设置了 show.legend = FALSE,所以不会显示图例)legend.title = element_blank(),legend.text = element_text(size=12),legend.position = "right")

3. 结果:

在这里插入图片描述

http://www.lryc.cn/news/173530.html

相关文章:

  • 解决Keil5下载没有对应芯片Flash的问题
  • 深拷贝与浅拷贝(对象的引用)
  • 重新认识架构—不只是软件设计
  • 我的创业笔记:困境与思索
  • minio文件上传
  • IDEA .iml文件及.idea文件夹详解
  • 使用Python做一个微信机器人
  • 云计算战略:选择适合你业务的云平台
  • Python:打印目录下每层的文件总数
  • LVS-NAT模式
  • 【神印王座】龙皓晨竟然上了头版头条!内容违背,新闻真实性原则
  • C++之类和函数权限访问总结(二百二十七)
  • 手动部署 OceanBase 集群
  • 【操作系统笔记十二】Linux常用基础命令
  • Compose LazyColumn 对比 RecyclerView ,谁的性能更好?
  • [python 刷题] 49 Group Anagrams
  • vue+element plus 使用table组件,清空用户的选择项
  • 改写软件-怎么选择改写软件
  • gateway之跨域处理
  • uniapp 实现不同用户展示不同的tabbar(底部导航栏)
  • 线性归一化是什么,用python实现数据的线性归一化
  • 超级好用绘图工具(Draw.io+Github)
  • 全国职业技能大赛云计算--高职组赛题卷③(私有云)
  • Redis SCAN命令操作实战(详细)
  • 计网第五章(运输层)(六)(TCP可靠传输的实现)
  • 酒店外卖小程序商城的作用是什么
  • 居家养老一键通的功能
  • 海外代理IP是什么?如何使用?
  • mmdetection v3避坑
  • 备份服务器数据库并保存到Git仓库