• 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

VPS Starter Arubacloud
+2 głosów
64 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 417 wizyt
pytanie zadane 16 października 2021 w Algorytmy przez mn130496 Gaduła (3,530 p.)
0 głosów
1 odpowiedź 696 wizyt
pytanie zadane 21 kwietnia 2020 w C i C++ przez Atman Użytkownik (810 p.)
0 głosów
2 odpowiedzi 158 wizyt

92,454 zapytań

141,262 odpowiedzi

319,089 komentarzy

61,854 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

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 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!

...