Hỗ trợ HTMLImageElement và ImageData trong copyExternalImageToTexture()
Phương thức copyExternalImageToTexture() trên GPUQueue cho phép bạn sao chép ảnh chụp nhanh được lấy từ hình ảnh, video hoặc canvas nguồn vào một GPUTexture nhất định. Giờ đây, bạn có thể truyền các đối tượng HTMLImageElement và ImageData làm nguồn. Hãy xem ví dụ sau và vấn đề chromium:1471372.
// Fetch and decode image.
const source = document.createElement("img");
source.src = "my-image.png";
await source.decode();
// Create destination texture.
const size = [source.width, source.height];
const texture = myDevice.createTexture({
size,
format: "rgba8unorm",
usage:
GPUTextureUsage.COPY_DST |
GPUTextureUsage.RENDER_ATTACHMENT |
GPUTextureUsage.TEXTURE_BINDING,
});
// Copies a snapshot taken from the source image into a texture.
myDevice.queue.copyExternalImageToTexture({ source }, { texture }, size);
Hỗ trợ thử nghiệm cho kết cấu lưu trữ chỉ đọc và đọc-ghi
Loại liên kết kết cấu lưu trữ cho phép bạn thực hiện các thao tác đọc kết cấu mà không cần lấy mẫu và lưu trữ vào các vị trí tuỳ ý trong chương trình đổ bóng. Khi tính năng "chromium-experimental-read-write-storage-texture" có trong GPUAdapter, giờ đây, bạn có thể yêu cầu GPUDevice có tính năng này và đặt quyền truy cập GPUStorageTexture thành "read-write" hoặc "read-only" khi tạo bố cục nhóm liên kết. Trước đây, tính năng này bị giới hạn ở "write-only".
Để tận dụng tính năng này, bạn phải bật tiện ích này một cách rõ ràng trong mã WGSL bằng enable chromium_experimental_read_write_storage_texture. Khi bật, bạn có thể sử dụng trình đủ điều kiện truy cập read_write và read cho kết cấu lưu trữ, các hàm tích hợp textureLoad() và textureStore() sẽ hoạt động tương ứng và một hàm tích hợp textureBarrier() mới có sẵn để đồng bộ hoá các quyền truy cập bộ nhớ kết cấu trong một nhóm công việc. Hãy xem ví dụ sau và vấn đề dawn:1972.
Tính năng này vẫn đang ở giai đoạn thử nghiệm và có thể thay đổi. Trong khi tính năng này đang được chuẩn hoá, hãy chạy Chrome bằng --enable-dawn-features=allow_unsafe_apis cờ để cung cấp tính năng này.
const feature = "chromium-experimental-read-write-storage-texture";
const adapter = await navigator.gpu.requestAdapter();
if (!adapter.features.has(feature)) {
throw new Error("Read-write storage texture support is not available");
}
// Explicitly request read-write storage texture support.
const device = await adapter.requestDevice({
requiredFeatures: [feature],
});
const bindGroupLayout = device.createBindGroupLayout({
entries: [{
binding: 0,
visibility: GPUShaderStage.COMPUTE,
storageTexture: {
access: "read-write", // <-- New!
format: "r32uint",
},
}],
});
const shaderModule = device.createShaderModule({ code: `
enable chromium_experimental_read_write_storage_texture;
@group(0) @binding(0) var tex : texture_storage_2d<r32uint, read_write>;
@compute @workgroup_size(1, 1)
fn main(@builtin(local_invocation_id) local_id: vec3u) {
var data = textureLoad(tex, vec2i(local_id.xy));
data.x *= 2;
textureStore(tex, vec2i(local_id.xy), data);
}`,
});
// You can now create a compute pipeline with this shader module and
// send the appropriate commands to the GPU.
Thông tin cập nhật về Dawn
API C webgpu.h đã đổi tên các trường sau để đảm bảo tính nhất quán: requiredFeaturesCount thành requiredFeatureCount, pipelineStatisticsCount thành pipelineStatisticCount, và colorFormatsCount thành colorFormatCount. Xem vấn đề dawn:146040.
Một chương trình DawnInfo mới (tương tự như vulkaninfo) cho phép bạn liệt kê các nút bật/tắt, bộ điều hợp, tính năng của bộ điều hợp và giới hạn của bộ điều hợp. Chương trình này có sẵn khi bạn tạo samples của dawn. Sau đây là kết quả được cắt bớt đáng kể để ngắn gọn. Xem thay đổi dawn:149020.
./out/Debug/DawnInfo
Toggles
=======
Name: allow_unsafe_apis
Suppresses validation errors on API entry points or parameter combinations
that aren't considered secure yet.
http://crbug.com/1138528
[…]
Adapter
=======
VendorID: 0x106B
Vendor: apple
Architecture: common-3
DeviceID: 0x0000
Name: Apple M1 Pro
Driver description: Metal driver on macOS Version 13.5.1 (Build 22G90)
Adapter Type: discrete GPU
Backend Type: Metal
Power: <undefined>
Features
========
* depth_clip_control
Disable depth clipping of primitives to the clip volume
https://bugs.chromium.org/p/dawn/issues/detail?id=1178
[…]
Adapter Limits
==============
maxTextureDimension1D: 16,384
maxTextureDimension2D: 16,384
[…]
Nội dung này chỉ đề cập đến một số điểm nổi bật chính. Hãy xem danh sách đầy đủ các cam kết.
Tính năng mới trong WebGPU
Danh sách mọi nội dung đã được đề cập trong loạt bài Tính năng mới trong WebGPU.
Chrome 147-148
Chrome 146
- Hỗ trợ chế độ tương thích WebGPU trên OpenGL ES 3.1
- Tệp đính kèm tạm thời
- Tiện ích texture_and_sampler_let của WGSL
- Thông tin cập nhật về Dawn
Chrome 145
- Tiện ích subgroup_uniformity của WGSL
- Thử nghiệm ánh xạ vùng đệm đồng bộ trong trình thực thi
- Thông tin cập nhật về Dawn
Chrome 144
- Tiện ích subgroup_id của WGSL
- Tiện ích uniform_buffer_standard_layout của WGSL
- WebGPU trên Linux
- writeBuffer và writeTexture nhanh hơn
- Thông tin cập nhật về Dawn
Chrome 143
- Hoán vị thành phần hoạt tiết
- Loại bỏ việc sử dụng kết cấu bộ nhớ chỉ đọc bgra8unorm
- Thông tin cập nhật về Dawn
Chrome 142
Chrome 141
- Đã hoàn tất Tint IR
- Phân tích phạm vi số nguyên trong trình biên dịch WGSL
- Bản cập nhật SPIR-V 1.4 cho phần phụ trợ Vulkan
- Thông tin cập nhật về Dawn
Chrome 140
- Yêu cầu thiết bị sử dụng bộ điều hợp
- Cách viết tắt để sử dụng kết cấu khi khung hiển thị kết được dùng
- WGSL textureSampleLevel hỗ trợ kết cấu 1D
- Ngừng sử dụng kết cấu lưu trữ chỉ đọc bgra8unorm
- Xoá thuộc tính isFallbackAdapter của GPUAdapter
- Thông tin cập nhật về Dawn
Chrome 139
- Hỗ trợ hoạ tiết 3D cho các định dạng nén BC và ASTC
- Tính năng "core-features-and-limits" mới
- Dùng thử theo nguyên gốc cho chế độ tương thích WebGPU
- Thông tin cập nhật về Dawn
Chrome 138
- Cách viết tắt để sử dụng vùng đệm làm tài nguyên liên kết
- Thay đổi yêu cầu về kích thước đối với các vùng đệm được ánh xạ khi tạo
- Báo cáo về cấu trúc cho các GPU gần đây
- Ngừng sử dụng thuộc tính isFallbackAdapter của GPUAdapter
- Thông tin cập nhật về Dawn
Chrome 137
- Sử dụng khung hiển thị kết cấu cho liên kết externalTexture
- Sao chép vùng đệm mà không chỉ định độ lệch và kích thước
- workgroupUniformLoad của WGSL sử dụng con trỏ đến nguyên tử
- Thuộc tính powerPreference của GPUAdapterInfo
- Xoá thuộc tính compatibilityMode của GPURequestAdapterOptions
- Thông tin cập nhật về Dawn
Chrome 136
- Thuộc tính isFallbackAdapter của GPUAdapterInfo
- Cải thiện thời gian biên dịch chương trình đổ bóng trên D3D12
- Lưu và sao chép hình ảnh canvas
- Gỡ bỏ các hạn chế của chế độ tương thích
- Thông tin cập nhật về Dawn
Chrome 135
- Cho phép tạo bố cục quy trình với bố cục nhóm liên kết rỗng
- Cho phép các khung nhìn mở rộng vượt quá ranh giới của mục tiêu kết xuất
- Dễ dàng truy cập vào chế độ tương thích thử nghiệm trên Android
- Xoá giới hạn maxInterStageShaderComponents
- Thông tin cập nhật về Dawn
Chrome 134
- Cải thiện khối lượng công việc học máy bằng các nhóm con
- Xoá tính năng hỗ trợ các loại kết cấu có thể lọc dấu phẩy động dưới dạng có thể kết hợp
- Thông tin cập nhật về Dawn
Chrome 133
- Định dạng đỉnh unorm8x4-bgra và 1 thành phần bổ sung
- Cho phép yêu cầu các giới hạn không xác định bằng giá trị không xác định
- Thay đổi quy tắc căn chỉnh WGSL
- Tăng hiệu suất WGSL bằng discard
- Sử dụng VideoFrame displaySize cho các kết cấu bên ngoài
- Xử lý hình ảnh có hướng không mặc định bằng copyExternalImageToTexture
- Cải thiện trải nghiệm của nhà phát triển
- Bật chế độ tương thích bằng featureLevel
- Dọn dẹp các tính năng thử nghiệm của nhóm con
- Ngừng sử dụng giới hạn maxInterStageShaderComponents
- Thông tin cập nhật về Dawn
Chrome 132
- Sử dụng khung hiển thị kết cấu
- Kết hợp kết cấu dấu phẩy động 32 bit
- Thuộc tính adapterInfo của GPUDevice
- Định cấu hình ngữ cảnh canvas bằng định dạng không hợp lệ sẽ gây ra lỗi JavaScript
- Lọc các hạn chế của bộ lấy mẫu trên kết cấu
- Thử nghiệm mở rộng các nhóm con
- Cải thiện trải nghiệm của nhà phát triển
- Hỗ trợ thử nghiệm cho các định dạng kết cấu được chuẩn hoá 16 bit
- Thông tin cập nhật về Dawn
Chrome 131
- Khoảng cách cắt trong WGSL
- GPUCanvasContext getConfiguration()
- Các nguyên thuỷ điểm và đường thẳng không được có độ lệch độ sâu
- Hàm tích hợp quét toàn diện cho các nhóm con
- Hỗ trợ thử nghiệm cho tính năng vẽ nhiều lần gián tiếp
- Tuỳ chọn biên dịch mô-đun chương trình đổ bóng toán học nghiêm ngặt
- Xoá GPUAdapter requestAdapterInfo()
- Thông tin cập nhật về Dawn
Chrome 130
- Kết hợp nguồn kép
- Cải thiện thời gian biên dịch chương trình đổ bóng trên Metal
- Ngừng sử dụng GPUAdapter requestAdapterInfo()
- Thông tin cập nhật về Dawn
Chrome 129
- Hỗ trợ HDR bằng chế độ ánh xạ tông màu canvas
- Mở rộng tính năng hỗ trợ các nhóm con
- Thông tin cập nhật về Dawn
Chrome 128
- Thử nghiệm với các nhóm con
- Ngừng sử dụng tính năng đặt độ lệch độ sâu cho đường thẳng và điểm
- Ẩn cảnh báo DevTools về lỗi chưa ghi lại nếu preventDefault
- WGSL nội suy lấy mẫu trước và một trong hai
- Thông tin cập nhật về Dawn
Chrome 127
- Hỗ trợ thử nghiệm cho OpenGL ES trên Android
- Thuộc tính thông tin GPUAdapter
- Cải thiện khả năng tương tác WebAssembly
- Cải thiện lỗi bộ mã hoá lệnh
- Thông tin cập nhật về Dawn
Chrome 126
- Tăng giới hạn maxTextureArrayLayers
- Tối ưu hoá quá trình tải vùng đệm lên cho phần phụ trợ Vulkan
- Cải thiện thời gian biên dịch chương trình đổ bóng
- Các vùng đệm lệnh đã gửi phải là duy nhất
- Thông tin cập nhật về Dawn
Chrome 125
- Nhóm con (tính năng đang phát triển)
- Kết xuất thành lát cắt của kết cấu 3D
- Thông tin cập nhật về Dawn
Chrome 124
- Kết cấu lưu trữ chỉ đọc và đọc-ghi
- Hỗ trợ trình thực thi dịch vụ và trình thực thi dùng chung
- Thuộc tính thông tin bộ điều hợp mới
- Sửa lỗi
- Thông tin cập nhật về Dawn
Chrome 123
- Hỗ trợ các hàm tích hợp DP4a trong WGSL
- Tham số con trỏ không hạn chế trong WGSL
- Cú pháp dễ hiểu để huỷ tham chiếu các tổ hợp thành phần trong WGSL
- Trạng thái chỉ đọc riêng biệt cho các khía cạnh mẫu tô và độ sâu
- Thông tin cập nhật về Dawn
Chrome 122
- Mở rộng phạm vi tiếp cận bằng chế độ tương thích (tính năng đang phát triển)
- Tăng giới hạn maxVertexAttributes
- Thông tin cập nhật về Dawn
Chrome 121
- Hỗ trợ WebGPU trên Android
- Sử dụng DXC thay vì FXC để biên dịch chương trình đổ bóng trên Windows
- Truy vấn dấu thời gian trong các lượt tính toán và kết xuất
- Điểm truy cập mặc định vào các mô-đun chương trình đổ bóng
- Hỗ trợ display-p3 làm không gian màu GPUExternalTexture
- Thông tin về vùng nhớ
- Thông tin cập nhật về Dawn
Chrome 120
- Hỗ trợ các giá trị dấu phẩy động 16 bit trong WGSL
- Phá vỡ giới hạn
- Thay đổi đối với trạng thái độ sâu-mẫu tô
- Thông tin cập nhật về bộ điều hợp
- Lượng tử hoá truy vấn dấu thời gian
- Các tính năng dọn dẹp
Chrome 119
- Kết cấu dấu phẩy động 32 bit có thể lọc
- Định dạng đỉnh unorm10-10-10-2
- Định dạng kết cấu rgb10a2uint
- Thông tin cập nhật về Dawn
Chrome 118
- Hỗ trợ HTMLImageElement và ImageData trong
copyExternalImageToTexture() - Hỗ trợ thử nghiệm cho kết cấu lưu trữ chỉ đọc và đọc-ghi
- Thông tin cập nhật về Dawn
Chrome 117
- Huỷ đặt vùng đệm đỉnh
- Huỷ đặt nhóm liên kết
- Tắt tiếng lỗi từ quá trình tạo quy trình không đồng bộ khi thiết bị bị mất
- Thông tin cập nhật về quá trình tạo mô-đun chương trình đổ bóng SPIR-V
- Cải thiện trải nghiệm của nhà phát triển
- Lưu vào bộ nhớ đệm các quy trình có bố cục được tạo tự động
- Thông tin cập nhật về Dawn
Chrome 116
- Tích hợp WebCodecs
- Thiết bị bị mất do GPUAdapter
requestDevice() - Giữ cho quá trình phát video diễn ra mượt mà nếu
importExternalTexture()được gọi - Tuân thủ thông số kỹ thuật
- Cải thiện trải nghiệm của nhà phát triển
- Thông tin cập nhật về Dawn
Chrome 115
- Tiện ích ngôn ngữ WGSL được hỗ trợ
- Hỗ trợ thử nghiệm cho Direct3D 11
- Nhận GPU rời rạc theo mặc định trên nguồn điện AC
- Cải thiện trải nghiệm của nhà phát triển
- Thông tin cập nhật về Dawn
Chrome 114
- Tối ưu hoá JavaScript
- getCurrentTexture() trên canvas chưa định cấu hình sẽ gửi InvalidStateError
- Thông tin cập nhật về WGSL
- Thông tin cập nhật về Dawn