कैनवस टोन मैपिंग मोड के साथ एचडीआर की सुविधा
वेब डेवलपर के पास एचडीआर कॉन्टेंट डिलीवर करने के सीमित विकल्प होते हैं. वे मुख्य तौर पर <img>
और <video>
एलिमेंट पर निर्भर होते हैं. हालांकि, <canvas>
एलिमेंट सिर्फ़ एसडीआर के लिए उपलब्ध है. कैनवस में डाइनैमिक एचडीआर कॉन्टेंट जनरेट करने के लिए, उसे दिखाने से पहले उसके कॉन्टेंट को एचडीआर इमेज के तौर पर एन्कोड करना ज़रूरी है. उदाहरण के लिए, यह डेमो देखें.
WebGPU कैनवस कॉन्फ़िगरेशन में मौजूद नए GPUCanvasToneMappingMode
पैरामीटर की मदद से, WebGPU अब सफ़ेद (#FFFFFF
) से ज़्यादा चमकदार रंगों को ड्रॉ कर सकता है. यह इन मोड की मदद से ऐसा करता है:
"standard"
: डिफ़ॉल्ट रूप से, कॉन्टेंट को स्क्रीन की एसडीआर रेंज तक ही सीमित रखा जाता है. यह मोड, स्क्रीन के कलर स्पेस में मौजूद सभी कलर वैल्यू को[0, 1]
इंटरवल पर क्लैंप करके पूरा किया जाता है."extended"
: स्क्रीन की पूरी एचडीआर रेंज को अनलॉक करता है. यह मोड, स्क्रीन की[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" },
});
पार्टिकल (एचडीआर) सैंपल और WebGPU एचडीआर का उदाहरण देखकर, WebGPU की मदद से एचडीआर की सुविधा को एक्सप्लोर करें. साथ ही, chromestatus एंट्री देखें.
सबग्रुप के लिए ज़्यादा सहायता
सबग्रुप एक्सपेरिमेंट के एलान के बाद, सबग्रुप के बिल्ट-इन फ़ंक्शन अब कंप्यूट शेडर और फ़्रैगमेंट शेडर, दोनों में इस्तेमाल के लिए उपलब्ध हैं. अब ये सिर्फ़ कंप्यूट शेडर तक सीमित नहीं हैं. समस्या 354738715 देखें.
ध्यान दें कि फ़्रेगमेंट शेडर में, subgroup_size
की पहले से मौजूद वैल्यू फ़िलहाल काम नहीं करती. फ़िलहाल, ऐसा न करें.
इसके अलावा, सबग्रुप के लिए ये पहले से मौजूद फ़ंक्शन जोड़े गए हैं:
subgroupAdd(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
का कुल योग दिखाता है.subgroupExclusiveAdd(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
के स्कैन की खास जानकारी दिखाता है.subgroupMul(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
के मल्टीप्लाकेशन को दिखाता है.subgroupExclusiveMul(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
के एक्सक्लूज़िव स्कैन मल्टीप्लािकेशन दिखाता है.subgroupAnd(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
s का बाइनरी AND दिखाता है.subgroupOr(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
s का बाइनरी OR दिखाता है.subgroupXor(value)
: यह सबग्रुप में मौजूद सभी चालू इनवोकेशनvalue
s का बाइनरी XOR दिखाता है.subgroupMin(value)
: सबग्रुप में सभी चालू इनवोकेशनvalue
की सबसे कम वैल्यू दिखाता है.subgroupMax(value)
: यह सबग्रुप में सभी चालू इनवोकेशनvalue
की सबसे बड़ी वैल्यू दिखाता है.subgroupAll(value)
: अगर सबग्रुप में सभी चालू इनवोकेशन के लिएvalue
सही है, तो यह फ़ंक्शन 'सही' दिखाता है.subgroupAny(value)
: अगर सबग्रुप में किसी भी ऐक्टिव इनवोकेशन के लिएvalue
सही है, तो यह फ़ंक्शन 'सही' दिखाता है.subgroupElect()
: अगर सबग्रुप में चल रहे इनवोकेशन में, इस इनवोकेशन काsubgroup_invocation_id
सबसे कम है, तो यह 'सही' दिखाता है.subgroupBroadcastFirst(value)
: सबग्रुप में सबसे कमsubgroup_invocation_id
वाले ऐक्टिव इनवोकेशन से,value
को सभी अन्य ऐक्टिव इनवोकेशन पर ब्रॉडकास्ट करता है.subgroupShuffle(value, id)
: उस ऐक्टिव इनवोकेशन सेvalue
दिखाता है जिसकाsubgroup_invocation_id
,id
से मेल खाता है.subgroupShuffleXor(value, mask)
: उस ऐक्टिव इनवोकेशन सेvalue
दिखाता है जिसकाsubgroup_invocation_id
,subgroup_invocation_id ^ mask
से मेल खाता है.mask
डाइनैमिक तौर पर एक जैसा होना चाहिए.subgroupShuffleUp(value, delta)
: उस ऐक्टिव इनवोकेशन सेvalue
दिखाता है जिसकाsubgroup_invocation_id
,subgroup_invocation_id - delta
से मेल खाता है.subgroupShuffleDown(value, delta)
: उस ऐक्टिव इनवोकेशन सेvalue
दिखाता है जिसकाsubgroup_invocation_id
,subgroup_invocation_id + delta
से मेल खाता है.quadBroadcast(value, id)
:id
वाले आईडी के साथ क्वॉड इनवोकेशन सेvalue
ब्रॉडकास्ट करता है.id
एक कॉन्स्टेंट-एक्सप्रेशन होना चाहिए.quadSwapX(value)
: X दिशा में क्वॉड में,value
को एक से दूसरे इनवोकेशन के बीच स्वैप करता है.quadSwapY(value)
: Y दिशा में क्वॉड में,value
को एक से दूसरे इनवोकेशन के बीच स्वैप करता है.quadSwapDiagonal(value)
: क्वाड में डायगनल तौर पर, एक कॉल से दूसरे कॉल के बीचvalue
को स्वैप करता है.
Dawn के बारे में अपडेट
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 में नया क्या है
WebGPU में नया क्या है सीरीज़ में शामिल सभी चीज़ों की सूची.
Chrome 132
- टेक्स्चर व्यू का इस्तेमाल
- 32-बिट फ़्लोट टेक्स्चर ब्लेंडिंग
- GPUDevice adapterInfo एट्रिब्यूट
- अमान्य फ़ॉर्मैट के साथ कैनवस कॉन्टेक्स्ट को कॉन्फ़िगर करने पर, JavaScript से जुड़ी गड़बड़ी का मैसेज मिलना
- टेक्स्चर पर सैंपलर की पाबंदियों को फ़िल्टर करना
- सबग्रुप के लिए एक्सपेरिमेंट की सुविधा को बेहतर बनाना
- डेवलपर के अनुभव को बेहतर बनाना
- 16-बिट नॉर्मलाइज़ किए गए टेक्सचर फ़ॉर्मैट के लिए, एक्सपेरिमेंट के तौर पर उपलब्ध सहायता
- Dawn से जुड़े अपडेट
Chrome 131
- WGSL में दूरियों को क्लिप करना
- GPUCanvasContext getConfiguration()
- पॉइंट और लाइन प्राइमिटिव में डीपथ बायस नहीं होना चाहिए
- सबग्रुप के लिए, सभी को ध्यान में रखकर स्कैन करने की सुविधा के साथ पहले से मौजूद फ़ंक्शन
- मल्टी-ड्रॉ इनडायरेक्ट के लिए एक्सपेरिमेंटल सपोर्ट
- शेडर मॉड्यूल कंपाइल करने का विकल्प, सख्त गणित
- GPUAdapter requestAdapterInfo() को हटाना
- Dawn से जुड़े अपडेट
Chrome 130
- दो सोर्स को ब्लेंड करना
- Metal पर शेडर को कंपाइल करने में लगने वाले समय में सुधार
- GPUAdapter requestAdapterInfo() का इस्तेमाल बंद करना
- Dawn से जुड़े अपडेट
Chrome 129
Chrome 128
- सबग्रुप के साथ एक्सपेरिमेंट करना
- रेखाओं और बिंदुओं के लिए, डेप्थ बायस की सेटिंग को बंद करना
- preventDefault का इस्तेमाल करने पर, DevTools में गड़बड़ी की चेतावनी न दिखाएं
- WGSL, सैंपलिंग को पहले इंटरपोल करता है और फिर
- Dawn से जुड़े अपडेट
Chrome 127
- Android पर OpenGL ES के लिए एक्सपेरिमेंटल सपोर्ट
- GPUAdapter info एट्रिब्यूट
- WebAssembly के इंटरऑपरेबिलिटी में सुधार
- कमांड एन्कोडर से जुड़ी गड़बड़ियों को बेहतर बनाया गया
- Dawn से जुड़े अपडेट
Chrome 126
- maxTextureArrayLayers की सीमा बढ़ाना
- Vulkan बैकएंड के लिए, बफ़र अपलोड को ऑप्टिमाइज़ करना
- शेडर को कंपाइल करने में लगने वाले समय में सुधार
- सबमिट की गई कमांड बफ़र यूनीक होनी चाहिए
- Dawn से जुड़े अपडेट
Chrome 125
Chrome 124
- सिर्फ़ पढ़ने के लिए और पढ़ने-लिखने के लिए स्टोरेज टेक्स्चर
- Service workers और शेयर किए गए workers के लिए सहायता
- अडैप्टर की जानकारी देने वाले नए एट्रिब्यूट
- गड़बड़ियां ठीक की गईं
- Dawn से जुड़े अपडेट
Chrome 123
- WGSL में DP4a के बिल्ट-इन फ़ंक्शन के साथ काम करने की सुविधा
- WGSL में बिना पाबंदी वाले पॉइंटर पैरामीटर
- WGSL में कॉम्पोज़िट को डीरेफ़रंस करने के लिए सिंटैक्स शुगर
- स्टेंसिल और डेप्थ के लिए, रीड-ओनली मोड की अलग-अलग स्थिति
- Dawn से जुड़े अपडेट
Chrome 122
- कंपैटबिलिटी मोड की मदद से रीच बढ़ाना (यह सुविधा डेवलप की जा रही है)
- maxVertexAttributes की सीमा बढ़ाना
- Dawn से जुड़े अपडेट
Chrome 121
- Android पर WebGPU की सुविधा
- Windows पर शेडर को कंपाइल करने के लिए, FXC के बजाय DXC का इस्तेमाल करना
- कंप्यूट और रेंडर पास में टाइमस्टैंप क्वेरी
- शेडर मॉड्यूल के लिए डिफ़ॉल्ट एंट्री पॉइंट
- GPUExternalTexture कलर स्पेस के तौर पर display-p3 का इस्तेमाल करना
- मेमोरी हेप की जानकारी
- Dawn से जुड़े अपडेट
Chrome 120
- WGSL में 16-बिट फ़्लोटिंग-पॉइंट वैल्यू के लिए सहायता
- सीमाओं को पार करना
- डेप्थ-स्टेंसिल स्टेटस में बदलाव
- अडैप्टर की जानकारी से जुड़े अपडेट
- टाइमस्टैंप क्वेरी को क्वांटाइज़ करना
- समय-समय पर साफ़-सफ़ाई करने की सुविधाएं
Chrome 119
- फ़िल्टर किए जा सकने वाले 32-बिट फ़्लोट टेक्सचर
- unorm10-10-10-2 वर्टिक्स फ़ॉर्मैट
- rgb10a2uint टेक्स्चर फ़ॉर्मैट
- Dawn से जुड़े अपडेट
Chrome 118
copyExternalImageToTexture()
में HTMLImageElement और ImageData की सुविधा- रीड-राइट और रीड-ओनली स्टोरेज टेक्स्चर के लिए, एक्सपेरिमेंट के तौर पर उपलब्ध सहायता
- Dawn से जुड़े अपडेट
Chrome 117
- वर्टिक्स बफ़र को अनसेट करना
- बाइंड किए गए ग्रुप को अनसेट करना
- डिवाइस खो जाने पर, असाइनमेंट के लिए असाइनमेंट पाइपलाइन बनाने से जुड़ी गड़बड़ियों को रोकना
- SPIR-V शेडर मॉड्यूल बनाने से जुड़े अपडेट
- डेवलपर के अनुभव को बेहतर बनाना
- अपने-आप जनरेट हुए लेआउट की मदद से, पाइपलाइन को कैश मेमोरी में सेव करना
- Dawn से जुड़े अपडेट
Chrome 116
- WebCodecs इंटिग्रेशन
- GPUAdapter
requestDevice()
से खोया हुआ डिवाइस वापस मिलना importExternalTexture()
को कॉल करने पर, वीडियो चलाने की सुविधा को बिना रुकावट के जारी रखना- स्पेसिफ़िकेशन के मुताबिक होना
- डेवलपर के अनुभव को बेहतर बनाना
- Dawn से जुड़े अपडेट
Chrome 115
- WGSL भाषा के इस्तेमाल किए जा सकने वाले एक्सटेंशन
- Direct3D 11 के लिए एक्सपेरिमेंटल सपोर्ट
- AC पावर पर डिफ़ॉल्ट रूप से डिसक्रेट जीपीयू पाना
- डेवलपर के अनुभव को बेहतर बनाना
- Dawn से जुड़े अपडेट
Chrome 114
- Optimize JavaScript
- बिना कॉन्फ़िगर किए गए कैनवस पर getCurrentTexture() से InvalidStateError मिलता है
- WGSL से जुड़े अपडेट
- Dawn से जुड़े अपडेट