• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Płyniejszy scroll.

Object Storage Arubacloud
+1 głos
128 wizyt
pytanie zadane 10 stycznia 2017 w JavaScript przez ShiroUmizake Nałogowiec (46,300 p.)

Pytanie, może nie zbyt oczywiste. Ale za chwilę wytłumaczę o co chodzi.

Mam taką oto metodę Run:

run (){
        this.isRun = true;
      if (this.way == 'left'){
        this.id = setInterval(
          this.renderLeft.bind(this),
          10
        );
      }
      else if (this.way == 'right'){
        this.id = setInterval(
          this.renderRight.bind(this),
          10
        );
      }
  }

To chyba, jest oczywiste wywołuje co N czasu metodę renderRight.

renderLeft(){
    if (this.startAPP){
      console.log('method run');
        if (this.isMaxRect() || this.isLifeSpanAPITooLong() ){
          this.stopAPP();
          return;
        }
      this.scrollLeft();
      ++this.lifeSpanAPI;
      return;
    }
    else if (this.isMaxCurrentFrame() || this.isZeroPosX()){
      this.stopAPP();
      return;
    }
    this.scrollLeft();

  }

A to jest kontroler dla scrollLeft. Pierwszy warunek się sprawdza wtedy , gdy inna cześć aplikacji w tym przypadku slidera jest odpalona. A gdy wciskana jest strzałka jak pan Bóg przekazał ta uruchamiany jest warunek drugi. To ta metoda decyduje kiedy zakończy swój żywot API. A co robi scrollLeft to chyba jest oczywiste.

Problem jest taki, że ta animacja zamula. Gdy, się wciśnie strzałki jest OK, ale jak już po obrazkach. Czasami, frame obrzydliwe zwalnia i wygląda to tak jakby nie wiem liczył PI po tysięcznym przecinku. Niestety te metody są potrzebne. Gdyż kontroler musi wiedzieć, czy element osiągnął wskazany punkt , a jak wiadomo do punktu można dojśc z dwóch stron prawo i lewo lub czy API za długo żyje (czasami zdarza się , że API nie wie czy scrollować lewo lub prawo. Ogólnie domyślam się dlaczego tak dzieje, ale zaimplementowanie rozwiązania powodowały mnóstwo zależności. Dla ciekawskich kod obsługujący te warunki.

 

  isMaxRect(){
    let rectNode = this.node.getBoundingClientRect();
      if (this.way =='right'){
        return this.isMaxRectRight(rectNode);
      }
      else if (this.way == 'left'){
        return this.isMaxRectLeft(rectNode);
      }

  }
  isMaxRectRight(rectNode){
    if (rectNode.left <= this.maxRectLeft) return true; else return false;
  }
  isMaxRectLeft(rectNode){
      if (rectNode.left >= this.maxRectLeft) return true; else return false;
  }
  isLifeSpanAPITooLong (){
    if (this.lifeSpanAPI == 20){
      return true;
    }
    return false;
  }

Macie jakieś pomysły?

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

+1 głos
0 odpowiedzi 108 wizyt
pytanie zadane 27 grudnia 2021 w JavaScript przez ferdynand Obywatel (1,250 p.)
+2 głosów
0 odpowiedzi 130 wizyt
pytanie zadane 18 kwietnia 2021 w JavaScript przez Puszkin Nowicjusz (170 p.)
0 głosów
1 odpowiedź 279 wizyt

92,575 zapytań

141,424 odpowiedzi

319,649 komentarzy

61,960 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...