অ্যানিমেশন

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

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

আপনার ব্যবহারকারীরা গুরুত্বপূর্ণ তথ্যের প্রতি মনোযোগ দেয় তা নিশ্চিত করার একটি উপায় হল পালসিং আইকন৷

আপনি কীফ্রেম সহ একটি অ্যানিমেশন সিকোয়েন্স সেট করতে CSS ব্যবহার করতে পারেন। এই ক্রমগুলি মৌলিক, এক-রাজ্য অ্যানিমেশন বা জটিল, সময়-ভিত্তিক ক্রম হতে পারে।

একটি কীফ্রেম কি?

বেশিরভাগ অ্যানিমেশন সরঞ্জামগুলিতে, কীফ্রেমগুলি হল সেই পদ্ধতি যা আপনি একটি টাইমলাইনে টাইমস্ট্যাম্পগুলিতে অ্যানিমেশন স্টেটগুলি বরাদ্দ করতে ব্যবহার করেন।

উদাহরণস্বরূপ, এখানে স্পন্দিত "সহায়ক" বিন্দুর জন্য একটি টাইমলাইন রয়েছে৷ অ্যানিমেশনটি 1 সেকেন্ডের জন্য চলে এবং এর 2টি রাজ্য রয়েছে।

1 সেকেন্ডের সময়সীমার মধ্যে পালসার অ্যানিমেশনের অবস্থা
স্পন্দন অ্যানিমেশন রাষ্ট্র.

একটি নির্দিষ্ট বিন্দু যেখানে এই অ্যানিমেশন স্টেটগুলির প্রতিটি শুরু এবং শেষ হয়। আপনি কীফ্রেমগুলির সাথে টাইমলাইনে এগুলি ম্যাপ করুন৷

আগের মত একই ডায়াগ্রাম, কিন্তু এইবার, কীফ্রেম সহ
কীফ্রেমের সাথে স্পন্দিত অ্যানিমেশন।

@keyframes

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

CSS @keyframes অ্যানিমেশন কীফ্রেমের মতো একই ধারণার উপর ভিত্তি করে তৈরি।

এখানে দুটি রাজ্যের সাথে একটি উদাহরণ রয়েছে:

@keyframes my-animation {
  from {
    transform: translateY(20px);
  }
  to {
    transform: translateY(0px);
  }
}

প্রথম গুরুত্বপূর্ণ অংশটি হল কাস্টম শনাক্তকারী ( custom-ident ) , কীফ্রেম নিয়মের নাম। এই উদাহরণে শনাক্তকারী হল my-animation । কাস্টম শনাক্তকারী একটি ফাংশনের নামের মতো কাজ করে, আপনাকে আপনার CSS কোডের অন্য কোথাও কীফ্রেম নিয়ম উল্লেখ করতে দেয়।

কীফ্রেম নিয়মের মধ্যে, from এবং to কীওয়ার্ডগুলি 0% এবং 100% প্রতিনিধিত্ব করে, যা অ্যানিমেশনের শুরু এবং শেষ। আপনি এই মত একই নিয়ম পুনরায় তৈরি করতে পারেন:

@keyframes my-animation {
    0% {
        transform: translateY(20px);
    }
    100% {
        transform: translateY(0px);
    }
}

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

@keyframes pulse {
  0% {
    opacity: 0;
  }
  50% {
    transform: scale(1.4);
    opacity: 0.4;
  }
}
অ্যানিমেশন কীভাবে পরিবর্তিত হয় তা দেখতে pulse নিয়ম সম্পাদনার চেষ্টা করুন।

animation বৈশিষ্ট্য

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

একটি CSS নিয়মে আপনার @keyframes ব্যবহার করতে, আপনি হয় পৃথকভাবে বিভিন্ন অ্যানিমেশন বৈশিষ্ট্য সংজ্ঞায়িত করতে পারেন, অথবা animation শর্টহ্যান্ড বৈশিষ্ট্য ব্যবহার করতে পারেন।

animation-duration

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

.my-element {
    animation-duration: 10s;
}

