কীভাবে উচ্চ-পারফরম্যান্স সিএসএস অ্যানিমেশন তৈরি করবেন (original) (raw)

Kayce Basques

রাচেল অ্যান্ড্রু

এই নির্দেশিকা আপনাকে শেখায় কিভাবে উচ্চ-পারফরম্যান্স CSS অ্যানিমেশন তৈরি করতে হয়।

দেখুন কেন কিছু অ্যানিমেশন ধীর হয়? এই সুপারিশের পিছনে তত্ত্ব শিখতে.

ব্রাউজার সামঞ্জস্য

এই নির্দেশিকাটি সুপারিশ করে এমন সমস্ত CSS বৈশিষ্ট্যগুলিতে ভাল ক্রস-ব্রাউজার সমর্থন রয়েছে৷

transform

opacity

will-change

একটি উপাদান সরান

একটি উপাদান সরাতে, transform সম্পত্তির translate বা rotation কীওয়ার্ড মান ব্যবহার করুন।

উদাহরণস্বরূপ, একটি আইটেমকে দৃশ্যে স্লাইড করতে, translate ব্যবহার করুন।

.animate {
  animation: slide-in 0.7s both;
}

@keyframes slide-in {
  0% {
    transform: translateY(-1000px);
  }
  100% {
    transform: translateY(0);
  }
}

উপাদান ঘোরাতে rotate ব্যবহার করুন. নিম্নলিখিত উদাহরণটি একটি উপাদানকে 360 ডিগ্রি ঘোরায়।

.animate {
  animation: rotate 0.7s ease-in-out both;
}

@keyframes rotate {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}

একটি উপাদানের আকার পরিবর্তন করুন

একটি উপাদানের আকার পরিবর্তন করতে, transform সম্পত্তির scale কীওয়ার্ড মান ব্যবহার করুন।

.animate {
  animation: scale 1.5s both;
}

@keyframes scale {
  50% {
    transform: scale(0.5);
  }
  100% {
    transform: scale(1);
  }
}

একটি উপাদান এর দৃশ্যমানতা পরিবর্তন করুন

একটি উপাদান দেখাতে বা লুকানোর জন্য, opacity ব্যবহার করুন।

.animate {
  animation: opacity 2.5s both;
}

