ggplot2图形设计:标签与注释的艺术
2025-06-02 13:44:34作者:尤峻淳Whitney
引言
在数据可视化中,标签和注释是提升图表可读性和表达力的关键元素。本文将基于RStudio Conf 2022中关于ggplot2图形设计的研讨会内容,深入探讨如何利用ggplot2的强大功能来优化图表中的标签和注释。
准备工作
首先,我们需要加载必要的库并准备数据:
library(tidyverse)
bikes <- read_csv("london-bikes-custom.csv",
col_types = "Dcfffilllddddc")
bikes$season <- forcats::fct_inorder(bikes$season)
theme_set(theme_light(base_size = 14, base_family = "Roboto Condensed"))
基础标签设置
使用labs()函数
labs()函数是ggplot2中设置标签的主要方式,可以定义标题、副标题、坐标轴标签、图例标题等:
ggplot(bikes, aes(x = temp_feel, y = count, color = season)) +
geom_point(alpha = .5) +
labs(
x = "Feels Like temperature (°F)",
y = "Reported bike shares",
title = "TfL bike sharing trends",
subtitle = "Reported bike rents versus Feels Like temperature in London",
caption = "Data: TfL",
color = "Season:",
tag = "1."
)
通过theme()定制标签样式
标题样式调整
使用theme()可以精细控制标签的视觉表现:
g + theme(
plot.title = element_text(face = "bold"),
plot.title.position = "plot"
)
坐标轴文本样式
可以修改坐标轴文本的颜色、字体、角度等属性:
g + theme(
axis.text = element_text(
color = "#28a87d",
family = "Tabular",
face = "italic",
angle = 45
)
)
使用scale_*()格式化标签
数值格式化
scales包提供了多种格式化数值标签的方法:
g +
scale_y_continuous(
breaks = 0:4*15000,
labels = scales::comma_format(suffix = " bikes")
)
自定义格式化函数
也可以使用自定义函数格式化标签:
g +
scale_x_continuous(
labels = function(y) paste0(y, "°F"),
name = "Feels Like Temperature"
)
使用ggtext增强文本样式
Markdown样式文本
ggtext包允许在标签中使用Markdown和HTML语法:
g +
ggtitle("<b style='font-family:tabular;font-size:25pt'>TfL</b> bike sharing trends") +
theme(
plot.title = ggtext::element_markdown()
)
处理长标题
对于长标题,可以使用element_textbox_simple实现自动换行:
g +
ggtitle("很长的标题文本...") +
theme(
plot.title = ggtext::element_textbox_simple(
fill = "grey90",
box.color = "grey40"
)
)
分面标签控制
自定义分面标签
labeller参数允许自定义分面标签的显示方式:
codes <- c(
`TRUE` = "Workday",
`FALSE` = "Weekend or Holiday"
)
g +
facet_wrap(
~ is_workday + day_night,
labeller = labeller(
.default = stringr::str_to_title,
is_workday = codes
)
)
添加注释
基本文本注释
使用annotate()添加文本注释:
ggplot(bikes, aes(humidity, temp)) +
geom_point() +
annotate(
geom = "text",
x = 90, y = 27.5,
label = "注释文本",
size = 6, color = "red"
)
添加形状和箭头
可以组合多种注释元素:
ggplot(bikes, aes(humidity, temp)) +
geom_point() +
annotate(
geom = "curve",
x = 90, xend = 82,
y = 25, yend = 18.5,
arrow = arrow(type = "closed")
)
总结
通过合理使用标签和注释,我们可以显著提升数据可视化的表达效果。ggplot2提供了丰富的工具集,从基本的标签设置到高级的注释功能,能够满足各种可视化需求。掌握这些技巧,可以让你的图表更加专业、更具信息量。
记住,好的标签和注释应该:
- 清晰传达信息
- 与图表风格协调
- 不干扰数据本身的展示
- 增强而非分散观众的注意力
通过实践这些技术,你将能够创建出既美观又富有洞察力的数据可视化作品。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0190
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0113
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
omega-aiOmega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。Java04
llm-universe本项目是一个面向小白开发者的大模型应用开发教程,在线阅读地址:https://datawhalechina.github.io/llm-universe/Jupyter Notebook08
项目优选
收起
deepin linux kernel
C
32
16
暂无描述
Dockerfile
759
4.94 K
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.78 K
188
暂无简介
Dart
1 K
259
Ascend Extension for PyTorch
Python
716
866
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
854
1.9 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.07 K
1.09 K
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.72 K
1.02 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
674
1.32 K
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
454
438