পেইন্ট জটিলতা সরলীকরণ এবং পেইন্ট এলাকা হ্রাস

পেইন্ট হল পিক্সেল পূরণ করার প্রক্রিয়া যা অবশেষে ব্যবহারকারীদের স্ক্রিনে সংমিশ্রিত হয়। এটি প্রায়শই পাইপলাইনের সমস্ত কাজগুলির মধ্যে সবচেয়ে দীর্ঘস্থায়ী হয় এবং সম্ভব হলে এড়ানো যায়৷

পেইন্ট হল পিক্সেল পূরণ করার প্রক্রিয়া যা অবশেষে ব্যবহারকারীদের স্ক্রিনে সংমিশ্রিত হয়। এটি প্রায়শই পাইপলাইনের সমস্ত কাজগুলির মধ্যে সবচেয়ে দীর্ঘস্থায়ী হয় এবং সম্ভব হলে এড়ানো যায়৷

সারসংক্ষেপ

  • রূপান্তর বা অস্বচ্ছতা ব্যতীত যে কোনও সম্পত্তি পরিবর্তন করা সর্বদা পেইন্টকে ট্রিগার করে।
  • পেইন্ট প্রায়ই পিক্সেল পাইপলাইনের সবচেয়ে ব্যয়বহুল অংশ; আপনি যেখানে পারেন এটা এড়িয়ে চলুন.
  • অ্যানিমেশনের স্তর প্রচার এবং অর্কেস্ট্রেশনের মাধ্যমে পেইন্ট এলাকা হ্রাস করুন।
  • পেইন্ট জটিলতা এবং খরচ মূল্যায়ন করতে Chrome DevTools পেইন্ট প্রোফাইলার ব্যবহার করুন; আপনি যেখানে পারেন কমিয়ে দিন।

ট্রিগারিং লেআউট এবং পেইন্ট

আপনি যদি লেআউট ট্রিগার করেন, তাহলে আপনি সবসময় পেইন্টকে ট্রিগার করবেন, যেহেতু যেকোনো উপাদানের জ্যামিতি পরিবর্তন করার মানে হল এর পিক্সেলগুলি ঠিক করা দরকার!

সম্পূর্ণ পিক্সেল পাইপলাইন।

আপনি যদি অ-জ্যামিতিক বৈশিষ্ট্য পরিবর্তন করেন, যেমন ব্যাকগ্রাউন্ড, টেক্সট রঙ বা ছায়া। এই ক্ষেত্রে লেআউট প্রয়োজন হবে না এবং পাইপলাইন এই মত দেখাবে:

লেআউট ছাড়া পিক্সেল পাইপলাইন।

পেইন্টের বাধা দ্রুত শনাক্ত করতে Chrome DevTools ব্যবহার করুন

আপনি ক্রোম DevTools ব্যবহার করতে পারেন যে এলাকাগুলি আঁকা হচ্ছে তা দ্রুত শনাক্ত করতে। রেন্ডারিং ট্যাব খুলুন এবং তারপর পেইন্ট ফ্ল্যাশিং সক্ষম করুন।

যখনই পেইন্টিং ঘটবে তখন এই বিকল্পটি ক্রোম চালু করলে স্ক্রীন সবুজ হয়ে যাবে। আপনি যদি পুরো স্ক্রীন ফ্ল্যাশ সবুজ দেখতে পান, বা স্ক্রিনের এমন জায়গাগুলি যেগুলি আঁকা উচিত বলে মনে করেননি, তাহলে আপনাকে আরও একটু খনন করা উচিত।

পেইন্টিং ঘটলে পৃষ্ঠা সবুজ ঝলকানি.

সরানো বা বিবর্ণ উপাদান প্রচার করুন

পেন্টিং সবসময় স্মৃতিতে একটি একক ছবিতে করা হয় না। প্রকৃতপক্ষে, প্রয়োজনে ব্রাউজারের পক্ষে একাধিক চিত্র বা কম্পোজিটর স্তরে আঁকা সম্ভব।

কম্পোজিটর স্তরগুলির একটি উপস্থাপনা৷

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

একটি নতুন স্তর তৈরি করার সর্বোত্তম উপায় হল will-change সিএসএস প্রপার্টি ব্যবহার করা। এটি ক্রোম, অপেরা এবং ফায়ারফক্সে কাজ করবে এবং transform মান সহ একটি নতুন কম্পোজিটর স্তর তৈরি করবে:

.moving-element {
  will-change: transform;
}

যে ব্রাউজারগুলি will-change সমর্থন করে না, কিন্তু স্তর তৈরি থেকে উপকৃত হয়, যেমন Safari এবং Mobile Safari, একটি নতুন স্তর জোর করতে আপনাকে (ভুল) একটি 3D রূপান্তর ব্যবহার করতে হবে:

.moving-element {
  transform: translateZ(0);
}

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

আপনি যদি একটি উপাদানকে একটি নতুন স্তরে উন্নীত করে থাকেন, তাহলে তা নিশ্চিত করতে DevTools ব্যবহার করুন যে এটি করার ফলে আপনি একটি পারফরম্যান্স সুবিধা পেয়েছেন। প্রোফাইলিং ছাড়া উপাদান প্রচার করবেন না.

পেইন্ট এলাকা হ্রাস

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

পেইন্ট ক্ষেত্রগুলি হ্রাস করা প্রায়শই আপনার অ্যানিমেশন এবং ট্রানজিশনগুলিকে বেশি ওভারল্যাপ না করার জন্য বা পৃষ্ঠার নির্দিষ্ট অংশগুলিকে অ্যানিমেট করা এড়াতে উপায় খুঁজে বের করার একটি ক্ষেত্রে।

পেইন্ট জটিলতা সরলীকরণ

স্ক্রিনের অংশ আঁকার জন্য সময় লাগে।

যখন এটি পেইন্টিং আসে, কিছু জিনিস অন্যদের চেয়ে বেশি ব্যয়বহুল। উদাহরণ স্বরূপ, যেকোন কিছুতে ঝাপসা থাকে (উদাহরণস্বরূপ, ছায়ার মত) একটি লাল বাক্স আঁকার চেয়ে - বলুন - রং করতে বেশি সময় লাগবে। CSS এর পরিপ্রেক্ষিতে, তবে, এটি সর্বদা স্পষ্ট নয়: background: red; এবং box-shadow: 0, 4px, 4px, rgba(0,0,0,0.5); অগত্যা তাদের ব্যাপকভাবে ভিন্ন কর্মক্ষমতা বৈশিষ্ট্য আছে মত চেহারা না, কিন্তু তারা আছে.

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

যেখানে আপনি সবসময় অ্যানিমেশনের সময় পেইন্ট এড়াতে চান বিশেষ করে, কারণ আপনার প্রতি ফ্রেমের 10ms সাধারণত পেইন্টের কাজ সম্পন্ন করার জন্য যথেষ্ট দীর্ঘ নয়, বিশেষ করে মোবাইল ডিভাইসে।