Kanvas ton eşleme moduyla HDR desteği
Web geliştiriciler, HDR içerik sunmak için sınırlı seçeneklere sahiptir ve öncelikle <img>
ve <video>
öğelerini kullanır. Ancak <canvas>
öğesi, SDR ile sınırlı kalır. Bir tuvalde dinamik HDR içeriği oluşturmak için içeriğin görüntülenmeden önce HDR görüntüsü olarak kodlanması gerekir (örnek için bu demoya bakın).
WebGPU tuval yapılandırmasındaki yeni GPUCanvasToneMappingMode
parametresi, WebGPU'nun artık beyazdan (#FFFFFF
) daha parlak renkler çizmesine olanak tanıyor. Bu işlem aşağıdaki modlar aracılığıyla gerçekleştirilir:
"standard"
: Varsayılan davranış, içeriği ekranın SDR aralığıyla kısıtlar. Bu mod, ekranın renk alanındaki tüm renk değerlerinin[0, 1]
aralığına sabitlenmesiyle elde edilir."extended"
: Ekranın tam HDR aralığını açar. Bu mod, ekranın[0, 1]
aralığında"standard"
ile eşleşir. Sınırlama veya projeksiyon, ekranın genişletilmiş dinamik aralığına uygulanır ancak[0, 1]
.
Aşağıdaki kod snippet'inde, yüksek dinamik aralık için tuvalin nasıl yapılandırılacağı gösterilmektedir.
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) örneğini ve WebGPU HDR örneğini inceleyerek WebGPU ile HDR'yi keşfedin ve chromestatus girişine göz atın.

