Kanvas ton eşleme moduyla HDR desteği
Web geliştiriciler, HDR içerik sunmak için sınırlı seçeneklere sahiptir ve temel olarak <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 resmi 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 hesaplama 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ğırma işlemlerininvalueözel tarama toplamını döndürür.subgroupMul(value): Alt gruptaki tüm etkin çağrıların çarpımını döndürürvalue.subgroupExclusiveMul(value): Alt gruptaki tüm etkin çağrılardavalueö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.valuesubgroupOr(value): Alt gruptaki tüm etkin çağırmaların ikili VEYA'sını döndürürvalue.subgroupXor(value): Alt gruptaki tüm etkin çağırmaların ikili XOR'unu döndürür.valuesubgroupMin(value): Alt gruptaki tüm etkin çağrılardavalueen düşük değeri döndürür.subgroupMax(value): Alt gruptaki tüm etkin çağrılardanvalueen yüksek değeri döndürür.subgroupAll(value): Alt gruptaki tüm etkin çağrılar içinvaluedoğruysa true değerini döndürür.subgroupAny(value): Alt gruptaki etkin bir çağırma içinvaluedoğ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_iddeğerine sahip olması durumunda doğru değerini döndürür.subgroupBroadcastFirst(value): Alt grupta en düşüksubgroup_invocation_iddeğerine sahip etkin çağırmadanvalue, diğer tüm etkin çağırmalara yayınlanır.subgroupShuffle(value, id):subgroup_invocation_id'siidile eşleşen etkin çağırmadanvaluedeğerini döndürür.subgroupShuffleXor(value, mask):subgroup_invocation_id'sisubgroup_invocation_id ^ maskile eşleşen etkin çağırmadanvaluedeğerini döndürür.maskdinamik olarak tek tip olmalıdır.subgroupShuffleUp(value, delta):subgroup_invocation_id'sisubgroup_invocation_id - deltaile eşleşen etkin çağırmadanvaluedeğerini döndürür.subgroupShuffleDown(value, delta):subgroup_invocation_id'sisubgroup_invocation_id + deltaile eşleşen etkin çağırmadanvaluedeğerini döndürür.quadBroadcast(value, id): Kimliğiidolan dörtlü çağırmadanvalueyayınlar.id, sabit ifade olmalıdır.quadSwapX(value): X yönünde dörtlüdeki çağırmalar arasındavaluedeğiştirir.quadSwapY(value): Y yönündeki dörtlüde çağırmalar arasındavaluedeğiştirir.quadSwapDiagonal(value): Dörtlüdeki çağrılar arasında çapraz olarakvaluegeçiş yapar.
Dawn ile ilgili güncellemeler
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 tüm konuların listesi.
Chrome 143
- Doku bileşeni karıştırması
- bgra8unorm salt okunur depolama dokusu kullanımını kaldırma
- Dawn ile ilgili güncellemeler
Chrome 142
Chrome 141
- Tint IR tamamlandı
- WGSL derleyicisinde tam sayı aralığı analizi
- Vulkan arka ucu için SPIR-V 1.4 güncellemesi
- Dawn ile ilgili güncellemeler
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 deneme süreci
- 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 verme
- Görüntü alanlarının, oluşturma hedefi sınırlarının ötesine geçmesine izin verme
- 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 verme
- WGSL hizalama kurallarındaki değişiklikler
- WGSL'de silme işlemiyle elde edilen performans artışları
- 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 nokta dokularını karıştırma
- GPUDevice adapterInfo özelliği
- Geçersiz biçimle tuval bağlamı yapılandırıldığında JavaScript hatası oluşuyor
- 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 örnekleme interpolasyonu
- 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ı
- Hizmet çalışanı ve paylaşılan çalışan desteği
- Yeni adaptör 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 damgası 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ı zorlama
- Derinlik-şablon durumundaki değişiklikler
- Adaptör bilgisi güncellemeleri
- Zaman damgası sorgularının nicelleştirilmesi
- 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şlemindeki 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 hattı önbelleğe alma
- Dawn ile ilgili güncellemeler
Chrome 116
- WebCodecs entegrasyonu
- GPUAdapter
requestDevice()tarafından döndürülen kayıp cihaz importExternalTexture()çağrılı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ücünde 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
Chrome 113
importExternalTexture()'de WebCodecs VideoFrame kaynağını kullanma