ব্যাকড্রপ-ফিল্টার দিয়ে ওএস-স্টাইলের ব্যাকগ্রাউন্ড তৈরি করুন

একটি উপাদান পিছনে ঝাপসা এবং রং স্থানান্তর.

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

একটি হিমায়িত কাচ প্রভাব একটি উদাহরণ.
একটি হিমায়িত কাচ প্রভাব একটি উদাহরণ. উৎস

ঐতিহাসিকভাবে, এই কৌশলগুলি ওয়েবে প্রয়োগ করা কঠিন ছিল, যার জন্য নিখুঁত হ্যাক বা সমাধানের চেয়ে কম প্রয়োজন। সাম্প্রতিক বছরগুলিতে সাফারি এবং এজ উভয়ই background-filter (এবং বিকল্পভাবে, -webkit-backdrop-filter ) বৈশিষ্ট্যের মাধ্যমে এই ক্ষমতাগুলি প্রদান করেছে, যা ফিল্টার ফাংশনের উপর ভিত্তি করে অগ্রভাগ এবং পটভূমির রঙগুলিকে গতিশীলভাবে মিশ্রিত করে। এখন Chrome 76 সংস্করণ থেকে শুরু করে, background-filter সমর্থন করে৷

backdrop-filter জন্য ফিল্টার ফাংশনগুলির একটি প্রদর্শন। কোডপেনের উদাহরণটি চেষ্টা করুন।

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

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

  • ক্রোম: 76।
  • প্রান্ত: 79।
  • ফায়ারফক্স: 103।
  • সাফারি: 18।

উৎস

কর্মক্ষমতার কারণে, backdrop-filter সমর্থিত না হলে পলিফিলের পরিবর্তে একটি ছবিতে ফিরে যান। নীচের উদাহরণ এটি দেখায়.

@supports (backdrop-filter: none) {
    .background {
        backdrop-filter: blur(10px);
    }
}

@supports not (backdrop-filter: none) {
  .background {
    background-image: blurred-hero.png;
  }
}

বেসিক

  • backdrop-filter বৈশিষ্ট্য একটি উপাদানে এক বা একাধিক ফিল্টার প্রয়োগ করে, উপাদানটির পিছনে যে কোনও কিছুর চেহারা পরিবর্তন করে।
  • ওভারলেয়িং উপাদান অন্তত আংশিক স্বচ্ছ হতে হবে।
  • ওভারলেয়িং উপাদানটি একটি নতুন স্ট্যাকিং প্রসঙ্গ পাবে।

CSS backdrop-filter একটি উপাদানে এক বা একাধিক প্রভাব প্রয়োগ করে যা স্বচ্ছ বা স্বচ্ছ। এটি বুঝতে, নীচের চিত্রগুলি বিবেচনা করুন।

ফোরগ্রাউন্ড স্বচ্ছতা নেই
একটি বৃত্তের উপর চাপানো একটি ত্রিভুজ। ত্রিভুজ দিয়ে বৃত্ত দেখা যায় না।
.frosty-glass-pane {
  backdrop-filter: blur(2px);
}
ফোরগ্রাউন্ড স্বচ্ছতা
একটি বৃত্তের উপর চাপানো একটি ত্রিভুজ। ত্রিভুজটি স্বচ্ছ, এর মাধ্যমে বৃত্তটি দেখা যায়।
.frosty-glass-pane {
  opacity: .9;
  backdrop-filter: blur(2px);
}

backdrop-filter ব্যবহার বা সমর্থিত না হলে ওভারল্যাপিং উপাদানগুলি কীভাবে রেন্ডার করা হবে তা বাম দিকের চিত্রটি দেখায়। ডানদিকের ছবিটি backdrop-filter ব্যবহার করে একটি ঝাপসা প্রভাব প্রয়োগ করে। লক্ষ্য করুন যে এটি backdrop-filter ছাড়াও opacity ব্যবহার করে। opacity ছাড়া, অস্পষ্টতা প্রয়োগ করার কিছুই থাকবে না। এটি প্রায় বলার অপেক্ষা রাখে না যে যদি opacity 1 (সম্পূর্ণ অস্বচ্ছ) সেট করা হয় তবে পটভূমিতে কোন প্রভাব পড়বে না।

backdrop-filter প্রপার্টি হল সিএসএস ফিল্টারগুলির মতো যাতে আপনার সমস্ত প্রিয় ফিল্টার ফাংশন সমর্থিত: blur() , brightness() , contrast() , opacity() , drop-shadow() ইত্যাদি। এটি url() ফাংশনকেও সমর্থন করে যদি আপনি একটি বহিরাগত চিত্রকে ফিল্টার হিসাবে ব্যবহার করতে চান, সেইসাথে none , inherit , initial , এবং unset কীওয়ার্ডগুলি ব্যবহার করতে চান। MDN- এ এই সমস্ত কিছুর জন্য ব্যাখ্যা রয়েছে, যার মধ্যে সিনট্যাক্স, ফিল্টার এবং মানগুলির বর্ণনা রয়েছে৷