Genişletilmiş alt grup desteği
Alt grup denemeleri duyurusunun ardından, alt grup yerleşik işlevleri artık hem hesaplama gölgelendiricilerinde hem de parça gölgelendiricilerinde kullanılabilir. Artık yalnızca işlem gölgelendiricileriyle sınırlı değildir. 354738715 numaralı soruna bakın.
subgroup_size
yerleşik değerinin şu anda parça gölgelendiricilerde hatalı olduğunu unutmayın. Şimdilik bu özelliği kullanmayın.
Ayrıca, aşağıdaki alt grup yerleşik işlevleri eklendi:
subgroupAdd(value)
: Alt gruptaki tüm etkin çağrıların toplamını döndürürvalue
.subgroupExclusiveAdd(value)
: Alt gruptaki tüm etkin çağrılarınvalue
özel tarama toplamını döndürür.subgroupMul(value)
: Alt gruptaki tüm etkin çağrıların çarpımınıvalue
döndürür.subgroupExclusiveMul(value)
: Alt gruptaki tüm etkin çağrılardavalue
'nin özel tarama çarpımını döndürür.subgroupAnd(value)
: Alt gruptaki tüm etkin çağırmaların ikili VE'sini döndürür.value
subgroupOr(value)
: Alt gruptaki tüm etkin çağırmaların ikili VEYA'sını döndürür.value
subgroupXor(value)
: Alt gruptaki tüm etkin çağrıların ikili XOR'unu döndürür.value
subgroupMin(value)
: Alt gruptaki tüm etkin çağrımlarınvalue
en düşük değerini döndürür.subgroupMax(value)
: Alt gruptaki tüm etkin çağırma işlemlerinin maksimum değerini döndürür.value
subgroupAll(value)
: Alt gruptaki tüm etkin çağırmalar içinvalue
doğruysa true değerini döndürür.subgroupAny(value)
: Alt gruptaki etkin bir çağırma içinvalue
doğruysa true değerini döndürür.subgroupElect()
: Bu çağrının, alt gruptaki etkin çağrılar arasında en düşüksubgroup_invocation_id
değerine sahip olması durumunda doğru (true) değerini döndürür.subgroupBroadcastFirst(value)
: Alt grupta en düşüksubgroup_invocation_id
değerine sahip etkin çağırmadan diğer tüm etkin çağırmalaravalue
yayınlanır.subgroupShuffle(value, id)
:subgroup_invocation_id
'siid
ile eşleşen etkin çağırmadanvalue
değerini döndürür.subgroupShuffleXor(value, mask)
:subgroup_invocation_id
'sisubgroup_invocation_id ^ mask
ile eşleşen etkin çağırmadanvalue
değerini döndürür.mask
dinamik olarak tek tip olmalıdır.subgroupShuffleUp(value, delta)
:subgroup_invocation_id
'sisubgroup_invocation_id - delta
ile eşleşen etkin çağırmadanvalue
değerini döndürür.subgroupShuffleDown(value, delta)
:subgroup_invocation_id
'sisubgroup_invocation_id + delta
ile eşleşen etkin çağırmadanvalue
değerini döndürür.quadBroadcast(value, id)
: Kimliğiid
olan dörtlü çağırmadanvalue
yayınları.id
, sabit ifade olmalıdır.quadSwapX(value)
: X yönünde dörtlüdeki çağırmalar arasındavalue
öğesini değiştirir.quadSwapY(value)
: Y yönündeki dörtlüde çağırmalar arasındavalue
değiştirir.quadSwapDiagonal(value)
: Dörtlüdeki çağrılar arasında çapraz olarakvalue
geçiş yapar.
Dawn güncellemeleri
wgpu::PrimitiveState
yapısı artık doğrudan derinlik kırpma kontrolü ayarını içeriyor. Bu sayede ayrı bir wgpu::PrimitiveDepthClipControl
yapısına gerek kalmıyor. Daha fazla bilgi edinmek için aşağıdaki kod snippet'ine ve webgpu-headers PR'ye bakın.
// Before
wgpu::PrimitiveState primitive = {};
wgpu::PrimitiveDepthClipControl depthClipControl;
depthClipControl.unclippedDepth = true;
primitive.nextInChain = &depthClipControl;
// Now
wgpu::PrimitiveState primitive = {};
primitive.unclippedDepth = true;
Bu özet yalnızca önemli noktalardan bazılarını kapsar. Kapsamlı commit listesine göz atın.
WebGPU'daki yenilikler
WebGPU'daki Yenilikler serisinde ele alınan her şeyin listesi.
Chrome 140
- Cihaz istekleri adaptörü tüketiyor
- Doku görünümünün kullanıldığı yerlerde doku kullanmak için kısa yol
- WGSL textureSampleLevel, 1 boyutlu dokuları destekler
- bgra8unorm salt okunur depolama dokusu kullanımını kullanımdan kaldırma
- GPUAdapter isFallbackAdapter özelliğini kaldırın
- Dawn ile ilgili güncellemeler
Chrome 139
- BC ve ASTC sıkıştırılmış biçimleri için 3D doku desteği
- Yeni "temel özellikler ve sınırlar" özelliği
- WebGPU uyumluluk modu için kaynak denemesi
- Dawn ile ilgili güncellemeler
Chrome 138
- Arabellek bağlama kaynağı olarak kullanma için kısa yol
- Oluşturma sırasında eşlenen arabellekler için boyut şartı değişiklikleri
- Yakın tarihli GPU'lar için mimari raporu
- GPUAdapter isFallbackAdapter özelliğinin desteğini sonlandırma
- Dawn ile ilgili güncellemeler
Chrome 137
- externalTexture bağlama için doku görünümünü kullanma
- Arabellekler, ofset ve boyut belirtilmeden kopyalanıyor
- Atomik işaretçi kullanarak WGSL workgroupUniformLoad
- GPUAdapterInfo powerPreference özelliği
- GPURequestAdapterOptions compatibilityMode özelliğini kaldırma
- Dawn ile ilgili güncellemeler
Chrome 136
- GPUAdapterInfo isFallbackAdapter özelliği
- D3D12'de gölgelendirici derleme süresinde iyileştirmeler
- Kanvas görüntülerini kaydetme ve kopyalama
- Artış uyumluluk modu kısıtlamaları
- Dawn ile ilgili güncellemeler
Chrome 135
- Boş bağlama grubu düzeniyle işlem hattı düzeni oluşturmaya izin ver
- Görüntü alanlarının, oluşturma hedefi sınırlarının ötesine geçmesine izin ver
- Android'de deneysel uyumluluk moduna daha kolay erişim
- maxInterStageShaderComponents sınırını kaldırma
- Dawn ile ilgili güncellemeler
Chrome 134
- Alt gruplarla makine öğrenimi iş yüklerini iyileştirme
- Karıştırılabilir olarak kayan filtrelenebilir doku türleri desteğini kaldırma
- Dawn ile ilgili güncellemeler
Chrome 133
- Ek unorm8x4-bgra ve 1 bileşenli köşe biçimleri
- Bilinmeyen sınırların tanımlanmamış değerle istenmesine izin ver
- WGSL hizalama kurallarındaki değişiklikler
- Silme işlemiyle WGSL performansında artış
- Harici dokular için VideoFrame displaySize'ı kullanma
- copyExternalImageToTexture kullanarak varsayılan olmayan yönlere sahip resimleri işleme
- Geliştirici deneyimini iyileştirme
- featureLevel ile uyumluluk modunu etkinleştirme
- Deneysel alt grup özelliklerinde temizleme
- maxInterStageShaderComponents sınırının desteğini sonlandırma
- Dawn ile ilgili güncellemeler
Chrome 132
- Doku görünümü kullanımı
- 32 bit kayan noktalı doku karıştırma
- GPUDevice adapterInfo özelliği
- Geçersiz biçimdeki tuval bağlamını yapılandırma JavaScript hatası veriyor
- Doku üzerinde filtreleme örnekleyici kısıtlamaları
- Genişletilmiş alt grup denemesi
- Geliştirici deneyimini iyileştirme
- 16 bit normalleştirilmiş doku biçimleri için deneysel destek
- Dawn ile ilgili güncellemeler
Chrome 131
- WGSL'de kırpma mesafeleri
- GPUCanvasContext getConfiguration()
- Nokta ve çizgi temel öğelerinde derinlik önyargısı olmamalıdır
- Alt gruplar için kapsayıcı tarama yerleşik işlevleri
- Çoklu çekme dolaylı desteği (deneysel)
- Shader modülü derleme seçeneği strict math
- GPUAdapter requestAdapterInfo() yöntemini kaldırın
- Dawn ile ilgili güncellemeler
Chrome 130
- Çift kaynaklı karıştırma
- Metal'de gölgelendirici derleme süresinde iyileştirmeler
- GPUAdapter requestAdapterInfo() yönteminin desteğinin sonlandırılması
- Dawn ile ilgili güncellemeler
Chrome 129
Chrome 128
- Alt gruplarla deneme yapma
- Çizgiler ve noktalar için derinlik önyargısı ayarını kullanımdan kaldırma
- preventDefault kullanılıyorsa yakalanmamış hata DevTools uyarısını gizleme
- WGSL, önce örneklemeyi enterpolasyon yapar ve ardından
- Dawn ile ilgili güncellemeler
Chrome 127
- Android'de OpenGL ES için deneysel destek
- GPUAdapter info özelliği
- WebAssembly birlikte çalışabilirlik iyileştirmeleri
- Komut kodlayıcı hatalarında iyileştirme
- Dawn ile ilgili güncellemeler
Chrome 126
- maxTextureArrayLayers sınırını artırma
- Vulkan arka ucu için arabellek yükleme optimizasyonu
- Gölgeleyici derleme süresinde iyileştirmeler
- Gönderilen komut arabellekleri benzersiz olmalıdır
- Dawn ile ilgili güncellemeler
Chrome 125
- Alt gruplar (geliştirme aşamasında olan bir özellik)
- 3D dokunun dilimine göre oluşturma
- Dawn ile ilgili güncellemeler
Chrome 124
- Salt okunur ve okuma-yazma depolama dokuları
- Service worker'lar ve shared worker'lar için destek
- Yeni bağdaştırıcı bilgisi özellikleri
- Hata düzeltmeleri
- Dawn ile ilgili güncellemeler
Chrome 123
- WGSL'de DP4a yerleşik işlevleri desteği
- WGSL'de kısıtlanmamış işaretçi parametreleri
- WGSL'de bileşikleri referanssızlaştırmak için sözdizimi kolaylığı
- Şablon ve derinlik yönleri için ayrı salt okunur durum
- Dawn ile ilgili güncellemeler
Chrome 122
- Uyumluluk moduyla erişimi genişletme (geliştirme aşamasında olan bir özellik)
- maxVertexAttributes sınırını artırma
- Dawn ile ilgili güncellemeler
Chrome 121
- Android'de WebGPU'yu destekleme
- Windows'da gölgelendirici derleme için FXC yerine DXC kullanma
- İşleme ve oluşturma geçişlerindeki zaman damgalı sorgular
- Shader modüllerine varsayılan giriş noktaları
- GPUExternalTexture renk alanı olarak display-p3'ü destekleme
- Bellek yığınları bilgileri
- Dawn ile ilgili güncellemeler
Chrome 120
- WGSL'de 16 bitlik kayan nokta değerleri için destek
- Sınırları zorlayın
- Derinlik-şablon durumundaki değişiklikler
- Adaptör bilgisi güncellemeleri
- Zaman damgası sorgularının nicemleme işlemi
- Bahar temizliği özellikleri
Chrome 119
- Filtrelenebilir 32 bit kayan noktalı dokular
- unorm10-10-10-2 köşe biçimi
- rgb10a2uint doku biçimi
- Dawn ile ilgili güncellemeler
Chrome 118
copyExternalImageToTexture()
içinde HTMLImageElement ve ImageData desteği- Okuma/yazma ve salt okuma depolama dokusu için deneysel destek
- Dawn ile ilgili güncellemeler
Chrome 117
- Köşe arabelleğini ayarlamayı kaldırma
- Bağlama grubunu kaldırma
- Cihaz kaybolduğunda eşzamansız işlem hattı oluşturma işleminden kaynaklanan hataları sessize alma
- SPIR-V gölgelendirici modülü oluşturma güncellemeleri
- Geliştirici deneyimini iyileştirme
- Otomatik olarak oluşturulan düzene sahip işlem hatlarını önbelleğe alma
- Dawn ile ilgili güncellemeler
Chrome 116
- WebCodecs entegrasyonu
- GPUAdapter
requestDevice()
tarafından döndürülen kayıp cihaz importExternalTexture()
aranırsa video oynatmayı sorunsuz tutma- Spesifikasyona uygunluk
- Geliştirici deneyimini iyileştirme
- Dawn ile ilgili güncellemeler
Chrome 115
- Desteklenen WGSL dil uzantıları
- Direct3D 11 için deneysel destek
- AC güçte varsayılan olarak ayrı GPU kullanma
- Geliştirici deneyimini iyileştirme
- Dawn ile ilgili güncellemeler
Chrome 114
- JavaScript'i optimize etme
- Yapılandırılmamış tuvalde getCurrentTexture() işlevi InvalidStateError hatası veriyor
- WGSL güncellemeleri
- Dawn ile ilgili güncellemeler