Как я могу передать эстетику ggplot2 из переменной? - PullRequest
7 голосов
/ 17 сентября 2010

У меня проблемы с передачей POSIXct, хранящегося в переменной, в виде xmin / xmax для geom_rect.Я пытался создать автономный пример, не тривиализируя то, что я пытаюсь сделать ...

Идея состоит в том, чтобы взять объект заговора ggplot2, x которого является POSIXt, и "увеличить"на определенном диапазоне во времени.Увеличение находится в верхних 80%, а вся серия - в нижних 20% с индикатором того, какая часть является увеличенной сверху.

Моя проблема в том, что я не могу получитьxmin / xmax передается в geom_rect - каждая вещь, которую я пробовал (кроме сборки графика вместо функции), выдает мне другую ошибку.Я пытаюсь использовать aes (), aes_string (), передавая в качестве параметров вместо эстетики, передавая только строки и т. Д.

Пример ниже говорит мне:

Error in eval(expr, envir, enclos) : object 'lims' not found

Я думаю, что мойпроблема в том, что переменные, которые я использую для установки эстетики, не находятся в области действия, когда эстетика обрабатывается, но я не могу понять, как еще это сделать.Справка.

library(ggplot2)

subplot <- function(x, y) viewport(layout.pos.col=x, layout.pos.row=y)
vplayout <- function(x, y) {
  grid.newpage()
  pushViewport(viewport(layout=grid.layout(y,x)))
}

anm_zoom <- function(limits, p) {

  lims <- as.POSIXct(limits)
  limlab <- paste(lims, collapse=" to ")

  top <- p + scale_x_datetime(limlab, limits=lims, expand=c(0,0))

  bottom <- p;
  bottom <- bottom + opts(title="")
  bottom <- bottom + opts(legend.position="none")
  bottom <- bottom + opts(axis.title.y=theme_blank())
  bottom <- bottom + scale_x_datetime("", expand=c(0,0))
  bottom <- bottom + geom_rect(aes(xmin=lims[1], xmax=lims[2]),
 ymin=-Inf, ymax=Inf, fill="grey80", alpha=0.01)

  ## Render the plots
  vplayout(1,5)
  print(top, vp=subplot(1,c(1,2,3,4)))
  print(bottom, vp=subplot(1,5))
}


pdate <- seq.POSIXt(from=as.POSIXct("2010-09-09 00:00"),
   to=as.POSIXct("2010-09-10 23:59"), by="2 mins")
var1 <- rnorm(length(pdate))
var2 <- rnorm(length(pdate))
df1 <- data.frame(pdate, var1, var2)

dm  <- melt(df1, id="pdate")

p <- ggplot(dm) + aes(x=pdate, y=value) + stat_summary(fun.y="sum", geom="line")

anm_zoom(c("2010-09-09 12:15", "2010-09-09 12:30"), p)

Ответы [ 3 ]

8 голосов
/ 18 сентября 2010

Хмммм, я думаю, вам нужна новая функция aes, которая немного похожа на aes (в том, что она не пытается анализировать свои аргументы) и немного похожа на aes_string (в том смысле, что она оценивает свои аргументы непосредственно в местной среде):

aes_now <- function(...) {
  structure(list(...),  class = "uneval")
}

Тогда

bottom <- bottom + geom_rect(aes_now(xmin=lims[1], xmax=lims[2]),
 ymin=-Inf, ymax=Inf, fill="grey80", alpha=0.01)

дает вам то, что вы хотите.

1 голос
/ 07 октября 2014

Переписать: из хадли ответ

В связи с обновлениями более новой версии ggplot2 от hadley , более интуитивно понятный способ обработки нестандартной оценки ggplot() в функции заключается в использовании aes_q() следующим образом:

  xminName  <- substitute(lims[1]); xmaxName  <- substitute(lims[2])
  bottom <- bottom + 
    geom_rect(aes_q(xmin=xminName, xmax=xmaxName),
              ymin=-Inf, ymax=Inf, fill="grey80", alpha=0.01)
0 голосов
/ 17 сентября 2010

вам просто нужно изменить имя предела аргумента вашей функции, так как я думаю, что это создает конфликт областей видимости.я просто изменил его на limit1, а также на первую строку в вашем коде, чтобы прочитать lims = as.POSIXct (limit1), и он отлично работает.проверить это !!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...