যখন backdrop-filter none ছাড়া অন্য কিছুতে সেট করা হয়, ব্রাউজারটি একটি নতুন স্ট্যাকিং প্রসঙ্গ তৈরি করে। একটি ধারণকারী ব্লকও তৈরি করা যেতে পারে, কিন্তু শুধুমাত্র যদি উপাদানটির পরম এবং স্থির অবস্থানের বংশধর থাকে।

আপনি সমৃদ্ধ এবং চতুর প্রভাবগুলির জন্য ফিল্টারগুলিকে একত্রিত করতে পারেন, বা আরও সূক্ষ্ম বা সুনির্দিষ্ট প্রভাবগুলির জন্য শুধুমাত্র একটি ফিল্টার ব্যবহার করতে পারেন৷ এমনকি আপনি এগুলিকে SVG ফিল্টারগুলির সাথে একত্রিত করতে পারেন৷

উদাহরণ

পূর্বে অপারেটিং সিস্টেমের জন্য সংরক্ষিত ডিজাইন কৌশল এবং শৈলীগুলি এখন একটি সিএসএস ঘোষণার মাধ্যমে কার্যকরী এবং অর্জনযোগ্য। আসুন কিছু উদাহরণ দেখি।

একক ফিল্টার

নিম্নলিখিত উদাহরণে, রঙ এবং ঝাপসা একত্রিত করে হিমায়িত প্রভাব অর্জন করা হয়। ব্লারটি backdrop-filter দ্বারা সরবরাহ করা হয়, যখন রঙটি উপাদানটির আধা-স্বচ্ছ পটভূমির রঙ থেকে আসে।

.blur-behind-me {
  background-color: rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(.5rem);
}
CodePen এ নিজের জন্য এই উদাহরণটি চেষ্টা করুন।

একাধিক ফিল্টার

কখনও কখনও আপনার পছন্দসই প্রভাব অর্জন করতে একাধিক ফিল্টার প্রয়োজন হবে। এটি করার জন্য, একটি স্থান দ্বারা পৃথক করা ফিল্টারগুলির একটি তালিকা প্রদান করুন৷ যেমন:

.brighten-saturate-and-blur-behind-me {
  backdrop-filter: brightness(150%) saturate(150%) blur(1rem);
}

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

CodePen এ নিজের জন্য এই উদাহরণটি চেষ্টা করুন।

ওভারলে

এই উদাহরণটি দেখায় কিভাবে একটি পৃষ্ঠার পটভূমির সাথে স্টাইলিস্টিকভাবে মিশ্রিত করার সময় পাঠ্য পাঠযোগ্য করতে একটি আধা-স্বচ্ছ পটভূমিকে অস্পষ্ট করা যায়।

.modal {
  backdrop-filter: blur(10px);
  background-color: rgba(255, 255, 255, 0.5);
}
নিজের জন্য এই উদাহরণ চেষ্টা করুন.

ডায়নামিক ব্যাকগ্রাউন্ডে টেক্সট কনট্রাস্ট

আগেই বলা হয়েছে, backdrop-filter পারফরম্যান্ট ইফেক্টের অনুমতি দেয় যা ওয়েবে কঠিন বা অসম্ভব। এর একটি উদাহরণ একটি অ্যানিমেশনের প্রতিক্রিয়ায় একটি পটভূমি পরিবর্তন করা। এই উদাহরণে, backdrop-filter পাঠ্যের পিছনে যা ঘটছে তা সত্ত্বেও পাঠ্য এবং এর পটভূমির মধ্যে উচ্চ বৈসাদৃশ্য বজায় রাখে। এটি ডিফল্ট ব্যাকগ্রাউন্ড কালার darkslategray দিয়ে শুরু হয় এবং ট্রান্সফর্মেশনের পর রংগুলিকে উল্টাতে backdrop-filter ব্যবহার করে।

.container::before {
  z-index: 1;
  background-color: darkslategray;
  filter: invert(1);
}

.container::after {
    backdrop-filter: invert(1);
  z-index: 3;
}
Codrops-চেন হুই জিং থেকে এই উদাহরণটি ব্যবহার করে দেখুন।

উপসংহার

গত কয়েক বছরে আপনার মধ্যে 560 জনেরও বেশি ক্রোমিয়াম বাগটিকে আপভোট করেছেন, স্পষ্টভাবে এটিকে একটি দীর্ঘ প্রতীক্ষিত CSS বৈশিষ্ট্য হিসাবে চিহ্নিত করে৷ ক্রোমের 76 সংস্করণে backdrop-filter প্রকাশ করা ওয়েবকে সত্যিকারের OS-এর মতো UI উপস্থাপনার এক ধাপ কাছাকাছি নিয়ে আসে৷

অতিরিক্ত সম্পদ