آموزش ساخت انیمیشن با استفاده از اسکرچ
نوشته شده توسط : مهراب مدیری

اخیراً با یکی از طراحان تیمم در مورد دیدگاه او برای طراحی مجدد چگونه با اسکرچ انیمیشن بسازیم  قسمت خاصی از سایت Codecademy صحبت می کردم. او برخی از انتقال‌های بسیار شیک و تا حدودی مفصل را که در حال بررسی بود، به نمایش گذاشت. من بلافاصله شروع به تعجب کردم که پیاده سازی آنها در برنامه ما که در React ساخته شده است چقدر پیچیده است. آیا باید در چندین کتابخانه جدید بارگیری کنم؟ آیا حتی در React امکان انجام برخی از انیمیشن‌های یکپارچه و متوالی عناصر از یک حالت به حالت دیگر وجود داشت، بدون نیاز به کد فوق‌العاده پیچیده یا هک‌های ناخوشایند؟

 

اغلب اوقات، زمانی که می خواهید یک انیمیشن در برنامه React  چگونه با اسکرچ انیمیشن بسازیم خود داشته باشید، منطقی است که به یکی از کتابخانه های متعددی که جزئیات را انتزاعی می کند و به شما اجازه می دهد از یک سبک بیانی استفاده کنید، بپردازید. اما گاهی اوقات این کتابخانه‌ها شما را تا آخر راه نمی‌برند.

 

شاید شما (یا طراح که با آن کار می کنید) مجموعه پیچیده ای از انیمیشن های متوالی متشکل از عناصر متعدد را هنگام ورود و خروج یک جزء والد به DOM تصور کنید. شاید بخواهید موقعیت‌های عناصر خاصی را که در قسمت‌های مختلف برنامه دوباره رندر می‌شوند، متحرک کنید. یا شاید بخواهید کنترل تغییرات یک لیست دائماً در حال به‌روزرسانی، ترتیب ورود/به‌روزرسانی/خروج a la d3 را در دست بگیرید.

 

به‌طور شگفت‌انگیزی امکان‌پذیر است که جلوه‌های انیمیشن پیچیده‌تر چگونه با اسکرچ انیمیشن بسازیم  را در کد خود ایجاد کنید، بدون اینکه مجبور باشید با محدودیت‌های احتمالی یک کتابخانه انیمیشن سازگار با React مقابله کنید. با این حال، شما باید با مخالفت اندکی با اصل React موافق باشید. در مثال‌های زیر، ما به رویدادهای چرخه حیات متصل می‌شویم، و با تأخیر گهگاهی به‌روزرسانی‌ها به منظور متحرک کردن عناصر از یک حالت به حالت دیگر، مؤلفه‌ها را «ناخالص» می‌سازیم. ما همچنین مستقیماً با استفاده از refs وارد DOM خواهیم شد.

 

دستکاری چرخه عمر قطعه

برای ایجاد انواع خاصی از انیمیشن‌ها، باید با بخش‌های مختلف چرخه حیات کامپوننت تداخل داشته باشیم. برای مثال، اگر می‌خواهیم حذف عناصر را متحرک کنیم، به راهی نیاز داریم که حذف گره‌ها از DOM را در طول مدت انیمیشن خروج به تأخیر بیندازیم. برای متحرک سازی انتقال عناصر از نقطه A به نقطه B در سراسر صفحه، باید موقعیت های شروع و پایان گره را درست قبل از اینکه مرورگر تغییر را روی صفحه نمایش دهد محاسبه کنیم و خود انتقال های طرح بندی را مدیریت کنیم.

 

خوشبختانه، React روش‌های چرخه حیات مختلفی را ارائه می‌کند که می‌توانیم به آن‌ها متصل شویم. متد shouldComponentUpdate که زمانی که یک کامپوننت چگونه با اسکرچ انیمیشن بسازیم  پروپ یا حالت جدید دریافت می‌کند فعال می‌شود، به ما اجازه می‌دهد به‌روزرسانی‌های DOM را تا پایان اجرای انیمیشن خروجی به تأخیر بیندازیم. از طرف دیگر اگر قصد داریم عناصر را از یک قسمت صفحه به قسمت دیگر منتقل کنیم، به راهی برای ثبت موقعیت های قبلی عناصر درست قبل از به روز رسانی نیاز داریم. ما می‌توانیم از دو روش استفاده کنیم - یا componentWillReceiveProps یا shouldComponentUpdate برای ثبت موقعیت‌های قبلی عناصر، و سپس componentDidUpdate برای تغییر مکان آنها و انتقال هموار آنها به مکان‌های جدیدشان.

 

