Оси R-стиля с ggplot

Используя ggplot, можно ли получить оси X/y "R-style", которые не встречаются в начале координат и которые вместо этого состоят из двух отключенных диапазонов, как в следующем примере?

enter image description here

Причина здесь заключается в том, чтобы заставить графики ggplot выглядеть последовательно рядом с чистыми R-тегами.

Ответ 1

Попробуйте это,

library(ggplot2)

d <- data.frame(x=1:10, y=rnorm(10))

base_breaks_x <- function(x){
  b <- pretty(x)
  d <- data.frame(y=-Inf, yend=-Inf, x=min(b), xend=max(b))
  list(geom_segment(data=d, aes(x=x, y=y, xend=xend, yend=yend), inherit.aes=FALSE),
       scale_x_continuous(breaks=b))
}
base_breaks_y <- function(x){
  b <- pretty(x)
  d <- data.frame(x=-Inf, xend=-Inf, y=min(b), yend=max(b))
  list(geom_segment(data=d, aes(x=x, y=y, xend=xend, yend=yend), inherit.aes=FALSE),
       scale_y_continuous(breaks=b))
}

ggplot(d, aes(x,y)) +
  geom_point() +
  theme_bw() +
  theme(panel.border = element_blank(),
       panel.grid.major = element_blank(),
       panel.grid.minor = element_blank()) +
  base_breaks_x(d$x) +
  base_breaks_y(d$y)

screenshot

Изменить: a связанная с этим проблема была обсуждена в пакете ggtheme и потенциально обеспечивает более чистое решение (нет необходимости предоставлять данные явно к функции разрывов).