@keyframes opacity {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

লেআউট বা পেইন্ট ট্রিগার যে বৈশিষ্ট্যগুলি এড়িয়ে চলুন

অ্যানিমেশনের জন্য কোনো CSS প্রপার্টি ব্যবহার করার আগে ( transform এবং opacity ছাড়া), রেন্ডারিং পাইপলাইনে সম্পত্তির প্রভাব নির্ধারণ করুন। একেবারে প্রয়োজনীয় না হলে লেআউট বা পেইন্ট ট্রিগার করে এমন কোনো সম্পত্তি এড়িয়ে চলুন।

ফোর্স লেয়ার তৈরি

যেমন ব্যাখ্যা করা হয়েছে কেন কিছু অ্যানিমেশন ধীর? , একটি নতুন স্তরে উপাদান স্থাপন করা ব্রাউজারকে লেআউটের বাকি অংশ পুনরায় রং করার প্রয়োজন ছাড়াই সেগুলিকে পুনরায় রং করতে দেয়৷

ব্রাউজারগুলি সাধারণত কোন আইটেমগুলিকে একটি নতুন স্তরে স্থাপন করা উচিত সে সম্পর্কে ভাল সিদ্ধান্ত নিতে পারে, তবে আপনি will-change সম্পত্তির সাথে ম্যানুয়ালি স্তর তৈরি করতে বাধ্য করতে পারেন৷ নাম অনুসারে, এই বৈশিষ্ট্যটি ব্রাউজারকে বলে যে এই উপাদানটি কোনওভাবে পরিবর্তিত হতে চলেছে।

CSS-এ, আপনি যেকোনো নির্বাচকের জন্য will-change প্রয়োগ করতে পারেন:

body > .sidebar {
  will-change: transform;
}

যাইহোক, স্পেসিফিকেশন পরামর্শ দেয় যে আপনার এটি শুধুমাত্র এমন উপাদানগুলিতে যোগ করা উচিত যা সর্বদা পরিবর্তন হতে চলেছে। উদাহরণস্বরূপ, এটি একটি সাইডবারের জন্য ব্যবহার করা যেতে পারে যা ব্যবহারকারী ভিতরে এবং বাইরে স্লাইড করতে পারে। উপাদানটি ঘন ঘন পরিবর্তন না হলে, পরিবর্তন ঘটার সম্ভাবনা থাকলে JavaScript ব্যবহার করে will-change প্রয়োগ করুন। ব্রাউজারকে প্রয়োজনীয় অপ্টিমাইজেশন করার জন্য পর্যাপ্ত সময় দেওয়া নিশ্চিত করুন এবং পরিবর্তন বন্ধ হয়ে গেলে সম্পত্তিটি সরিয়ে দিন।

will-change সমর্থন ছাড়াই ব্রাউজারে স্তর তৈরি করতে বাধ্য করতে, আপনি transform: translateZ(0)

ধীরগতির বা গ্লিচি অ্যানিমেশন ডিবাগ করুন

Chrome DevTools এবং Firefox DevTools আপনাকে বুঝতে সাহায্য করতে পারে কেন আপনার অ্যানিমেশনগুলি ধীর বা অস্পষ্ট।

একটি অ্যানিমেশন লেআউট ট্রিগার করে কিনা তা পরীক্ষা করুন

একটি অ্যানিমেশন যা transform ব্যতীত অন্য কিছু ব্যবহার করে একটি উপাদানকে স্থানান্তরিত করে তা ধীর হতে পারে। নিচের উদাহরণটি transform ব্যবহার করে একটি অ্যানিমেশনকে top এবং left ব্যবহার করে একটি অ্যানিমেশনের সাথে তুলনা করে।

করবেন না

.box { position: absolute; top: 10px; left: 10px; animation: move 3s ease infinite; }

@keyframes move { 50% { top: calc(90vh - 160px); left: calc(90vw - 200px); } }

করবেন

.box { position: absolute; top: 10px; left: 10px; animation: move 3s ease infinite; }

@keyframes move { 50% { transform: translate(calc(90vw - 200px), calc(90vh - 160px)); } }

আপনি নিম্নলিখিত দুটি উদাহরণে এটি পরীক্ষা করতে পারেন এবং DevTools ব্যবহার করে পারফরম্যান্স অন্বেষণ করতে পারেন।

Chrome DevTools

  1. পারফরম্যান্স প্যানেল খুলুন।
  2. আপনার অ্যানিমেশন চলাকালীন রানটাইম পারফরম্যান্স রেকর্ড করুন
  3. সারাংশ ট্যাব পরিদর্শন করুন.

আপনি যদি সারাংশ ট্যাবে রেন্ডারিংয়ের জন্য একটি অশূন্য মান দেখতে পান তবে এর অর্থ হতে পারে আপনার অ্যানিমেশন ব্রাউজারটিকে লেআউটের কাজ করতে বাধ্য করছে৷

সারাংশ প্যানেল রেন্ডারিংয়ের জন্য 37ms এবং পেইন্টিংয়ের জন্য 79ms দেখায়।

অ্যানিমেশন-সহ-উপর-বাম উদাহরণটি রেন্ডারিং কাজ করে।

সারাংশ প্যানেল রেন্ডারিং এবং পেইন্টিংয়ের জন্য শূন্য মান দেখায়।

অ্যানিমেশন-সহ-রূপান্তর উদাহরণটি রেন্ডারিং কাজ করে না।

ফায়ারফক্স ডেভ টুলস

Firefox DevTools-এ ওয়াটারফল আপনাকে বুঝতে সাহায্য করতে পারে ব্রাউজারটি কোথায় সময় কাটাচ্ছে।

  1. পারফরম্যান্স প্যানেল খুলুন।
  2. আপনার অ্যানিমেশন ঘটছে যখন রেকর্ডিং কর্মক্ষমতা শুরু করুন.
  3. রেকর্ডিং বন্ধ করুন এবং জলপ্রপাত ট্যাব পরিদর্শন করুন।

আপনি যদি Recalculate Style এর জন্য এন্ট্রি দেখতে পান, তার মানে অ্যানিমেশন রেন্ডার করতে ব্রাউজারটিকে রেন্ডারিং জলপ্রপাতের শুরুতে ফিরে যেতে হবে।

ড্রপ ফ্রেম জন্য পরীক্ষা করুন

  1. Chrome DevTools-এ রেন্ডারিং ট্যাব খুলুন।
  2. FPS মিটার চেকবক্স সক্ষম করুন৷
  3. আপনার অ্যানিমেশন চলাকালীন মান দেখুন।

FPS মিটার UI এর শীর্ষে থাকা ফ্রেম লেবেলে মনোযোগ দিন। এটি 50% 1 (938 m) dropped of 1878 মত মান দেখায়। একটি উচ্চ-পারফরম্যান্স অ্যানিমেশনের উচ্চ শতাংশ রয়েছে, যেমন 99% , যার অর্থ হল কয়েকটি ফ্রেম বাদ দেওয়া হচ্ছে এবং অ্যানিমেশনটি মসৃণ দেখাচ্ছে৷

fps মিটার দেখায় 50% ফ্রেম বাদ দেওয়া হয়েছে

অ্যানিমেশন-সহ-উপর-বাম উদাহরণের কারণে 50% ফ্রেম বাদ দেওয়া হয়

fps মিটার দেখায় মাত্র 1% ফ্রেম বাদ দেওয়া হয়েছে

ট্রান্সফর্ম-সহ অ্যানিমেশনের উদাহরণের কারণে মাত্র 1% ফ্রেম বাদ পড়ে।

একটি অ্যানিমেশন পেইন্ট ট্রিগার কিনা পরীক্ষা করুন

কিছু বৈশিষ্ট্য অন্যদের তুলনায় ব্রাউজারের আঁকার জন্য বেশি ব্যয়বহুল। উদাহরণ স্বরূপ, লাল বাক্স আঁকার চেয়ে অস্পষ্টতা (উদাহরণস্বরূপ, ছায়ার মতো) যেকোন কিছুর রং করতে বেশি সময় লাগে। এই পার্থক্যগুলি সর্বদা CSS-এ স্পষ্ট নয়, তবে ব্রাউজার DevTools আপনাকে চিহ্নিত করতে সাহায্য করতে পারে কোন এলাকায় আবার রং করা দরকার, সেইসাথে অন্যান্য পেইন্টিং-সম্পর্কিত পারফরম্যান্স সমস্যাগুলি।

Chrome DevTools

  1. Chrome DevTools-এ রেন্ডারিং ট্যাব খুলুন।
  2. পেইন্ট ফ্ল্যাশিং নির্বাচন করুন।
  3. স্ক্রীনের চারপাশে পয়েন্টারটি সরান।

সবুজ রঙে হাইলাইট করা একটি UI উপাদান এটিকে পুনরায় রং করা হবে

Google Maps থেকে এই উদাহরণে, আপনি উপাদানগুলিকে পুনরায় রং করা দেখতে পারেন৷

আপনি যদি পুরো স্ক্রীন ফ্ল্যাশিং দেখতে পান, বা এমন জায়গাগুলি হাইলাইট করা হয়েছে যা আপনি পরিবর্তন করা উচিত বলে মনে করেন না, আরও তদন্ত করুন।

কোনো নির্দিষ্ট সম্পত্তি পেইন্টিং-সম্পর্কিত পারফরম্যান্সের সমস্যা সৃষ্টি করছে কিনা তা নির্ধারণ করতে হলে, Chrome DevTools-এর পেইন্ট প্রোফাইলার সাহায্য করতে পারে।

ফায়ারফক্স ডেভ টুলস

  1. সেটিংস খুলুন এবং টগল পেইন্ট ফ্ল্যাশিংয়ের জন্য একটি টুলবক্স বোতাম যোগ করুন।
  2. আপনি যে পৃষ্ঠাটি পরিদর্শন করতে চান, সেখানে বোতামটি টগল করুন এবং আপনার মাউস সরান বা হাইলাইট করা এলাকাগুলি দেখতে স্ক্রোল করুন৷

যৌগিক পর্যায়ে অ্যানিমেট করুন

যেখানে সম্ভব, অ্যানিমেশনগুলিকে opacity সীমাবদ্ধ করুন এবং রেন্ডারিং পাথের সংমিশ্রণ পর্যায়ে অ্যানিমেশনগুলি রাখতে transform ৷ আপনার অ্যানিমেশনগুলির দ্বারা পথের কোন স্তর প্রভাবিত হচ্ছে তা পরীক্ষা করতে DevTools ব্যবহার করুন৷

কোনো পেইন্ট অপারেশন বিশেষভাবে ব্যয়বহুল কিনা তা দেখতে পেইন্ট প্রোফাইলার ব্যবহার করুন। আপনি যদি কিছু খুঁজে পান, তাহলে পরীক্ষা করে দেখুন যে একটি ভিন্ন CSS প্রপার্টি ভালো পারফরম্যান্সের সাথে একই চেহারা এবং অনুভূতি দেয় কিনা।

will-change সম্পত্তি সামান্য ব্যবহার করুন, এবং শুধুমাত্র যদি আপনি একটি কর্মক্ষমতা সমস্যার সম্মুখীন হন।