Конечное значение GWT Animation не соблюдается - PullRequest
5 голосов
/ 19 апреля 2010

У меня есть FlowPanel, которую я пытаюсь анимировать взад-вперед, как навигация по iphone. (См. этот пост для моего оригинального вопроса о том, как это сделать)

Итак, он "работает" с кодом, показанным ниже. Я говорю, работая в кавычках, потому что я нахожу, что мое окончательное положение моего скроллера не точное и всегда изменяется при прокрутке.

GWT.log всегда сообщает фактические значения, которые я ищу, поэтому, например, с помощью вызова scrollTo, приведенного ниже, мой GWT.log говорит:

ScrollStart: 0 scrollStop: -246

Но когда я фактически анализирую элемент в fireBug, его css, левая позиция никогда не бывает точно -246px. Иногда он отключается на целых 10 пикселей, поэтому моя панель просто перестала прокручиваться, прежде чем закончить.

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

Я даже не знаю, с чего начать с отладки, кроме того, что я уже сделал. Любые советы приветствуются.

РЕДАКТИРОВАТЬ: Дополнительная информация журнала:
Регистрация внутри onUpdate показывает это:

Updating: progress: 0.09319577524960648 position: -22.926160711403195
Updating: progress: 0.1328387452821571 position: -32.67833133941065
Updating: progress: 0.609071620698271 position: -149.83161869177468
Updating: progress: 0.7269952498697734 position: -178.84083146796425
Updating: progress: 0.9852532367342712 position: -242.37229623663072
AnimationComplete: final scrollStart/scrollStop: 0/-246

Почему оно заканчивается на 0,98% ???

Код для вызова анимации

scroller = new Scroller();
scroller.scrollTo(-246,400);

Код анимации

public class Scroller extends Animation {

    private FlowPanel scroller;
    private final Element e;

    public Scroller(){
        scroller = new FlowPanel();
        e = scroller.getElement();
    }

    public void scrollTo(int position, int milliseconds) {

        scrollStart = e.getOffsetLeft();
        scrollStop = position;

        GWT.log("ScrollStart: " + scrollStart + " scrollStop: " + scrollStop);
        run(milliseconds);
    }

    @Override
    protected void onUpdate(double progress) {
        double position = scrollStart + (progress * (scrollStop - scrollStart));
        e.getStyle().setLeft(position, Style.Unit.PX);
    }
}

1 Ответ

7 голосов
/ 19 апреля 2010

onComplete вызывается после завершения анимации (и onStart вызывается до ее запуска), поэтому переопределите, если вы хотите выполнить действие, когда анимация завершена на 100%:

public class Scroller extends Animation {
      ...

      @Override
      protected void onComplete() {
        e.getStyle().setLeft(scrollStop, Style.Unit.PX);
      }
}

Редактировать Как отмечает Брэд, в документах не очень ясно, что onComplete - это то, что вызывается после завершения анимации. В Javadoc написано: Animation.onUpdate :

Вызывается, когда анимация должна быть обновлено. Ценность прогресса от 0,0 до 1,0 включительно (если вы не переопределите интерполяционный (двойной) метод для обеспечения более широкий диапазон значений). Вы можете переопределить onStart () и onComplete () для выполнить настройку и снести процедур.

Код , который вызывает эти методы , - единственное, что дает понять, что onUpdate вызывается только тогда, когда анимация началась, но еще не закончена, то есть, когда значение прогресса> 0, но <1 . </p>

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