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

question-closed Rownanie matematycznie na stopniowe zmniejsznanie

Object Storage Arubacloud
+2 głosów
68 wizyt
pytanie zadane 18 listopada 2020 w JavaScript przez Renzov Obywatel (1,220 p.)
zamknięte 18 listopada 2020 przez Renzov

Hej,

Mam pewien problem z bardzo prostym równaniem matematycznym. Miałem zrobiony na stronie taki efekt, że:

Na środku ekranu pojawia się kropka. Kiedy użytkownik rusza myszką na boki, kropka idzie w odwrotnym kierunku od myszki. Im bliżej myszka znajduje się krawędzi, tym bardziej kropka zwalnia. Niestety projekt mi uciekł i nie pamiętam jak zrobiłem równanie. Na chwilę obecną mam zrobione równanie tak, że kropka idzie w przeciwną stronę, ale nie zwalnia.

Mam zrobione tak:

Jeśli ekran użytkownika ma 1500 szerokości:

//Wychwycenie w jakim % znajduje się kursor

(Pozycja kursora / szerokość okna) * 100

//Usunięcie negatywnego wyniku i wyśrodkowanie obiektu (Używam transform translate do przesuwania kropki)

(Pozycja kursora / szerokość okna) * 100) -50)* -1) -50);

I tutaj wszystko działa. Gdy kursor jest na 0, obiekt przesuwa się o 100%, 750px - 50% i 1500px 100%

Teraz nie wiem jak zrobić tak, żeby zwalniał bliżej krawędzi i nawet do niej nie dochodził. Kombinowałem z ^3 oraz / 1000 ale działało to w jedną stronę. Od 50+ działało dobrze, obiekt zwalniał, ale poniżej 50 przyśpieszał.

Zamieszczam ponizej grafik, bo ciezko bedzie troche zrozumiec o co mi dokladnie chodzi:

komentarz zamknięcia: Rozwiazane
komentarz 18 listopada 2020 przez ScriptyChris Mędrzec (190,190 p.)

Możesz pokazać kod?

1
komentarz 18 listopada 2020 przez Renzov Obywatel (1,220 p.)

Hej,

Już udało mi się to rozwiać za pomocą tego:

this.mouse.x = event.clientX;
this.mouse.y = event.clientY;
this.mouse.xNew = (-50 + ((window.innerWidth / 2) - this.mouse.x) / 150);
this.mouse.yNew = (-50 + ((window.innerHeight / 2) - this.mouse.y) / 150);
this.splashPosition.total = ('translate(' + this.mouse.xNew + '%, ' + this.mouse.yNew + '%)');

 

Podobne pytania

+2 głosów
2 odpowiedzi 425 wizyt
pytanie zadane 16 października 2021 w Algorytmy przez mn130496 Gaduła (3,530 p.)
0 głosów
1 odpowiedź 715 wizyt
pytanie zadane 21 kwietnia 2020 w C i C++ przez Atman Użytkownik (810 p.)
0 głosów
2 odpowiedzi 163 wizyt

92,555 zapytań

141,403 odpowiedzi

319,557 komentarzy

61,940 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!

...