使用 ggtext 的 ggplots 拼凑标题中的颜色?

use*_*745 6 r ggplot2 patchwork ggtext

如何使用 ggtext 为拼凑而成的 ggplots 赋予彩色标题?

例子

假设我们有四个图

library(ggplot2)
library(patchwork)
library(ggtext)

p1 <- ggplot(mtcars) + 
  geom_point(aes(mpg, disp)) + 
  ggtitle('Plot 1')

p2 <- ggplot(mtcars) + 
  geom_boxplot(aes(gear, disp, group = gear)) + 
  ggtitle('Plot 2')

p3 <- ggplot(mtcars) + 
  geom_point(aes(hp, wt, colour = mpg)) + 
  ggtitle('Plot 3')

p4 <- ggplot(mtcars) + 
  geom_bar(aes(gear)) + 
  facet_wrap(~cyl) + 
  ggtitle('Plot 4')
Run Code Online (Sandbox Code Playgroud)

这些可以这样安排

patch <- (p1 + p2) / (p3 + p4)
patch
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

拼凑而成的标题可以像这样

patch +
  plot_annotation(
  title = "Here is a regular title")
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

单个 ggplot 可以像这样被赋予一个丰富多彩的标题

p1 +
  ggtitle("Here <span style='color:#953011;'><strong>is a colourful title</strong></span>") +
  theme(plot.title = element_markdown(lineheight = 1.1)) 
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

ggplots的拼凑如何才能获得一个丰富多彩的标题。这是我失败的尝试

patch +
  plot_annotation(
  title = "Here<span style='color:#953011;'><strong>is a colourful title</strong></span>") +
  theme(plot.title = element_markdown(lineheight = 1.1)) 
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

mar*_*kus 8

plot_annotation有一个theme论点,所以你可以做

#remotes::install_github("wilkelab/ggtext")
library(ggplot2)
library(patchwork)
library(ggtext)

patch <- (p1 + p2)

patch +
  plot_annotation(
    title = "Here <span style='color:#953011;'><strong>is a colourful title</strong></span>",
    theme = theme(plot.title = element_markdown(lineheight = 1.1)))
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明