دسترسی به گره های DOM با refs و ویژگی های داده

برای دسترسی به گره‌های DOM از یک ref در کانتینر والد استفاده می‌کنیم تا بتوانیم آنها را متحرک کنیم. حتی اگر در مثال‌های زیر، هدف حفظ منطق انیمیشن و اجزای آن نسبتاً جدا از هم است، چند اخطار وجود دارد.

 

اول، کامپوننت کانتینر پیچیده باید به جای یک جزء کاربردی، مبتنی بر کلاس باشد تا بتوانیم از طریق یک ref به عنصر DOM آن دسترسی داشته باشیم. ثانیاً، برخی از انیمیشن ها همچنین به ه چگونه با اسکرچ انیمیشن بسازیم ر کودک نیاز دارند که یک ویژگی منحصر به فرد data-* داشته باشد. (از data-id استفاده خواهم کرد.) این ویژگی به عملکرد انیمیشن ما کمک می کند تا بین عناصر کودک تمایز قائل شود و آنها را به درستی پردازش کند.

 

تفکیک نگرانی های انیمیشن به یک جزء درجه بالاتر

 

در مثال‌ها، من از مؤلفه‌های مرتبه بالاتر برای جدا کردن منطق انیمیشن چرخه حیات از منطق ارائه مؤلفه‌ها استفاده کرده‌ام. این تنها یک راه ممکن برای سازماندهی چیزها است، و در مورد داوری کم ر چگونه با اسکرچ انیمیشن بسازیم ی پیچیدگی می‌افزاید. با این حال، به نظر می رسد الگویی که من در مثال ها استفاده کرده ام نسبتاً خوب عمل می کند.

 

این متشکل از سه قسمت است:

 

اجزای ارائه، در اینجا یک لیست و یک جزء آیتم. آن‌ها عمدتاً از انیمیشن‌ها بی‌اطلاع هستند، به جز دو مورد - همانطور که در بالا ذکر شد، فهرست والد دارای یک مرجع است، بنابراین نمی‌تواند کاربردی باشد و آیتم فرزند باید یک ویژگی data-id را ارائه کند.

توابع انیمیشن در فایل خود. من از کتابخانه انیمیشن وانیلی JS مورد علاقه خود، anime.js برای دستکاری واقعی DOM استفاده می کنم. اما می توانید از یک کتابخانه انیمیشن JS یا انتقال و انیمیشن  چگونه با اسکرچ انیمیشن بسازیم های CSS استفاده کنید.

مؤلفه مرتبه بالاتری که مؤلفه List والد را می‌پیچد و توابع انیمیشن را دریافت می‌کند. در بخش‌های مختلف چرخه حیات کامپوننت، تابع انیمیشن مناسب را با اشاره به مولفه فهرست پیچیده فراخوانی می‌کند.

این یک نمای کلی سطح بالا از نحوه ساختار کد

How to make animation with scratch  است. حالا بیایید به مثال ها نگاه کنیم!

 





:: برچسب‌ها: برنامه نویسی کودکان ,
:: بازدید از این مطلب : 177
|
امتیاز مطلب : 10
|
تعداد امتیازدهندگان : 2
|
مجموع امتیاز : 2
تاریخ انتشار : یک شنبه 22 بهمن 1402 | نظرات ()
مطالب مرتبط با این پست
لیست
می توانید دیدگاه خود را بنویسید


نام
آدرس ایمیل
وب سایت/بلاگ
:) :( ;) :D
;)) :X :? :P
:* =(( :O };-
:B /:) =DD :S
-) :-(( :-| :-))
نظر خصوصی

 کد را وارد نمایید:

آپلود عکس دلخواه: