prefers-reduced-motion: কখনও কখনও কম নড়াচড়া বেশি হয়

প্রিফারস-রিডুড-মোশন মিডিয়া ক্যোয়ারী শনাক্ত করে যে ব্যবহারকারী অপারেটিং সিস্টেমকে অ্যানিমেশন বা গতির পরিমাণ কমানোর জন্য অনুরোধ করেছে কিনা।

সবাই আলংকারিক অ্যানিমেশন বা ট্রানজিশন পছন্দ করে না এবং কিছু ব্যবহারকারী প্যারালাক্স স্ক্রলিং, জুমিং ইফেক্ট এবং আরও অনেক কিছুর মুখোমুখি হলে মোশন সিকনেস অনুভব করেন। ব্যবহারকারীর পছন্দ মিডিয়া ক্যোয়ারী prefers-reduced-motion আপনাকে আপনার সাইটের একটি গতি-হ্রাস করা বৈকল্পিক ডিজাইন করতে দেয় যারা এই পছন্দ প্রকাশ করেছেন তাদের জন্য।

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

  • ক্রোম: 74।
  • প্রান্ত: 79।
  • ফায়ারফক্স: 63.
  • সাফারি: 10.1।

উৎস

বাস্তব জীবনে এবং ওয়েবে খুব বেশি গতি

অন্য দিন, আমি আমার বাচ্চাদের সাথে আইস স্কেটিং করছিলাম। এটি একটি সুন্দর দিন ছিল, সূর্য জ্বলছিল, এবং বরফের রিঙ্কটি লোকেদের সাথে ঠাসা ছিল ⛸। এর সাথে একমাত্র সমস্যা: আমি ভিড়ের সাথে ভালভাবে মানিয়ে নিতে পারি না। অনেক গতিশীল লক্ষ্যের সাথে, আমি কোন কিছুতে ফোকাস করতে ব্যর্থ হই, এবং শেষ পর্যন্ত হারিয়ে যাই এবং সম্পূর্ণ ভিজ্যুয়াল ওভারলোডের অনুভূতি সহ, প্রায় একটি অ্যান্টিলের দিকে তাকানোর মতন 🐜।

বরফ স্কেটিং মানুষের পায়ের ভীড়.
বাস্তব জীবনে ভিজ্যুয়াল ওভারলোড।

মাঝে মাঝে, ওয়েবে একই ঘটনা ঘটতে পারে: ফ্ল্যাশিং বিজ্ঞাপন, অভিনব প্যারালাক্স ইফেক্ট, বিস্ময়কর প্রকাশ অ্যানিমেশন, অটোপ্লেয়িং ভিডিও এবং আরও অনেক কিছু সহ, ওয়েব কখনও কখনও বেশ অপ্রতিরোধ্য হতে পারে … সুখের বিষয়, বাস্তব জীবনের বিপরীতে, এর একটি সমাধান রয়েছে৷ CSS মিডিয়া ক্যোয়ারী prefers-reduced-motion ডেভেলপারদের এমন ব্যবহারকারীদের জন্য একটি পৃষ্ঠার একটি বৈকল্পিক তৈরি করতে দেয় যারা, ভাল, কম গতি পছন্দ করে। এতে ভিডিও অটোপ্লে করা থেকে বিরত থাকা থেকে শুরু করে কিছু নির্দিষ্ট আলংকারিক প্রভাব অক্ষম করা থেকে শুরু করে নির্দিষ্ট ব্যবহারকারীদের জন্য একটি পৃষ্ঠাকে সম্পূর্ণরূপে পুনরায় ডিজাইন করা হতে পারে।

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

ওয়েবে অ্যানিমেশন

অ্যানিমেশন প্রায়শই ব্যবহারকারীকে প্রতিক্রিয়া প্রদান করতে ব্যবহার করা হয়, উদাহরণস্বরূপ, তাদের জানাতে যে একটি ক্রিয়া গৃহীত হয়েছে এবং প্রক্রিয়া করা হচ্ছে। উদাহরণস্বরূপ, একটি শপিং ওয়েবসাইটে, একটি পণ্যকে একটি ভার্চুয়াল শপিং কার্টে "উড়তে" অ্যানিমেটেড করা যেতে পারে, সাইটের উপরের-ডানদিকে একটি আইকন হিসাবে চিত্রিত করা হয়েছে৷

আরেকটি ব্যবহারের ক্ষেত্রে ব্যবহারকারীর অনেক সময় ব্যয় করতে এবং পুরো অভিজ্ঞতাকে দ্রুত অনুভব করতে কঙ্কাল স্ক্রীন, প্রাসঙ্গিক মেটাডেটা এবং নিম্নমানের চিত্রের পূর্বরূপের মিশ্রণ ব্যবহার করে ব্যবহারকারীর ধারণা হ্যাক করার জন্য গতি ব্যবহার করা জড়িত। ধারণাটি হল ব্যবহারকারীকে কী আসছে তার প্রসঙ্গ দেওয়া এবং এর মধ্যে যত তাড়াতাড়ি সম্ভব জিনিসগুলি লোড করা।

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

মোশন-ট্রিগারড ভেস্টিবুলার স্পেকট্রাম ডিসঅর্ডার

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

অপারেটিং সিস্টেমে গতি সরান

অনেক অপারেটিং সিস্টেমে দীর্ঘ সময়ের জন্য কম গতির জন্য একটি পছন্দ নির্দিষ্ট করার জন্য অ্যাক্সেসযোগ্যতা সেটিংস রয়েছে। নিম্নলিখিত স্ক্রিনশটগুলি macOS Mojave-এর Reduce motion preference এবং Android Pie-এর রিমুভ অ্যানিমেশন পছন্দ দেখায়৷ চেক করা হলে, এই পছন্দগুলি অপারেটিং সিস্টেমকে অ্যাপ্লিকেশান লঞ্চিং অ্যানিমেশনের মতো আলংকারিক প্রভাবগুলি ব্যবহার না করার কারণ করে৷ অ্যাপ্লিকেশনগুলি নিজেরাও এই সেটিংটিকে সম্মান করতে পারে এবং করা উচিত এবং সমস্ত অপ্রয়োজনীয় অ্যানিমেশনগুলি সরিয়ে ফেলতে পারে৷

'মোশন কমানো' চেকবক্স সহ macOS সেটিংস স্ক্রীনটি চেক করা হয়েছে৷
'অ্যানিমেশন সরান' চেকবক্স সহ Android সেটিংস স্ক্রীনটি চেক করা হয়েছে।

ওয়েবে গতি সরান

মিডিয়া ক্যোয়ারি লেভেল 5 ওয়েবে কম গতি ব্যবহারকারী পছন্দ নিয়ে আসে। মিডিয়া ক্যোয়ারীগুলি লেখকদের ব্যবহারকারী এজেন্টের মান বা বৈশিষ্ট্যগুলি পরীক্ষা এবং অনুসন্ধান করার অনুমতি দেয় বা নথিটি রেন্ডার করা থেকে স্বাধীন ডিভাইস প্রদর্শন করে৷ মিডিয়া ক্যোয়ারী prefers-reduced-motion শনাক্ত করতে ব্যবহৃত হয় যে ব্যবহারকারী এটি ব্যবহার করে অ্যানিমেশন বা গতির পরিমাণ কমানোর জন্য একটি অপারেটিং সিস্টেম পছন্দ সেট করেছে কিনা। এটি দুটি সম্ভাব্য মান নিতে পারে:

  • no-preference : নির্দেশ করে যে ব্যবহারকারী অন্তর্নিহিত অপারেটিং সিস্টেমে কোন পছন্দ করেননি। এই কীওয়ার্ড মানটি বুলিয়ান প্রসঙ্গে false হিসাবে মূল্যায়ন করে।
  • reduce : ইঙ্গিত করে যে ব্যবহারকারী একটি অপারেটিং সিস্টেম পছন্দ সেট করেছেন যা নির্দেশ করে যে ইন্টারফেসগুলি চলাচল বা অ্যানিমেশনকে কমিয়ে আনতে হবে, বিশেষত সেই বিন্দুতে যেখানে সমস্ত অপ্রয়োজনীয় আন্দোলন সরানো হয়।

CSS এবং JavaScript প্রসঙ্গ থেকে মিডিয়া ক্যোয়ারী নিয়ে কাজ করা

সমস্ত মিডিয়া কোয়েরির মতো, একটি CSS প্রসঙ্গ এবং একটি জাভাস্ক্রিপ্ট প্রসঙ্গ থেকে prefers-reduced-motion চেক করা যেতে পারে।

উভয়কে ব্যাখ্যা করার জন্য, ধরে নিন আমার কাছে একটি গুরুত্বপূর্ণ সাইন-আপ বোতাম রয়েছে যা আমি ব্যবহারকারীকে ক্লিক করতে চাই। আমি একটি মনোযোগ আকর্ষণকারী "ভাইব্রেট" অ্যানিমেশন সংজ্ঞায়িত করতে পারি, কিন্তু একজন ভাল ওয়েব নাগরিক হিসাবে আমি এটি শুধুমাত্র সেইসব ব্যবহারকারীদের জন্য চালাব যারা অ্যানিমেশনের সাথে স্পষ্টভাবে ঠিক আছে, কিন্তু অন্য সবাই নয়, যারা অ্যানিমেশন থেকে অপ্ট আউট করেছেন এমন ব্যবহারকারী হতে পারে, অথবা ব্রাউজারে ব্যবহারকারীরা যারা মিডিয়া কোয়েরি বুঝতে পারে না।

/*
  If the user has expressed their preference for
  reduced motion, then don't use animations on buttons.
*/

@media (prefers-reduced-motion: reduce) {
  button
{
   
animation: none;
 
}
}

/*
  If the browser understands the media query and the user
  explicitly hasn't set a preference, then use animations on buttons.
*/

@media (prefers-reduced-motion: no-preference) {
  button
{
   
/* `vibrate` keyframes are defined elsewhere */
   
animation: vibrate 0.3s linear infinite both;
 
}
}

জাভাস্ক্রিপ্টের সাথে prefers-reduced-motion সাথে কিভাবে কাজ করতে হয় তা বোঝাতে, কল্পনা করুন আমি ওয়েব অ্যানিমেশন API এর সাথে একটি জটিল অ্যানিমেশন সংজ্ঞায়িত করেছি। যখন ব্যবহারকারীর পছন্দ পরিবর্তন হয় তখন ব্রাউজার দ্বারা CSS নিয়মগুলি গতিশীলভাবে ট্রিগার করা হবে, জাভাস্ক্রিপ্ট অ্যানিমেশনগুলির জন্য আমাকে পরিবর্তনগুলি শুনতে হবে এবং তারপর ম্যানুয়ালি আমার সম্ভাব্য ইন-ফ্লাইট অ্যানিমেশনগুলি বন্ধ করতে হবে (অথবা ব্যবহারকারী আমাকে অনুমতি দিলে সেগুলি পুনরায় চালু করুন):

const mediaQuery = window.matchMedia('(prefers-reduced-motion: reduce)');
mediaQuery
.addEventListener('change', () => {
  console
.log(mediaQuery.media, mediaQuery.matches);
 
// Stop JavaScript-based animations.
});

মনে রাখবেন যে প্রকৃত মিডিয়া কোয়েরির চারপাশে বন্ধনীগুলি বাধ্যতামূলক:

করবেন না
window.matchMedia('prefers-reduced-motion: reduce');
করবেন
window.matchMedia('(prefers-reduced-motion: reduce)');

<picture> প্রসঙ্গ থেকে মিডিয়া ক্যোয়ারী নিয়ে কাজ করা

একটি আকর্ষণীয় ব্যবহারের ক্ষেত্রে একটি অ্যানিমেটেড AVIF, WebP, বা GIF চালানো media বৈশিষ্ট্যের উপর নির্ভরশীল করা। যদি (prefers-reduced-motion: no-preference) true মূল্যায়ন করে, তবে অ্যানিমেটেড সংস্করণ প্রদর্শন করা নিরাপদ, অন্যথায় স্ট্যাটিক সংস্করণ:

<picture>
 
<!-- Animated versions. -->
 
<source
   
srcset="nyancat.avifs"
   
type="image/avif"
   
media="(prefers-reduced-motion: no-preference)"
 
/>
 
<source
   
srcset="nyancat.gif"
   
type="image/gif"
   
media="(prefers-reduced-motion: no-preference)"
 
/>
 
<!-- Static versions. -->
 
<img src="nyancat.png" alt="Nyan cat" width="250" height="250" />
</picture>

আপনি নিম্নলিখিত উদাহরণ দেখতে পারেন. পার্থক্য দেখতে আপনার ডিভাইসের গতি পছন্দ টগল করার চেষ্টা করুন।

বিখ্যাত নয়ান বিড়াল।

অনুরোধের সময় ব্যবহারকারীর পছন্দগুলি আবিষ্কার করুন

Sec-CH-Prefers-Reduced-Motion ক্লায়েন্ট ইঙ্গিত শিরোনাম সাইটগুলিকে অনুরোধের সময় ঐচ্ছিকভাবে ব্যবহারকারীর গতি পছন্দগুলি প্রাপ্ত করার অনুমতি দেয়, সার্ভারগুলিকে পারফরম্যান্সের কারণে সঠিক CSS ইনলাইন করতে দেয়৷

ডেমো

আমি Rogério Vicente এর আশ্চর্যজনক 🐈 HTTP স্ট্যাটাস বিড়ালের উপর ভিত্তি করে একটি ছোট ডেমো তৈরি করেছি। প্রথমে, কৌতুকটির প্রশংসা করার জন্য একটু সময় নিন, এটি হাস্যকর এবং আমি অপেক্ষা করব। এখন আপনি ফিরে এসেছেন, আমাকে ডেমো পরিচয় করিয়ে দিন। যখন আপনি স্ক্রোল করেন, প্রতিটি HTTP স্থিতি বিড়াল পর্যায়ক্রমে ডান বা বাম দিক থেকে প্রদর্শিত হয়। এটি একটি বাটারি মসৃণ 60 FPS অ্যানিমেশন, কিন্তু পূর্বে বর্ণিত হিসাবে, কিছু ব্যবহারকারী এটিকে অপছন্দ করতে পারে বা এমনকি এটির দ্বারা মোশন সিক হতে পারে, তাই ডেমোটি prefers-reduced-motion সম্মান করার জন্য প্রোগ্রাম করা হয়েছে। এটি এমনকি গতিশীলভাবে কাজ করে, যাতে ব্যবহারকারীরা তাদের পছন্দ পরিবর্তন করতে পারেন উড়তে, কোন পুনরায় লোড প্রয়োজন হয় না। যদি একজন ব্যবহারকারী হ্রাস গতি পছন্দ করে, অপ্রয়োজনীয় প্রকাশ অ্যানিমেশন চলে গেছে, এবং শুধুমাত্র নিয়মিত স্ক্রোলিং গতি বাকি আছে। নিম্নলিখিত স্ক্রিনকাস্টটি কর্মে ডেমো দেখায়:

prefers-reduced-motion ডেমো অ্যাপের ভিডিও

উপসংহার

আধুনিক ওয়েবসাইটগুলির জন্য ব্যবহারকারীর পছন্দগুলিকে সম্মান করা গুরুত্বপূর্ণ, এবং ওয়েব ডেভেলপারদের এটি করতে সক্ষম করার জন্য ব্রাউজারগুলি আরও বেশি বেশি বৈশিষ্ট্য প্রকাশ করছে। আর একটি লঞ্চ করা উদাহরণ হল prefers-color-scheme , যা সনাক্ত করে যে ব্যবহারকারী একটি হালকা বা গাঢ় রঙের স্কিম পছন্দ করে কিনা। হ্যালো ডার্কনেস, মাই ওল্ড ফ্রেন্ড 🌒 আমার নিবন্ধে আপনি prefers-color-scheme সম্পর্কে সবকিছু পড়তে পারেন।

সিএসএস ওয়ার্কিং গ্রুপ আরও ব্যবহারকারীর পছন্দের মিডিয়া কোয়েরি যেমন prefers-reduced-transparency (ব্যবহারকারী কম স্বচ্ছতা পছন্দ করে কিনা তা শনাক্ত করে), prefers-contrast (শনাক্ত করে যদি ব্যবহারকারী সিস্টেমকে সংলগ্ন রঙের মধ্যে বৈসাদৃশ্যের পরিমাণ বাড়াতে বা কমাতে অনুরোধ করে থাকে তা সনাক্ত করে। ), এবং inverted-colors (ব্যবহারকারী উল্টানো রং পছন্দ করে কিনা তা সনাক্ত করে)।

(বোনাস) সমস্ত ওয়েবসাইটে জোরপূর্বক গতি হ্রাস করা

প্রতিটি সাইট prefers-reduced-motion ব্যবহার করবে না, বা আপনার স্বাদের জন্য উল্লেখযোগ্যভাবে যথেষ্ট নয়। আপনি যদি, যে কারণেই হোক, সমস্ত ওয়েবসাইটে গতি বন্ধ করতে চান, আপনি আসলে করতে পারেন। এটি ঘটানোর একটি উপায় হল নিম্নলিখিত সিএসএস সহ একটি স্টাইল শীট আপনার পরিদর্শন করা প্রতিটি ওয়েব পৃষ্ঠায় ইনজেক্ট করা। সেখানে বেশ কয়েকটি ব্রাউজার এক্সটেনশন রয়েছে (আপনার নিজের ঝুঁকিতে ব্যবহার করুন!) যা এটির অনুমতি দেয়।

@media (prefers-reduced-motion: reduce) {
 
*,
 
::before,
 
::after {
   
animation-delay: -1ms !important;
   
animation-duration: 1ms !important;
   
animation-iteration-count: 1 !important;
   
background-attachment: initial !important;
   
scroll-behavior: auto !important;
   
transition-duration: 1ms !important;
   
transition-delay: -1ms !important;
 
}
}

এটি যেভাবে কাজ করে তা হল যে পূর্ববর্তী CSS সমস্ত অ্যানিমেশনের সময়কালকে ওভাররাইড করে এবং এত অল্প সময়ে পরিবর্তন করে যে সেগুলি আর লক্ষ্য করা যায় না। যেহেতু কিছু ওয়েবসাইট সঠিকভাবে কাজ করার জন্য চালানোর জন্য একটি অ্যানিমেশনের উপর নির্ভর করে (হয়ত কারণ একটি নির্দিষ্ট পদক্ষেপ animationend ইভেন্টের ফায়ারিংয়ের উপর নির্ভর করে), তত বেশি আমূল animation: none !important; পদ্ধতি কাজ করবে না। এমনকি পূর্ববর্তী হ্যাকটিও সমস্ত ওয়েবসাইটে সফল হওয়ার গ্যারান্টি দেওয়া হয় না (উদাহরণস্বরূপ, এটি ওয়েব অ্যানিমেশন API ব্যবহার করে শুরু করা গতিকে থামাতে পারে না), তাই আপনি ভাঙার লক্ষ্য করলে এটি নিষ্ক্রিয় করতে ভুলবেন না।

স্বীকৃতি

স্টিফেন ম্যাকগ্রুরের কাছে ব্যাপক চিৎকার-আউট যিনি Chrome-এ prefers-reduced-motion প্রয়োগ করেছেন এবং— রব ডডসনের সাথে-একসাথে এই নথিটি পর্যালোচনা করেছেন। আনস্প্ল্যাশে হান্না কাহেপের হিরো ছবি