< Return to Video

ანიმაცია RAF-ის გამოყენებით (ვიდეო ვერსია)

  • 0:00 - 0:04
    დავუბრუნდეთ Oh noes-ის დროის ათვლას.
  • 0:04 - 0:07
    როგორ მოვიქცეთ თუ გვინდა
    Oh noes გამოსახულება გაიზარდოს,
  • 0:07 - 0:10
    როცა დროის ათვლა ნულს მიუახლოვდება?
  • 0:10 - 0:13
    -- გარდაუვალ უბედურებას
    რომ მოასწავებდეს --
  • 0:13 - 0:17
    ამისი გაკეთების ერთი გზა
    არის CSS-ის სტილის ანიმირება
  • 0:17 - 0:20
    Window.setInterval-ის გამოყენებით.
  • 0:20 - 0:32
    პირველი ნაბიჯისთვის,
    სურათს ცვლადში მოვათავსებთ,
  • 0:32 - 0:35
    შემდეგ, დავწერთ საწყის სტილს,
  • 0:35 - 0:39
    ეს იმისთვის, რომ რამით დავიწყოთ.
  • 0:39 - 0:44
    შემდეგ კი დავწერთ makeItBigger ფუნქციას.
  • 0:44 - 0:49
    აქ საჭირო იქნება style.width-ის შეცვლა,
  • 0:49 - 1:00
    ავიღებთ წინა style.width-ს
    და დავუმატებთ ერთს.
  • 1:00 - 1:07
    საბოლოოდ, ამ ფუნქციით
    გამოვიძახებთ setInterval-ს,
  • 1:07 - 1:12
    -- რამდენად ხშირად გვინდა იზრებოდეს?
  • 1:12 - 1:19
    სუფთა ანიმაცია გვინდა, რაც ნიშნავს
    დაახლოებით 24-დან 60 კადრამდე წამში.
  • 1:19 - 1:26
    მოდით იყოს 30 კადრი წამში.
  • 1:26 - 1:32
    არ მუშაობს. ხედავთ რატომ? ცოტა ეშმაკურია.
  • 1:32 - 1:41
    რა არის ohnoes.style.width-ის
    მნიშვნელობა ამ ხაზის შემდეგ?
  • 1:41 - 1:46
    შეიძლება იფიქროთ,
    რომ 50px გადადის 51px-ში,
  • 1:46 - 1:50
    მაგრამ მოდით ვნახოთ
    რა იქნება ohnoes.style.width
  • 1:58 - 2:06
    50px-ს ვუმატებთ ერთს.
  • 2:06 - 2:08
    რას უდრის 50px პლუს ერთი?
  • 2:08 - 2:11
    შეიძლება იფიქროთ რომ ეს 51px იქნება,
  • 2:11 - 2:16
    მაგრამ ჯავასკრიპტი
    50px-ს აღიქვამს string-ად,
  • 2:16 - 2:22
    ამიტომ პასუხი გამოვა
    50px1, რაც უშინაარსოა.
  • 2:22 - 2:30
    ესეიგი, ბრაუზერი უბრალოდ
    არ აქცევს ყურადღებას ამ უშინაარსობას.
  • 2:30 - 2:36
    საჭიროა ეს სიდიდე რიცხვად გადავიყვანოთ,
  • 2:36 - 2:38
    შემდეგ, რიცხვს დავუმატოთ ერთი,
  • 2:38 - 2:41
    შემდეგ კი ისევ გადავაქციოთ px-ად.
  • 2:41 - 2:46
    ამისთვის ეს სიდიდე თავიდან
    მოვათავსოთ parseFloat-ში,
  • 2:46 - 2:48
    რაც მას რიცხვად გადააქცევს,
  • 2:48 - 2:53
    შემდეგ ვუმატებთ ერთს და
    ბოლოს ისევ ვუმატებთ px-ს.
  • 2:53 - 2:58
    ძალიან კარგი, იზრდება!
  • 2:58 - 3:03
    როგორც ხედავთ, CSS-ის ანიმაციებში
    ზოგჯერ საქმე გვაქვს ერთეულებთან,
  • 3:03 - 3:09
    რომლებიც უნდა მოვაშოროთ სიდედეებს,
  • 3:09 - 3:13
    შემდეგ კი ისევ დავაბრუნოთ.
  • 3:13 - 3:16
    CSS-ის ანიმაციების
    თვისებებთან setInterval-ის გამოყენებისას
  • 3:16 - 3:22
    არის გარკვეული სირთულეები.
  • 3:22 - 3:24
    პირველი, ბრაუზერი
    არ იძლევა იმის გარანტიას,
  • 3:24 - 3:28
    რომ ზუსტად ისე შეასრულებს
    პაუზას როგორც მივუთითებთ.
  • 3:28 - 3:33
    თუ სხვა რაღაცები ჩაერია,
    მაგალითად ბეჭდვა მომხმარებლისგან,
  • 3:33 - 3:36
    შესაძლოა callback უფრო
    გვიან იქნეს გამოძახებული.
  • 3:36 - 3:39
    მაშინ სუფთა ანიმაციას ვერ მივიღებთ.
  • 3:39 - 3:41
    მეორე - ბრაუზერი იმ
    შემთხვევაშიც გამოიძახებს ფუნქციას,
  • 3:41 - 3:43
    როცა ეს tab დახურულია.
  • 3:43 - 3:48
    ეს არაა საჭირო მაგრამ
    კომპიუტერის მეხსიერებას მაინც იკავებს.
  • 3:48 - 3:52
    ამიტომ თანამედროვე
    ბრაუზერებში სხვა ფუნქცია არსებობს,
  • 3:52 - 3:56
    სპეციალურად ასეთი ანიმაციებისთვის
  • 3:56 - 3:59
    და ეწოდება
    window.requestAnimationFrame
  • 3:59 - 4:03
    მის გამოსაყენებლად
    მოვიშოროთ setInterval ხაზი.
  • 4:03 - 4:12
    გამოვიძახოთ requestAnimationFrame
    ფუნქციის შიგნიდან
  • 4:12 - 4:18
    და მივუთითოთ makeItBigger ფუნქციაზე,
  • 4:18 - 4:27
    შემდეგ კი makeItBigger-ს გამოვიძახებთ.
  • 4:27 - 4:31
    ამჯერად გაცილებით სწრაფია!
  • 4:31 - 4:36
    ბრაუზერი ახლა
    makeItBigger-ს დახატვამდე იძახებს,
  • 4:36 - 4:38
    რაც დაახლოებით 60 კადრია წამში,
  • 4:38 - 4:41
    წინანდელზე ორჯერ სწრაფი.
  • 4:41 - 4:44
    სიგანეს ყოველ ჯერზე ერთ პიქსელს ვუმატებთ.
  • 4:44 - 4:48
    ესეიგი წამში ვუმატებთ 60 პიქსელს.
  • 4:48 - 4:51
    რამდენიმე წამში
    გამოსახულება გვერდზე დიდი ხდება
  • 4:51 - 4:53
    უკვე აღარც ჩანს.
  • 4:53 - 4:56
    როგორ შევანელოთ ანიმაცია?
  • 4:56 - 4:59
    რამდენიმე გზა არსებობს.
    ჩემი საყვარელი გზაა იმაზე დაკვირვება,
  • 4:59 - 5:04
    თუ რა დრო გავიდა და ახალი
    სიგანის ამის მიხედვით გამოთვლა.
  • 5:04 - 5:11
    ვიწყებთ საწყისი დროის დამახსოვრებით,
    მილიწამებში, ფუნქციის გამოძახებამდე.
  • 5:11 - 5:18
    var startTime = new Date().getTime();
  • 5:18 - 5:21
    makeItBigger-ში მოვათავსებთ მოცემულ დროს.
  • 5:21 - 5:27
    var currTime = new Date().getTime();
  • 5:27 - 5:32
    ვთქვათ, გვინდა 30
    პიქსელი-წამში სიჩქარით ზრდა
  • 5:32 - 5:37
    და დაწყება 50 პიქსელით.
  • 5:37 - 5:44
    ახალი სიგანე ტოლი
    იყოს 50-ს, საწყის სიგანეს,
  • 5:44 - 5:49
    დამატებული მოცემული
    დრო, მინუს საწყისი დრო,
  • 5:49 - 5:53
    მილიწამებში ვართ, ამიტომ ვყოფთ 1000-ზე,
  • 5:53 - 6:00
    შემდეგ კი პლუს 30,
    რადგან წამში 30-ით გვინდა გაზრდა.
  • 6:00 - 6:10
    ეს ახალი სიგანეა, ახლა კი
    style.width გავუტოლოთ ახალ სიგანეს.
  • 6:10 - 6:13
    გავუტოლოთ newWidth + px-ს.
  • 6:13 - 6:20
    ესეც ასე, სუფთა, 30px/წამი ანიმაცია.
  • 6:20 - 6:31
    შეგვიძლია ეს რიცხვი შევცვალოთ თუ
    უფრო ნელა ან სწრაფად გვინდა ზრდა.
  • 6:31 - 6:35
    როგორ შევაჩეროთ
    ანიმაცია თუ ის ძალიან დიდი გახდა?
  • 6:35 - 6:38
    შეგვიძლია ეს ხაზი მოვათავსოთ if-ში
  • 6:38 - 6:43
    და შევასრულოთ მხოლოდ
    იმ შემთხვევაში, თუ მოცემული სიგანე
  • 6:43 - 6:48
    გარკვეულ რიცხვზე ნაკლები
    იქნება, მაგალითად 300.
  • 6:59 - 7:07
    ვნახოთ, თუ გაჩერდება 300-ზე.
  • 7:07 - 7:09
    მშვენიერია!
  • 7:09 - 7:13
    requestAnimationFrame ტექნიკა იმუშავებს,
  • 7:13 - 7:18
    თუ მომხმარებელი იყენებს
    Chrome-ს, Firefox-ს, ან IE10+-ს.
  • 7:18 - 7:22
    ჯავასკრიპტის მრავალგვარი
    ბიბლიოთეკა არსებობს,
  • 7:22 - 7:26
    რომელიც მოითხოვს requestAnimationFrame-ს
    როცა ის მიწვდომადია
  • 7:26 - 7:30
    უფრო ძველ ბრაუზერებში
    კი setInterval-ს დაუბრუნდება.
  • 7:30 - 7:35
    web development ყოველთვის იცვლება,
  • 7:35 - 7:37
    ბრაუზერები ახალ თვისებებს ამატებენ,
  • 7:37 - 7:40
    დეველოპერები მათი
    გამოყენების ახალ გზებს პოულობენ..
  • 7:40 - 7:44
    ყოველთვის უნდა სწავლობდეთ რა არის ახალი
  • 7:44 - 7:47
    და რა უკეთესი იმისთვის,
    რაც თქვენ გინდათ გააკეთოთ.
Title:
ანიმაცია RAF-ის გამოყენებით (ვიდეო ვერსია)
Description:

more » « less
Video Language:
English, British
Duration:
07:48
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)
Educare Giorgi Kvantrishvili edited Georgian subtitles for Animating styles with RAF (Video Version)

Georgian subtitles

Revisions