Я добавил TimeLineMax к сцене, над которой я работаю. Функциональность отлично работает, но у меня возникают проблемы с несколькими деталями.Проблема с добавлением нескольких контактов и анимацией фона в Scrollmagic?
Я хотел бы, чтобы моя сцена была как этот сайт http://www.google.com/inbox/#bundles. Этим я хочу несколько контактов в одной сцене, чтобы пользователь не мог прокручивать мои анимации, не просматривая их.
Вот демо-сайт моей работы до сих пор: https://so-staging.herokuapp.com/users/sign_in#publisher-demo-container
Вы можете увидеть свой прогресс, если вы прокрутите вниз. Три шага появятся, а затем оживятся. Я также скорректировал фоновое положение # издателя-демо-шагов на основе прокрутки.
Однако цель не является желаемой. Я бы хотел: 1. Pin # publisher-demo 2. Пошаговый шаг 1 анимированный фон-положение на прокрутке. 3. Пошаговый шаг 2 4. Пошаговый шаг 3
Я хотел бы, чтобы каждый шаг был закреплен так, чтобы пользователь не мог перейти к следующему шагу, пока анимация не будет завершена.
Я знаю, что это сбивает с толку, и я смотрел на него слишком долго. Спасибо за помощь. Вот мой scrollmagic и GSAP-код.
var controller = new ScrollMagic();
var tween = new TimelineMax()
.add(TweenMax.to("#publisher-demo-steps", 0.5, {backgroundPosition : "50% 23%"}))
.add(TweenMax.to(".blue-circle", 1, {display: "block"}))
.add(TweenMax.to(".blue-circle", 1, {className: "+=animated zoomOut", display: "none", delay:3}))
.add(TweenMax.to("#publisher-demo-steps", 0.5, {backgroundPosition : "22% 52%"}))
.add(TweenMax.to(".red-circle", 1, {display: "block"}))
.add(TweenMax.to(".red-circle", 1, {className: "+=animated zoomOut", display: "none", delay:3}))
.add(TweenMax.to("#publisher-demo-steps", 0.5, {backgroundPosition : "76% 50%"}))
.add(TweenMax.to(".green-circle", 1, {display: "block"}))
.add(TweenMax.to(".green-circle", 1, {className: "+=animated zoomOut", display: "none", delay:3}));
var scene = new ScrollScene({triggerElement: "#publisher-demo", duration: 4000, triggerHook: -100})
.setPin("#publisher-demo")
.setTween(tween)
.addTo(controller);
Спасибо, что вернулись ко мне так быстро. –
Реализация ваших рекомендаций и, безусловно, ближе к тому, что я ищу. Одна вещь, которую я все еще пытаюсь понять, заключается в том, что я не хочу, чтобы пользователь прокручивался до следующей сцены (например, шаг 1, шаг 2) до тех пор, пока не завершится первая сцена. Их способ заблокировать функцию прокрутки до завершения анимации? –
Да, есть, но это считается прокруткой, и лично мне это очень не нравится, так как это плохо UX (убирающий контроль над пользователем). Если вы все еще хотите это сделать, проверьте следующее: http://stackoverflow.com/questions/4770025/how-to-disable-scrolling-temporarily –