অ্যানিমেশন-সময়কাল বৈশিষ্ট্য নির্ধারণ করে যে @keyframes টাইমলাইন একটি সময়ের মান হিসাবে কতক্ষণ হওয়া উচিত। এটি ডিফল্ট 0 সেকেন্ড, যার অর্থ অ্যানিমেশন এখনও চলে, কিন্তু এটি আপনার পক্ষে দেখতে খুব দ্রুত হবে৷ আপনি নেতিবাচক সময় মান ব্যবহার করতে পারবেন না.

animation-timing-function

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

অ্যানিমেশনে প্রাকৃতিক গতি পুনরায় তৈরি করতে সাহায্য করার জন্য, আপনি টাইমিং ফাংশন ব্যবহার করতে পারেন যা প্রতিটি পয়েন্টে অ্যানিমেশনের গতি গণনা করে। গণনা করা মানগুলি প্রায়শই বাঁকা হয়, যার ফলে অ্যানিমেশনটি animation-duration ধরে পরিবর্তনশীল গতিতে চলে এবং যদি ব্রাউজার @keyframes এ সংজ্ঞায়িত মানগুলির বাইরে একটি মান গণনা করে তাহলে উপাদানটি বাউন্স হতে দেখা যায়।

CSS-এ প্রিসেট হিসেবে বেশ কিছু কীওয়ার্ড পাওয়া যায়, যেগুলো অ্যানিমেশন-টাইমিং-ফাংশনের মান হিসেবে ব্যবহার করা হয়: linear , ease , ease-in , ease-out , ease-in-out

.my-element {
    animation-timing-function: ease-in-out;
}
অ্যানিমেশন কোন টাইমিং ফাংশন ব্যবহার করে তা পরিবর্তন করার চেষ্টা করুন।

ইজিং ফাংশনের মানগুলি বক্ররেখায় প্রদর্শিত হয় কারণ ইজিং একটি বেজিয়ার বক্ররেখা ব্যবহার করে গণনা করা হয়, একটি প্রকারের ফাংশন যা বেগের মডেল করতে ব্যবহৃত হয়। প্রতিটি টাইমিং ফাংশন কীওয়ার্ড, যেমন ease , একটি পূর্বনির্ধারিত বেজিয়ার বক্ররেখা উল্লেখ করে। CSS-এ, আপনি cubic-bezier() ফাংশন ব্যবহার করে সরাসরি একটি Bézier বক্ররেখা সংজ্ঞায়িত করতে পারেন, যা চারটি সংখ্যা মান গ্রহণ করে: x1 , y1 , x2 , y2

.my-element {
    animation-timing-function: cubic-bezier(.42, 0, .58, 1);
}

এই মানগুলি X এবং Y অক্ষ বরাবর বক্ররেখার প্রতিটি অংশকে প্লট করে।

একটি অগ্রগতি বনাম সময় চার্টে একটি বেজিয়ার বক্ররেখা
একটি উদাহরণ Bézier বক্ররেখা.

বেজিয়ার কার্ভ বোঝা জটিল। ভিজ্যুয়াল টুল, যেমন Lea Verou দ্বারা এই জেনারেটর , খুব সহায়ক।

steps সহজীকরণ ফাংশন

কখনও কখনও আপনি একটি বক্ররেখা বরাবর পরিবর্তে বিরতিতে সরানোর মাধ্যমে আপনার অ্যানিমেশনের আরও দানাদার নিয়ন্ত্রণ নিতে চাইতে পারেন। steps() ইজিং ফাংশন আপনাকে টাইমলাইনকে সমান সময়কালের নির্দিষ্ট ব্যবধানে ভাঙতে দেয়।

.my-element {
    animation-timing-function: steps(10, end);
}

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

দ্বিতীয় যুক্তি হল দিক। যদি এটি end সেট করা থাকে, যা ডিফল্ট, পদক্ষেপগুলি আপনার টাইমলাইনের শেষে শেষ হয়৷ এটি start জন্য সেট করা থাকলে, আপনার অ্যানিমেশনের প্রথম ধাপটি শুরু হওয়ার সাথে সাথেই সম্পূর্ণ হয়, যার মানে এটি end চেয়ে এক ধাপ আগে শেষ হয়।

অ্যানিমেশনের সাথে এবং ধাপ ছাড়া তুলনা করুন।

animation-iteration-count

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

.my-element {
    animation-iteration-count: 10;
}

অ্যানিমেশন-পুনরাবৃত্তি-গণনা বৈশিষ্ট্য অ্যানিমেশনের সময় @keyframes টাইমলাইন কতবার চালানো উচিত তা নির্ধারণ করে। ডিফল্টরূপে, এটি 1, যার অর্থ হল অ্যানিমেশনটি আপনার টাইমলাইনের শেষের দিকে পৌঁছালে তা বন্ধ হয়ে যায়। এই মান একটি ঋণাত্মক সংখ্যা হতে পারে না.

এই অ্যানিমেশনের জন্য পুনরাবৃত্তি গণনা পরিবর্তন করার চেষ্টা করুন।

আপনার অ্যানিমেশন লুপ করতে, পুনরাবৃত্তি গণনা infinite সেট করুন। এই পাঠের শুরু থেকে স্পন্দিত অ্যানিমেশন এইভাবে কাজ করে।

স্পন্দিত অ্যানিমেশন অসীমভাবে পুনরাবৃত্তি করে।

animation-direction

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

.my-element {
    animation-direction: reverse;
}

আপনি অ্যানিমেশন-নির্দেশ সহ আপনার কীফ্রেমের উপর টাইমলাইন কোন দিকটি চলে তা সেট করতে পারেন, যা নিম্নলিখিত মানগুলি নেয়:

  • normal : ডিফল্ট মান, যা ফরোয়ার্ড।
  • reverse : আপনার টাইমলাইনে পিছনে চলে।
  • alternate : প্রতিটি অ্যানিমেশন পুনরাবৃত্তির জন্য, টাইমলাইনটি সামনের দিকে দৌড়ানো এবং পিছনের দিকে দৌড়ানোর মধ্যে বিকল্প হয়।
  • alternate-reverse : alternate মতো, কিন্তু অ্যানিমেশনটি টাইমলাইন পিছিয়ে চলার সাথে শুরু হয়।
অ্যানিমেশন দিক পরিবর্তন করার চেষ্টা করুন।

animation-delay

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

.my-element {
    animation-delay: 5s;
}

অ্যানিমেশন-বিলম্ব বৈশিষ্ট্য নির্ধারণ করে যে অ্যানিমেশন শুরু করার আগে ব্রাউজার কতক্ষণ অপেক্ষা করে। animation-duration বৈশিষ্ট্যের মতো, এটি একটি সময় মান নেয়।

animation-duration বিপরীতে, আপনি animation-delay একটি নেতিবাচক মান হিসাবে সংজ্ঞায়িত করতে পারেন , যা আপনার টাইমলাইনের সংশ্লিষ্ট বিন্দুতে অ্যানিমেশন শুরু করে। উদাহরণস্বরূপ, যদি আপনার অ্যানিমেশন 10 সেকেন্ড দীর্ঘ হয় এবং আপনি animation-delay -5s সেট করেন, তাহলে অ্যানিমেশন আপনার টাইমলাইনের অর্ধেক থেকে শুরু হয়।

অ্যানিমেশন বিলম্ব পরিবর্তন করার চেষ্টা করুন.

animation-play-state

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

.my-element:hover {
    animation-play-state: paused;
}

অ্যানিমেশন-প্লে-স্টেট সম্পত্তি আপনাকে অ্যানিমেশন খেলতে এবং বিরতি দিতে দেয়। ডিফল্ট মান running । আপনি যদি এটিকে paused সেট করেন, অ্যানিমেশনটি বিরতি দেয়।

অ্যানিমেশন বিরাম দিতে অ্যানিমেটেড উপাদানের উপর আপনার কার্সার ধরে রাখুন।

animation-fill-mode

ব্রাউজার সমর্থন

  • ক্রোম: 43।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 16.
  • সাফারি: 9।

উৎস

অ্যানিমেশন-ফিল-মোড প্রপার্টি অ্যানিমেশন শুরু হওয়ার আগে বা শেষ হওয়ার পরে আপনার @keyframes টাইমলাইনে কোন মানগুলি বজায় থাকবে তা নির্ধারণ করে। ডিফল্ট মান none , যার অর্থ হল অ্যানিমেশন সম্পূর্ণ হলে, আপনার টাইমলাইনে থাকা মানগুলি বাতিল করা হবে৷ অন্যান্য বিকল্প অন্তর্ভুক্ত:

  • forwards : অ্যানিমেশন দিকনির্দেশের উপর ভিত্তি করে শেষ কীফ্রেমটি টিকে থাকে।
  • backwards : অ্যানিমেশন দিকনির্দেশের উপর ভিত্তি করে প্রথম কীফ্রেমটি টিকে থাকে।
  • both : প্রথম এবং শেষ উভয় কীফ্রেমই টিকে থাকে।
ফিল মোড পরিবর্তন করার চেষ্টা করুন।

animation শর্টহ্যান্ড

প্রতিটি সম্পত্তি আলাদাভাবে সংজ্ঞায়িত করার পরিবর্তে, আপনি একটি animation শর্টহ্যান্ডে তাদের সংজ্ঞায়িত করতে পারেন, যা আপনাকে নিম্নলিখিত ক্রমে অ্যানিমেশন বৈশিষ্ট্যগুলিকে সংজ্ঞায়িত করতে দেয়:

  1. animation-name
  2. animation-duration
  3. animation-timing-function
  4. animation-delay
  5. animation-iteration-count
  6. animation-direction
  7. animation-fill-mode
  8. animation-play-state
.my-element {
    animation: my-animation 10s ease-in-out 1s infinite forwards forwards running;
}

অ্যানিমেশন নিয়ে কাজ করার সময় বিবেচনা করুন

অ্যাপ্লিকেশন এবং ওয়েবসাইটগুলির সাথে ইন্টারঅ্যাক্ট করার সময় ব্যবহারকারীরা তাদের অপারেটিং সিস্টেমকে কম গতিতে পছন্দ করতে সেট করতে পারেন। আপনি prefers-reduced-motion media ক্যোয়ারী ব্যবহার করে এই পছন্দটি সনাক্ত করতে পারেন:

@media (prefers-reduced-motion) {
  .my-autoplaying-animation {
    animation-play-state: paused;
  }
}

এটি অগত্যা কোন অ্যানিমেশন জন্য একটি পছন্দ নয়. এটি কম অ্যানিমেশনের জন্য একটি পছন্দ, বিশেষ করে কম অপ্রত্যাশিত অ্যানিমেশন। আপনি আমাদের অ্যানিমেশন গাইডে এই পছন্দ এবং সামগ্রিক কর্মক্ষমতা সম্পর্কে আরও জানতে পারেন৷

হ্রাসকৃত অ্যানিমেশনের একটি উদাহরণ চেষ্টা করুন।

আপনার উপলব্ধি পরীক্ষা করুন

অ্যানিমেশন আপনার জ্ঞান পরীক্ষা করুন

একটি @keyframes অ্যানিমেশন কেস সংবেদনশীল নাম বা কাস্টম শনাক্তকারী ?

হ্যাঁ
🎉
না
CSS 2টি অ্যানিমেশনকে একই নামের অনুমতি দেয় না, তবে এটি SWOOP এবং swoop সহাবস্থান করতে দেয়।

from এবং to কীওয়ার্ড একই রকম:

start এবং end
আবার চেষ্টা করুন!
0% এবং 100%
from 0% এর সমান এবং to 100% এর সমান।
0 এবং 1
আবার চেষ্টা করুন!

animation-timing-function সাধারণত এই নামেও পরিচিত:

গতিশীল সময়
আবার চেষ্টা করুন!
বিলম্ব
আবার চেষ্টা করুন!
ইজিং
🎉

@keyframes অ্যানিমেশনের মধ্যে ন্যূনতম সংখ্যক কীফ্রেম প্রয়োজন?

1
ব্রাউজার উপাদানটির বর্তমান অবস্থাটিকে একটি কীফ্রেম হিসাবে গ্রহণ করবে, তাই সর্বনিম্ন 1টি কীফ্রেম প্রয়োজন৷
2
আবার চেষ্টা করুন!
3
আবার চেষ্টা করুন!
4
আবার চেষ্টা করুন!