使用ggplot2和ggtext创建精美的企鹅数据集可视化图表
2025-06-02 04:05:58作者:申梦珏Efrain
本文基于rstudio-conf-2022中关于ggplot2图形设计的研讨会材料,重点讲解如何使用ggplot2和ggtext包创建带有精美注释的企鹅数据集可视化图表。
数据准备
首先我们需要加载并了解数据集。我们使用的是palmerpenguins包提供的企鹅数据集:
library(palmerpenguins)
penguins
这个数据集包含了三种企鹅(阿德利企鹅、帽带企鹅和巴布亚企鹅)的体型测量数据,包括喙长、喙深、鳍状肢长度和体重等信息。
基础图表构建
我们从最基本的散点图开始,展示企鹅喙长和喙深的关系:
ggplot(
penguins,
aes(x = bill_length_mm, y = bill_depth_mm,
color = species, size = body_mass_g)
) +
geom_point(alpha = .2) +
labs(
x = "Bill length (mm)",
y = "Bill depth (mm)",
title = "Bill dimensions of brush-tailed penguins Pygoscelis spec.",
caption = "Horst AM, Hill AP, Gorman KB (2020). palmerpenguins R package version 0.1.0"
)
图表美化步骤
1. 添加点轮廓
为了让数据点更清晰可见,我们添加白色轮廓:
geom_point(alpha = .2, stroke = .3) +
geom_point(shape = 1, stroke = .3)
2. 自定义颜色和大小比例尺
scale_color_manual(
name = "Species:",
values = c("#FF8C00", "#A034F0", "#159090")
) +
scale_size(
name = "Body mass:",
breaks = 3:6 * 1000,
labels = function(x) paste(x / 1000, "kg"),
range = c(.5, 5)
)
3. 调整坐标轴
coord_cartesian(
expand = FALSE,
clip = "off"
) +
scale_x_continuous(
limits = c(30, 60),
breaks = 6:12*5
) +
scale_y_continuous(
limits = c(12.5, 22.5),
breaks = seq(12.5, 22.5, by = 2.5)
使用ggtext增强文本样式
ggtext包允许我们在图表中使用Markdown和HTML标记来格式化文本:
library(ggtext)
labs(
x = "Bill length *(mm)*",
y = "Bill depth *(mm)*",
title = "Bill dimensions of brush-tailed penguins *Pygoscelis spec.*",
caption = "Horst AM, Hill AP, Gorman KB (2020). <span style='font-family:tabular;'>palmerpenguins</span> R package version 0.1.0"
) +
theme(
plot.title = element_markdown(
face = "bold", size = 16, margin = margin(12, 0, 12, 0)
)
添加物种标签注释
我们需要先创建一个包含物种平均数据和格式化标签的数据框:
penguins_labs <-
penguins %>%
group_by(species) %>%
summarize(across(starts_with("bill"), ~ mean(.x, na.rm = TRUE))) %>%
mutate(
species_lab = case_when(
species == "Adelie" ~ "<b style='font-size:15pt;'>*P. adéliae*</b><br>(Adélie penguin)",
species == "Chinstrap" ~ "<b style='font-size:15pt;'>*P. antarctica*</b><br>(Chinstrap penguin)",
species == "Gentoo" ~ "<b style='font-size:15pt;'>*P. papua*</b><br>(Gentoo penguin)"
)
)
然后使用geom_richtext添加注释:
geom_richtext(
data = penguins_labs,
aes(label = species_lab,
color = species,
color = after_scale(colorspace::darken(color, .4))),
family = "Roboto Condensed",
size = 3, lineheight = .8,
fill = "#ffffffab", ## 半透明白色背景
show.legend = FALSE
)
最终主题定制
theme_minimal(
base_size = 10, base_family = "Roboto Condensed"
) +
theme(
plot.title.position = "plot",
plot.caption.position = "plot",
axis.text = element_text(family = "Tabular"),
legend.text = element_text(color = "grey50"),
plot.margin = margin(0, 14, 0, 12),
plot.background = element_rect(fill = NA, color = "grey50", size = 1)
)
总结
通过本教程,我们学习了如何:
- 使用ggplot2创建基础可视化
- 通过多种几何对象增强图表表现力
- 自定义比例尺和坐标轴
- 使用ggtext包实现丰富的文本格式化
- 添加和样式化注释
- 全面定制图表主题
这些技巧可以应用于各种数据可视化场景,帮助你创建既美观又专业的图表。
登录后查看全文
热门项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
MiniMax-M2.5MiniMax-M2.5开源模型,经数十万复杂环境强化训练,在代码生成、工具调用、办公自动化等经济价值任务中表现卓越。SWE-Bench Verified得分80.2%,Multi-SWE-Bench达51.3%,BrowseComp获76.3%。推理速度比M2.1快37%,与Claude Opus 4.6相当,每小时仅需0.3-1美元,成本仅为同类模型1/10-1/20,为智能应用开发提供高效经济选择。【此简介由AI生成】Python00
ruoyi-plus-soybeanRuoYi-Plus-Soybean 是一个现代化的企业级多租户管理系统,它结合了 RuoYi-Vue-Plus 的强大后端功能和 Soybean Admin 的现代化前端特性,为开发者提供了完整的企业管理解决方案。Vue06- RRing-2.5-1TRing-2.5-1T:全球首个基于混合线性注意力架构的开源万亿参数思考模型。Python00
Qwen3.5Qwen3.5 昇腾 vLLM 部署教程。Qwen3.5 是 Qwen 系列最新的旗舰多模态模型,采用 MoE(混合专家)架构,在保持强大模型能力的同时显著降低了推理成本。00
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
570
3.85 K
Ascend Extension for PyTorch
Python
383
457
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
894
680
暂无简介
Dart
804
198
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
353
210
昇腾LLM分布式训练框架
Python
119
146
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
68
20
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.37 K
781