ক্যানভাস টোন ম্যাপিং মোডের সাথে HDR সমর্থন
HDR কন্টেন্ট প্রদর্শনের জন্য ওয়েব ডেভেলপারদের কাছে সীমিত বিকল্প রয়েছে, যা মূলত <img> এবং <video> এলিমেন্টের উপর নির্ভরশীল। তবে, <canvas> এলিমেন্টটি SDR-এর মধ্যেই সীমাবদ্ধ থাকে। একটি ক্যানভাসের মধ্যে ডাইনামিক HDR কন্টেন্ট তৈরি করতে হলে, তা প্রদর্শনের আগে ক্যানভাসের বিষয়বস্তুকে একটি HDR ইমেজ হিসেবে এনকোড করতে হয় (উদাহরণস্বরূপ এই ডেমোটি দেখুন)।
WebGPU ক্যানভাস কনফিগারেশনের নতুন GPUCanvasToneMappingMode প্যারামিটারটি এখন WebGPU-কে সাদার ( #FFFFFF ) চেয়ে উজ্জ্বল রং আঁকতে দেয়। এটি নিম্নলিখিত মোডগুলির মাধ্যমে তা করে থাকে:
"standard": ডিফল্ট আচরণ স্ক্রিনের SDR রেঞ্জের মধ্যে কন্টেন্টকে সীমাবদ্ধ রাখে। এই মোডটি স্ক্রিনের কালার স্পেসের সমস্ত রঙের মানকে[0, 1]ব্যবধিতে ক্ল্যাম্প করার মাধ্যমে সম্পন্ন করা হয়।"extended": স্ক্রিনের সম্পূর্ণ HDR রেঞ্জ আনলক করে। এই মোডটি স্ক্রিনের[0, 1]রেঞ্জে"standard"মোডের অনুরূপ। ক্ল্যাম্পিং বা প্রজেকশন স্ক্রিনের এক্সটেন্ডেড ডাইনামিক রেঞ্জে করা হয়, কিন্তু[0, 1]রেঞ্জে নয়।
নিম্নলিখিত কোড স্নিপেটটি আপনাকে হাই ডাইনামিক রেঞ্জের জন্য একটি ক্যানভাস কনফিগার করার পদ্ধতি দেখাবে।
const adapter = await navigator.gpu.requestAdapter();
const device = await adapter.requestDevice();
const canvas = document.querySelector("canvas");
const context = canvas.getContext("webgpu");
context.configure({
device,
format: "rgba16float",
toneMapping: { mode: "extended" },
});
Particles (HDR) স্যাম্পল এবং WebGPU HDR উদাহরণটি দেখে WebGPU-এর সাহায্যে HDR সম্পর্কে জানুন, এবং chromestatus এন্ট্রিটি দেখুন।

সম্প্রসারিত উপগোষ্ঠী সমর্থন
সাবগ্রুপ পরীক্ষা-নিরীক্ষার ঘোষণার পর, সাবগ্রুপ বিল্ট-ইন ফাংশনগুলো এখন কম্পিউট শেডার এবং ফ্র্যাগমেন্ট শেডার উভয় ক্ষেত্রেই ব্যবহারের জন্য উপলব্ধ। এগুলো এখন আর শুধু কম্পিউট শেডারের মধ্যে সীমাবদ্ধ নয়। ইস্যু 354738715 দেখুন।
উল্লেখ্য যে, ফ্র্যাগমেন্ট শেডারগুলিতে subgroup_size বিল্ট-ইন ভ্যালুটি বর্তমানে ত্রুটিপূর্ণ । আপাতত এটি ব্যবহার করা থেকে বিরত থাকুন।
এছাড়াও, নিম্নলিখিত সাবগ্রুপ বিল্ট-ইন ফাংশনগুলো যোগ করা হয়েছে:
-
subgroupAdd(value): সাবগ্রুপ জুড়ে থাকা সমস্ত সক্রিয়valueইনভোকেশনের যোগফল ফেরত দেয়। -
subgroupExclusiveAdd(value): সাবগ্রুপ জুড়ে সমস্ত সক্রিয়valueইনভোকেশনের এক্সক্লুসিভ স্ক্যান সামেশন রিটার্ন করে। -
subgroupMul(value): সাবগ্রুপ জুড়ে থাকা সমস্ত সক্রিয়valueএর গুণফল ফেরত দেয়। -
subgroupExclusiveMul(value): সাবগ্রুপ জুড়ে সমস্ত সক্রিয় ইনভোকেশনেরvalueগুলির এক্সক্লুসিভ স্ক্যান গুণফল ফেরত দেয়। -
subgroupAnd(value): সাবগ্রুপ জুড়ে থাকা সমস্ত সক্রিয়valueইনভোকেশনের বাইনারি AND ফলাফল ফেরত দেয়। -
subgroupOr(value): সাবগ্রুপ জুড়ে থাকা সমস্ত সক্রিয়valueএর বাইনারি OR রিটার্ন করে। -
subgroupXor(value): সাবগ্রুপ জুড়ে থাকা সমস্ত সক্রিয় ইনভোকেশনেরvalueগুলোর বাইনারি XOR ফলাফল ফেরত দেয়। -
subgroupMin(value): সাবগ্রুপ জুড়ে সমস্ত সক্রিয়valueইনভোকেশনের সর্বনিম্ন মান রিটার্ন করে। -
subgroupMax(value): সাবগ্রুপ জুড়ে সমস্ত সক্রিয়valueসর্বোচ্চ মান ফেরত দেয়। -
subgroupAll(value): সাবগ্রুপের সমস্ত সক্রিয় ইনভোকেশনের জন্যvalueসত্য হলে true রিটার্ন করে। -
subgroupAny(value): সাবগ্রুপের যেকোনো সক্রিয় আহ্বানের জন্যvaluetrue হলে, এটি true রিটার্ন করে। -
subgroupElect(): সাবগ্রুপের সক্রিয় ইনভোকেশনগুলোর মধ্যে এই ইনভোকেশনটিরsubgroup_invocation_idসর্বনিম্ন হলে true রিটার্ন করে। -
subgroupBroadcastFirst(value): সাবগ্রুপের মধ্যে সর্বনিম্নsubgroup_invocation_idযুক্ত সক্রিয় ইনভোকেশন থেকে প্রাপ্তvalueঅন্য সকল সক্রিয় ইনভোকেশনে সম্প্রচার করে। -
subgroupShuffle(value, id): সক্রিয় আহ্বান থেকেvalueফেরত দেয়, যারsubgroup_invocation_ididসাথে মেলে। -
subgroupShuffleXor(value, mask): সক্রিয় ইনভোকেশন থেকেvalueরিটার্ন করে, যারsubgroup_invocation_idsubgroup_invocation_id ^ maskসাথে মেলে।maskঅবশ্যই ডাইনামিকভাবে ইউনিফর্ম হতে হবে। -
subgroupShuffleUp(value, delta): সেই সক্রিয় ইনভোকেশন থেকেvalueফেরত দেয় যারsubgroup_invocation_idsubgroup_invocation_id - deltaসাথে মেলে। -
subgroupShuffleDown(value, delta): সক্রিয় ইনভোকেশন থেকেvalueফেরত দেয়, যারsubgroup_invocation_idsubgroup_invocation_id + deltaসাথে মেলে। -
quadBroadcast(value, id): যে quad আহ্বানের id-এরvalueid, সেখান থেকে value-কে সম্প্রচার করে।idঅবশ্যই একটি ধ্রুবক-এক্সপ্রেশন হতে হবে। -
quadSwapX(value): কোয়াডের মধ্যে X দিকেvalueঅদলবদল করে। -
quadSwapY(value): কোয়াডের মধ্যে Y দিকেvalueঅদলবদল করে। -
quadSwapDiagonal(value): কোয়াডের মধ্যে তির্যকভাবেvalueঅদলবদল করে।
ভোরের আপডেট
wgpu::PrimitiveState স্ট্রাকচারটিতে এখন সরাসরি ডেপথ ক্লিপ কন্ট্রোল সেটিং অন্তর্ভুক্ত করা হয়েছে, ফলে আলাদা wgpu::PrimitiveDepthClipControl স্ট্রাকচারের প্রয়োজন নেই। আরও জানতে, নিম্নলিখিত কোড স্নিপেট এবং webgpu-headers PR-টি দেখুন।
// Before
wgpu::PrimitiveState primitive = {};
wgpu::PrimitiveDepthClipControl depthClipControl;
depthClipControl.unclippedDepth = true;
primitive.nextInChain = &depthClipControl;
// Now
wgpu::PrimitiveState primitive = {};
primitive.unclippedDepth = true;
এখানে কেবল কয়েকটি মূল বিষয় তুলে ধরা হয়েছে। কমিটগুলোর বিস্তারিত তালিকাটি দেখুন।
WebGPU-তে নতুন কী আছে
'What's New in WebGPU' সিরিজে যা যা আলোচনা করা হয়েছে, তার একটি তালিকা।
ক্রোম ১৪৭-১৪৮
ক্রোম ১৪৬
- OpenGL ES 3.1-এ WebGPU সামঞ্জস্যপূর্ণ মোড সমর্থন করে
- ক্ষণস্থায়ী সংযুক্তি
- WGSL টেক্সচার_এবং_স্যাম্পলার_লেট এক্সটেনশন
- ভোরের আপডেট
ক্রোম ১৪৫
- WGSL উপগোষ্ঠী_একরূপতা সম্প্রসারণ
- ওয়ার্কারদের মধ্যে পরীক্ষামূলক সিঙ্ক্রোনাস বাফার ম্যাপিং
- ভোরের আপডেট
ক্রোম ১৪৪
- WGSL উপগোষ্ঠী_আইডি এক্সটেনশন
- WGSL uniform_buffer_standard_layout এক্সটেনশন
- লিনাক্সে ওয়েবজিপিইউ
- দ্রুততর writeBuffer এবং writeTexture
- ভোরের আপডেট
ক্রোম ১৪৩
ক্রোম ১৪২
ক্রোম ১৪১
- টিন্ট আইআর সম্পন্ন হয়েছে
- WGSL কম্পাইলারে পূর্ণসংখ্যার পরিসর বিশ্লেষণ
- ভুলকান ব্যাকএন্ডের জন্য SPIR-V 1.4 আপডেট
- ভোরের আপডেট
ক্রোম ১৪০
- ডিভাইস অ্যাডাপ্টার ব্যবহারের অনুরোধ করে।
- যেখানে টেক্সচার ভিউ ব্যবহৃত হয়, সেখানে টেক্সচার ব্যবহারের সংক্ষিপ্ত রূপ।
- WGSL textureSampleLevel 1D টেক্সচার সমর্থন করে
- bgra8unorm রিড-অনলি স্টোরেজ টেক্সচারের ব্যবহার অপ্রচলিত করুন
- GPUAdapter isFallbackAdapter অ্যাট্রিবিউটটি সরান
- ভোরের আপডেট
ক্রোম ১৩৯
- BC এবং ASTC কম্প্রেসড ফরম্যাটের জন্য 3D টেক্সচার সাপোর্ট
- নতুন 'কোর-ফিচার-অ্যান্ড-লিমিটস' ফিচার
- WebGPU সামঞ্জস্য মোডের জন্য Origin ট্রায়াল
- ভোরের আপডেট
ক্রোম ১৩৮
- বাইন্ডিং রিসোর্স হিসেবে বাফার ব্যবহারের সংক্ষিপ্ত রূপ
- তৈরির সময় ম্যাপ করা বাফারগুলির আকারের প্রয়োজনীয়তা পরিবর্তিত হয়।
- সাম্প্রতিক জিপিইউগুলির জন্য স্থাপত্য প্রতিবেদন
- GPUAdapter isFallbackAdapter অ্যাট্রিবিউটটি অপ্রচলিত করুন
- ভোরের আপডেট
ক্রোম ১৩৭
- এক্সটার্নাল টেক্সচার বাইন্ডিং এর জন্য টেক্সচার ভিউ ব্যবহার করুন
- অফসেট এবং আকার নির্দিষ্ট না করে বাফার কপি করা হয়
- WGSL workgroupUniformLoad অ্যাটমিকের পয়েন্টার ব্যবহার করে
- GPUAdapterInfo powerPreference অ্যাট্রিবিউট
- GPURequestAdapterOptions-এর compatibilityMode অ্যাট্রিবিউটটি মুছে ফেলুন
- ভোরের আপডেট
ক্রোম ১৩৬
- GPUAdapterInfo isFallbackAdapter অ্যাট্রিবিউট
- D3D12-এ শেডার কম্পাইলেশন সময়ের উন্নতি
- ক্যানভাসের ছবিগুলো সংরক্ষণ ও কপি করুন
- লিফট সামঞ্জস্য মোড সীমাবদ্ধতা
- ভোরের আপডেট
ক্রোম ১৩৫
- নাল বাইন্ড গ্রুপ লেআউট সহ পাইপলাইন লেআউট তৈরির অনুমতি দিন
- ভিউপোর্টগুলিকে রেন্ডার টার্গেটের সীমানা ছাড়িয়ে প্রসারিত করার অনুমতি দিন
- অ্যান্ড্রয়েডে পরীক্ষামূলক সামঞ্জস্য মোডে আরও সহজে প্রবেশ করা যায়
- maxInterStageShaderComponents সীমা অপসারণ করুন
- ভোরের আপডেট
ক্রোম ১৩৪
- সাবগ্রুপের মাধ্যমে মেশিন-লার্নিং ওয়ার্কলোড উন্নত করুন
- ফ্লোট ফিল্টারযোগ্য টেক্সচার প্রকারের সমর্থন ব্লেন্ডেবল হিসেবে অপসারণ করুন
- ভোরের আপডেট
ক্রোম ১৩৩
- অতিরিক্ত unorm8x4-bgra এবং 1-কম্পোনেন্ট ভার্টেক্স ফরম্যাট
- অনির্ধারিত মান দিয়ে অজানা সীমা অনুরোধ করার অনুমতি দিন।
- WGSL অ্যালাইনমেন্ট নিয়মের পরিবর্তন
- বর্জনের মাধ্যমে WGSL-এর কর্মক্ষমতা বৃদ্ধি
- বাহ্যিক টেক্সচারের জন্য VideoFrame displaySize ব্যবহার করুন
- `copyExternalImageToTexture` ব্যবহার করে ডিফল্ট ওরিয়েন্টেশন ছাড়া অন্য ওরিয়েন্টেশনের ছবি পরিচালনা করুন।
- ডেভেলপারদের অভিজ্ঞতা উন্নত করা
- featureLevel-এর সাথে সামঞ্জস্য মোড সক্রিয় করুন
- পরীক্ষামূলক উপগোষ্ঠীর বৈশিষ্ট্য পরিষ্করণ
- maxInterStageShaderComponents সীমা বাতিল করুন
- ভোরের আপডেট
ক্রোম ১৩২
- টেক্সচার ভিউ ব্যবহার
- ৩২-বিট ফ্লোট টেক্সচার ব্লেন্ডিং
- GPUDevice অ্যাডাপ্টারইনফো অ্যাট্রিবিউট
- ভুল ফরম্যাটে ক্যানভাস কনটেক্সট কনফিগার করলে জাভাস্ক্রিপ্ট ত্রুটি দেখা দেয়।
- টেক্সচারের উপর ফিল্টারিং স্যাম্পলারের সীমাবদ্ধতা
- বর্ধিত উপগোষ্ঠী পরীক্ষা
- ডেভেলপারদের অভিজ্ঞতা উন্নত করা
- ১৬-বিট নর্মালাইজড টেক্সচার ফরম্যাটের জন্য পরীক্ষামূলক সমর্থন
- ভোরের আপডেট
ক্রোম ১৩১
- WGSL-এ ক্লিপ দূরত্ব
- GPUCanvasContext getConfiguration()
- বিন্দু এবং রেখা প্রিমিটিভগুলিতে গভীরতার পক্ষপাত থাকা উচিত নয়।
- উপগোষ্ঠীগুলির জন্য অন্তর্ভুক্তিমূলক স্ক্যান অন্তর্নির্মিত ফাংশন
- মাল্টি-ড্র ইনডিরেক্টের জন্য পরীক্ষামূলক সমর্থন
- শেডার মডিউল সংকলন বিকল্প কঠোর গণিত
- GPUAdapter requestAdapterInfo() অপসারণ করুন
- ভোরের আপডেট
ক্রোম ১৩০
- দ্বৈত উৎস মিশ্রণ
- মেটালে শেডার কম্পাইলেশন সময়ের উন্নতি
- GPUAdapter requestAdapterInfo() এর অপ্রচলিতকরণ
- ভোরের আপডেট
ক্রোম ১২৯
ক্রোম ১২৮
- উপগোষ্ঠী নিয়ে পরীক্ষা-নিরীক্ষা
- লাইন এবং পয়েন্টের জন্য ডেপথ বায়াস সেট করা অপ্রচলিত।
- preventDefault ব্যবহার করলে ক্যাপচার না করা ত্রুটির DevTools সতর্কতা লুকান
- WGSL প্রথমে ইন্টারপোলেট স্যাম্পলিং করে এবং হয়
- ভোরের আপডেট
ক্রোম ১২৭
- অ্যান্ড্রয়েডে OpenGL ES-এর জন্য পরীক্ষামূলক সমর্থন
- GPUAdapter তথ্য অ্যাট্রিবিউট
- ওয়েবঅ্যাসেম্বলি ইন্টারঅপ উন্নতি
- উন্নত কমান্ড এনকোডার ত্রুটি
- ভোরের আপডেট
ক্রোম ১২৬
- maxTextureArrayLayers সীমা বৃদ্ধি করুন
- ভলকান ব্যাকএন্ডের জন্য বাফার আপলোড অপ্টিমাইজেশন
- শেডার কম্পাইলেশন সময়ের উন্নতি
- জমা দেওয়া কমান্ড বাফারগুলি অবশ্যই অনন্য হতে হবে।
- ভোরের আপডেট
ক্রোম ১২৫
ক্রোম ১২৪
- পঠন-যোগ্য এবং পঠন-লিখনযোগ্য স্টোরেজ টেক্সচার
- পরিষেবা কর্মী এবং ভাগাভাগি কর্মীদের সমর্থন
- নতুন অ্যাডাপ্টার তথ্যের বৈশিষ্ট্য
- বাগ সংশোধন
- ভোরের আপডেট
ক্রোম ১২৩
- WGSL-এ DP4a-এর অন্তর্নির্মিত ফাংশনগুলির সমর্থন
- WGSL-এ অবাধ পয়েন্টার প্যারামিটার
- WGSL-এ কম্পোজিট ডি-রেফারেন্সিং-এর জন্য সিনট্যাক্স সুগার
- স্টেনসিল এবং গভীরতার দিকগুলির জন্য পৃথক পঠনযোগ্য অবস্থা
- ভোরের আপডেট
ক্রোম ১২২
- কম্প্যাটিবিলিটি মোডের মাধ্যমে পরিধি প্রসারিত করুন (ফিচারটি নির্মাণাধীন)
- maxVertexAttributes সীমা বৃদ্ধি করুন
- ভোরের আপডেট
ক্রোম ১২১
- অ্যান্ড্রয়েডে ওয়েবজিপিইউ সমর্থন করুন
- উইন্ডোজে শেডার কম্পাইলেশনের জন্য FXC-এর পরিবর্তে DXC ব্যবহার করুন।
- কম্পিউট এবং রেন্ডার পাসে টাইমস্ট্যাম্প কোয়েরি
- শেডার মডিউলগুলির ডিফল্ট এন্ট্রি পয়েন্ট
- GPUExternalTexture কালার স্পেস হিসেবে display-p3 সমর্থন করে।
- মেমরি হিপস তথ্য
- ভোরের আপডেট
ক্রোম ১২০
- WGSL-এ ১৬-বিট ফ্লোটিং-পয়েন্ট মানের জন্য সমর্থন
- সীমা ছাড়িয়ে যান
- গভীরতা-স্টেনসিল অবস্থার পরিবর্তন
- অ্যাডাপ্টার তথ্যের আপডেট
- টাইমস্ট্যাম্প কোয়েরি কোয়ান্টাইজেশন
- বসন্তকালীন পরিষ্কার-পরিচ্ছন্নতার বৈশিষ্ট্য
ক্রোম ১১৯
- ফিল্টারযোগ্য ৩২-বিট ফ্লোট টেক্সচার
- অগঠিত১০-১০-১০-২ শীর্ষবিন্দু বিন্যাস
- rgb10a2uint টেক্সচার ফরম্যাট
- ভোরের আপডেট
ক্রোম ১১৮
-
copyExternalImageToTexture()ফাংশনে HTMLImageElement এবং ImageData-এর সাপোর্ট - রিড-রাইট এবং রিড-অনলি স্টোরেজ টেক্সচারের জন্য পরীক্ষামূলক সমর্থন
- ভোরের আপডেট
ক্রোম ১১৭
- আনসেট ভার্টেক্স বাফার
- আনসেট বাইন্ড গ্রুপ
- ডিভাইস হারিয়ে গেলে অ্যাসিঙ্ক পাইপলাইন তৈরির ত্রুটিগুলো নীরব করুন
- SPIR-V শেডার মডিউল তৈরির আপডেট
- ডেভেলপারদের অভিজ্ঞতা উন্নত করা
- স্বয়ংক্রিয়ভাবে তৈরি লেআউট সহ ক্যাশিং পাইপলাইন
- ভোরের আপডেট
ক্রোম ১১৬
- ওয়েবকোডেকস ইন্টিগ্রেশন
- GPUAdapter
requestDevice()দ্বারা ফেরত দেওয়া হারানো ডিভাইস -
importExternalTexture()কল করা হলে ভিডিও প্লেব্যাক মসৃণ রাখুন - স্পেক সঙ্গতি
- ডেভেলপারদের অভিজ্ঞতা উন্নত করা
- ভোরের আপডেট
ক্রোম ১১৫
- সমর্থিত WGSL ভাষা এক্সটেনশন
- Direct3D 11 এর জন্য পরীক্ষামূলক সমর্থন
- এসি পাওয়ারে ডিফল্টভাবে ডেডিকেটেড জিপিইউ পাওয়া যায়।
- ডেভেলপারদের অভিজ্ঞতা উন্নত করা
- ভোরের আপডেট
ক্রোম ১১৪
- জাভাস্ক্রিপ্ট অপ্টিমাইজ করুন
- অকনফিগার করা ক্যানভাসে getCurrentTexture() কল করলে InvalidStateError থ্রো করে।
- WGSL আপডেট
- ভোরের আপডেট