4

我想在散点图中标记点,但只标记facet_zoom面板内的点。这是一个例子:

library(ggplot2)
library(ggforce)
library(ggrepel)
library(magrittr)

labels <- letters
example_values_x <- rnorm(26)
example_values_y <- rnorm(26)

df <- data.frame(labels, 
                 example_values_x, 
                 example_values_y)
df %>% ggplot(aes(y = example_values_y, 
                  x = example_values_x)) +
  geom_point() +
  facet_zoom(x = example_values_x > 0.5) + 
  geom_label_repel(data = filter(df, example_values_x > 0.5), aes(label = labels))

知道如何制作,这样标签也不会出现在非缩放面板上吗?

4

1 回答 1

7

注意:以下答案适用于ggforce 的 GitHub 版本。在撰写本文时,CRAN 上的版本似乎具有不同的接口facet_zoom(),即使包版本相同。

首先,获取要标记的数据子集并添加一zoom列,指定数据是否应在缩放面板 ( TRUE)、原始面板 ( FALSE) 或两者 ( NA) 中呈现:

dftxt <- dplyr::filter(df, example_values_x > 0.5) %>%
  dplyr::mutate( zoom = TRUE )      ## All entries to appear in the zoom panel only

您现在可以将这个新数据框传递给geom_label_repel,同时告诉facet_zoom()使用该zoom列来确定应在何处绘制数据:

df %>% ggplot(aes(y = example_values_y, 
                  x = example_values_x)) +
  geom_point() +
  facet_zoom(x = example_values_x > 0.5, zoom.data=zoom) +   # Note the zoom.data argument
  geom_label_repel(data = dftxt, aes(label = labels))

请注意,由于原件df没有zoom列,facet_zoom()因此会将其视为并根据需要在两个面板中NA绘制:geom_point()

在此处输入图像描述

于 2018-04-19T18:02:00.107 回答