Контроль скорости ганимации - PullRequest
       14

Контроль скорости ганимации

0 голосов
/ 09 сентября 2018

Я хочу замедлить скорость перехода между состояниями при использовании library(gganimate).

Вот небольшой пример:

# devtools::install_github("thomasp85/gganimate")
library(gganimate) # v0.9.9.9999

dat_sim <- function(t_state, d_state) {
  data.frame(
    x = runif(1000, 0, 1),
    y = runif(1000, 0, 1),
    t_state = t_state*d_state
    )
}

dat <- purrr::map_df(1:100, ~ dat_sim(., 1))

ggplot(dat, aes(x, y)) +
  geom_hex(bins = 5) +
  theme_void() +
  lims(x = c(.3, .7),
       y = c(.3, .7)) +
  theme(legend.position = "none") +
  transition_time(t_state)

toofast

Мое идеальное поведение было бы намного медленнее (10-100x), поэтому изменения цвета постепенно развиваются, и у кого-то нет приступов.

Если я попытаюсь использовать transition_states() для более ручного управления, я получу gif с пустыми рамками. Я пробовал различные комбинации для transition_legnth= и state_length= без заметного эффекта.

ggplot(dat, aes(x, y)) +
  geom_hex(bins = 5) +
  theme_void() +
  lims(x = c(.3, .7),
       y = c(.3, .7)) +
  theme(legend.position = "none") +
  transition_states(t_state, transition_length = .1, state_length = 2)

mostlyblank

1 Ответ

0 голосов
/ 09 сентября 2018

Я нашел в функции docs animate, которая может принимать параметры fps и detail .

@ param кадр / с Частота кадров анимации в кадрах / сек

@ param detail Количество дополнительных кадров для расчета на кадр

Результат:

p <- ggplot(dat, aes(x, y)) +
      geom_hex(bins = 5) +
      theme_void() +
      lims(x = c(.3, .7),
           y = c(.3, .7)) +
      theme(legend.position = "none") +
      transition_time(t_state)
animate(p, fps=1)

enter image description here

Также можно указать формат вывода, например png , jpeg , svg .

...