কীভাবে উচ্চ-পারফরম্যান্স সিএসএস অ্যানিমেশন তৈরি করবেন (original) (raw)
এই নির্দেশিকা আপনাকে শেখায় কিভাবে উচ্চ-পারফরম্যান্স 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
- পারফরম্যান্স প্যানেল খুলুন।
- আপনার অ্যানিমেশন চলাকালীন রানটাইম পারফরম্যান্স রেকর্ড করুন ।
- সারাংশ ট্যাব পরিদর্শন করুন.
আপনি যদি সারাংশ ট্যাবে রেন্ডারিংয়ের জন্য একটি অশূন্য মান দেখতে পান তবে এর অর্থ হতে পারে আপনার অ্যানিমেশন ব্রাউজারটিকে লেআউটের কাজ করতে বাধ্য করছে৷
অ্যানিমেশন-সহ-উপর-বাম উদাহরণটি রেন্ডারিং কাজ করে।
অ্যানিমেশন-সহ-রূপান্তর উদাহরণটি রেন্ডারিং কাজ করে না।
ফায়ারফক্স ডেভ টুলস
Firefox DevTools-এ ওয়াটারফল আপনাকে বুঝতে সাহায্য করতে পারে ব্রাউজারটি কোথায় সময় কাটাচ্ছে।
- পারফরম্যান্স প্যানেল খুলুন।
- আপনার অ্যানিমেশন ঘটছে যখন রেকর্ডিং কর্মক্ষমতা শুরু করুন.
- রেকর্ডিং বন্ধ করুন এবং জলপ্রপাত ট্যাব পরিদর্শন করুন।
আপনি যদি Recalculate Style এর জন্য এন্ট্রি দেখতে পান, তার মানে অ্যানিমেশন রেন্ডার করতে ব্রাউজারটিকে রেন্ডারিং জলপ্রপাতের শুরুতে ফিরে যেতে হবে।
ড্রপ ফ্রেম জন্য পরীক্ষা করুন
- Chrome DevTools-এ রেন্ডারিং ট্যাব খুলুন।
- FPS মিটার চেকবক্স সক্ষম করুন৷
- আপনার অ্যানিমেশন চলাকালীন মান দেখুন।
FPS মিটার UI এর শীর্ষে থাকা ফ্রেম লেবেলে মনোযোগ দিন। এটি 50% 1 (938 m) dropped of 1878
মত মান দেখায়। একটি উচ্চ-পারফরম্যান্স অ্যানিমেশনের উচ্চ শতাংশ রয়েছে, যেমন 99%
, যার অর্থ হল কয়েকটি ফ্রেম বাদ দেওয়া হচ্ছে এবং অ্যানিমেশনটি মসৃণ দেখাচ্ছে৷
অ্যানিমেশন-সহ-উপর-বাম উদাহরণের কারণে 50% ফ্রেম বাদ দেওয়া হয়
ট্রান্সফর্ম-সহ অ্যানিমেশনের উদাহরণের কারণে মাত্র 1% ফ্রেম বাদ পড়ে।
একটি অ্যানিমেশন পেইন্ট ট্রিগার কিনা পরীক্ষা করুন
কিছু বৈশিষ্ট্য অন্যদের তুলনায় ব্রাউজারের আঁকার জন্য বেশি ব্যয়বহুল। উদাহরণ স্বরূপ, লাল বাক্স আঁকার চেয়ে অস্পষ্টতা (উদাহরণস্বরূপ, ছায়ার মতো) যেকোন কিছুর রং করতে বেশি সময় লাগে। এই পার্থক্যগুলি সর্বদা CSS-এ স্পষ্ট নয়, তবে ব্রাউজার DevTools আপনাকে চিহ্নিত করতে সাহায্য করতে পারে কোন এলাকায় আবার রং করা দরকার, সেইসাথে অন্যান্য পেইন্টিং-সম্পর্কিত পারফরম্যান্স সমস্যাগুলি।
Chrome DevTools
- Chrome DevTools-এ রেন্ডারিং ট্যাব খুলুন।
- পেইন্ট ফ্ল্যাশিং নির্বাচন করুন।
- স্ক্রীনের চারপাশে পয়েন্টারটি সরান।
Google Maps থেকে এই উদাহরণে, আপনি উপাদানগুলিকে পুনরায় রং করা দেখতে পারেন৷
আপনি যদি পুরো স্ক্রীন ফ্ল্যাশিং দেখতে পান, বা এমন জায়গাগুলি হাইলাইট করা হয়েছে যা আপনি পরিবর্তন করা উচিত বলে মনে করেন না, আরও তদন্ত করুন।
কোনো নির্দিষ্ট সম্পত্তি পেইন্টিং-সম্পর্কিত পারফরম্যান্সের সমস্যা সৃষ্টি করছে কিনা তা নির্ধারণ করতে হলে, Chrome DevTools-এর পেইন্ট প্রোফাইলার সাহায্য করতে পারে।
ফায়ারফক্স ডেভ টুলস
- সেটিংস খুলুন এবং টগল পেইন্ট ফ্ল্যাশিংয়ের জন্য একটি টুলবক্স বোতাম যোগ করুন।
- আপনি যে পৃষ্ঠাটি পরিদর্শন করতে চান, সেখানে বোতামটি টগল করুন এবং আপনার মাউস সরান বা হাইলাইট করা এলাকাগুলি দেখতে স্ক্রোল করুন৷
যৌগিক পর্যায়ে অ্যানিমেট করুন
যেখানে সম্ভব, অ্যানিমেশনগুলিকে opacity
সীমাবদ্ধ করুন এবং রেন্ডারিং পাথের সংমিশ্রণ পর্যায়ে অ্যানিমেশনগুলি রাখতে transform
৷ আপনার অ্যানিমেশনগুলির দ্বারা পথের কোন স্তর প্রভাবিত হচ্ছে তা পরীক্ষা করতে DevTools ব্যবহার করুন৷
কোনো পেইন্ট অপারেশন বিশেষভাবে ব্যয়বহুল কিনা তা দেখতে পেইন্ট প্রোফাইলার ব্যবহার করুন। আপনি যদি কিছু খুঁজে পান, তাহলে পরীক্ষা করে দেখুন যে একটি ভিন্ন CSS প্রপার্টি ভালো পারফরম্যান্সের সাথে একই চেহারা এবং অনুভূতি দেয় কিনা।
will-change
সম্পত্তি সামান্য ব্যবহার করুন, এবং শুধুমাত্র যদি আপনি একটি কর্মক্ষমতা সমস্যার সম্মুখীন হন।