প্রতিস্থাপন, যোগ, বা জমা? এটাই হল প্রশ্ন.
একাধিক অ্যানিমেশন প্রভাব সমন্বয়
animation-composition
প্রপার্টি একাধিক অ্যানিমেশন একই সাথে একই সম্পত্তিকে প্রভাবিত করলে কী ঘটবে তা নিয়ন্ত্রণ করতে দেয়।
বলুন যে আপনি এই বেস ট্রান্সফর্মটি একটি উপাদানে প্রয়োগ করেছেন:
transform-origin: 50% 50%;
transform: translateX(50px) rotate(45deg);
এবং আপনার কাছে কীফ্রেমের এই সেটটিও রয়েছে:
@keyframes adjust {
to {
transform: translateX(100px);
}
}
একটি উপাদানে এই কীফ্রেমগুলি প্রয়োগ করার সময়, to
transform
বিদ্যমান transform
প্রতিস্থাপন করে। এটাই স্বাভাবিক ব্যবহার।
animation-composition
সাথে, আপনার এখন ডিফল্ট replace
পরিবর্তে কী ঘটবে তার উপর নিয়ন্ত্রণ আছে। গৃহীত মান হল:
-
replace
: প্রভাব মান অন্তর্নিহিত মান প্রতিস্থাপন করে। (ডিফল্ট) -
add
: প্রভাব মান অন্তর্নিহিত মান যোগ করা হয়. -
accumulate
: প্রভাবের মান অন্তর্নিহিত মানের সাথে মিলিত হয়।
যোগ এবং সঞ্চয়ের মধ্যে পার্থক্য সূক্ষ্ম। উদাহরণস্বরূপ, blur(2)
এবং blur(3)
দুটি মান নিন। একসাথে যোগ করা হলে এটি blur(2) blur(3)
উৎপন্ন করবে, কিন্তু জমা হলে এটি blur(5)
উৎপন্ন করবে।
আপনি এটিকে চায়ে ভরা কাপের সাথে তুলনা করতে পারেন। এটিতে দুধ ঢালা হলে এটি ঘটবে:
-
replace
: চা সরানো হয়, এবং দুধ দ্বারা প্রতিস্থাপিত হয়। -
add
: দুধ কাপে যোগ করা হয়, কিন্তু এটি চায়ের উপরে স্তরিত থাকে। -
accumulate
: দুধ চায়ে যোগ করা হয় এবং উভয়ই তরল হওয়ায় তারা সুন্দরভাবে মিশে যায়।
ডেমো
নীচের ডেমোতে তিনটি ধূসর বাক্স রয়েছে যেগুলিতে বেস transform
এবং animation
প্রয়োগ করা হয়েছে।
যদিও এই বাক্সগুলির একই অ্যানিমেশন থাকে তারা একটি ভিন্ন ফলাফল দেয় কারণ তাদের একটি ভিন্ন animation-composition
সেট রয়েছে:
প্রথম বাক্সটি animation-composition: replace
। এটাই স্বাভাবিক ব্যবহার। এর শেষ অবস্থানে, transform
জন্য আসল translateX(50px) rotate(45deg)
মানটি translateX(100px)
দ্বারা প্রতিস্থাপিত হয়।
দ্বিতীয় বাক্সটি animation-composition: add
। এর শেষ অবস্থানে, translateX(100px)
মূল translateX(50px) rotate(45deg)
এ যোগ করা হয়, যার ফলে translateX(50px) rotate(45deg) translateX(100px)
। এটি বাক্সটিকে 50px দ্বারা সরায়, তারপর এটি 45deg ঘুরিয়ে দেয় এবং তারপরে এটি 100px সরে যায়।
তৃতীয় বাক্সটি animation-composition: accumulate
। এর শেষ অবস্থানে, translateX(100px)
মূল ট্রান্সফর্ম থেকে translateX(50px)
এ গাণিতিকভাবে যোগ করা হবে, যার ফলে translateX(150px) rotate(45deg)
রূপান্তরিত হবে।