कैनवस टोन मैपिंग मोड के साथ एचडीआर की सुविधा
वेब डेवलपर के पास एचडीआर कॉन्टेंट डिलीवर करने के सीमित विकल्प होते हैं. वे मुख्य तौर पर <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
की बाइनरी OR दिखाता है.subgroupXor(value)
: यह सबग्रुप में इस्तेमाल किए जाने वाले सभी चालू बोले जाने वाले नामोंvalue
का बाइनरी XOR दिखाता है.subgroupMin(value)
: यह सबग्रुप में सभी चालू बोले जाने वाले निर्देशोंvalue
की सबसे कम वैल्यू दिखाता है.subgroupMax(value)
: यह सबग्रुप में सभी ऐक्टिव इंटरैक्शनvalue
s की सबसे बड़ी वैल्यू दिखाता है.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
को क्वाड में तिरछा करके बोले जाने वाले वाक्यों के बीच स्वैप करता है.
डॉन से जुड़े अपडेट
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 131
- WGSL में दूरियों को क्लिप करना
- GPUCanvasContext getConfiguration()
- पॉइंट और लाइन प्राइमिटिव में डीपथ बायस नहीं होना चाहिए
- सबग्रुप के लिए, सभी को ध्यान में रखकर स्कैन करने की सुविधा के साथ पहले से मौजूद फ़ंक्शन
- मल्टी-ड्रॉ इनडायरेक्ट के लिए एक्सपेरिमेंटल सपोर्ट
- शडर मॉड्यूल कंपाइलेशन विकल्प स्ट्रिक्ट मैथ
- GPUAdapter requestAdapterInfo() को हटाना
- Dawn से जुड़े अपडेट
Chrome 130
- दो सोर्स को ब्लेंड करना
- Metal पर शेडर को कंपाइल करने में लगने वाले समय में सुधार
- जीआरपी अडैप्टर 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
- रीड-ओनली और रीड-राइट स्टोरेज टेक्सचर
- सेवा वर्कर और शेयर किए गए वर्कर के लिए सहायता
- अडैप्टर की जानकारी देने वाले नए एट्रिब्यूट
- गड़बड़ियां ठीक की गईं
- 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 शेडर मॉड्यूल बनाने से जुड़े अपडेट
- डेवलपर के अनुभव को बेहतर बनाना
- अपने-आप जनरेट हुए लेआउट की मदद से, पाइपलाइन को कैश मेमोरी में सेव करना
- डॉन से जुड़े अपडेट
Chrome 116
- WebCodecs इंटिग्रेशन
- GPUAdapter
requestDevice()
से खोया हुआ डिवाइस वापस मिलना importExternalTexture()
को कॉल करने पर, वीडियो चलाने की सुविधा को बिना रुकावट के जारी रखना- खास जानकारी का पालन
- डेवलपर के अनुभव को बेहतर बनाना
- Dawn से जुड़े अपडेट
Chrome 115
- WGSL के साथ काम करने वाले लैंग्वेज एक्सटेंशन
- Direct3D 11 के लिए एक्सपेरिमेंटल सपोर्ट
- AC पावर पर डिफ़ॉल्ट रूप से डिसक्रेट जीपीयू पाना
- डेवलपर के अनुभव को बेहतर बनाना
- Dawn से जुड़े अपडेट
Chrome 114
- Optimize JavaScript
- बिना कॉन्फ़िगर किए गए कैनवस पर getCurrentTexture() से InvalidStateError मिलता है
- WGSL से जुड़े अपडेट
- Dawn से जुड़े अपडेट