Tính năng mới trong WebGPU (Chromet)

François Beaufort
François Beaufort

Tích hợp WebCodecs

WebGPU hiển thị một API để tạo "hoạ tiết bên ngoài" mờ các đối tượng từ HTMLVideoElement đến importExternalTexture(). Bạn có thể sử dụng các đối tượng này để lấy mẫu khung hình video một cách hiệu quả, theo cách không sao chép trực tiếp từ nguồn dữ liệu mô hình màu YUV.

Tuy nhiên, thông số kỹ thuật ban đầu của WebGPU không cho phép tạo đối tượng GPUExternalTexture từ đối tượng WebCodecs VideoFrame. Khả năng này rất quan trọng đối với các ứng dụng xử lý video nâng cao đã sử dụng WebCodecs và muốn tích hợp WebGPU vào quy trình xử lý video. Tính năng tích hợp WebCodecs hỗ trợ thêm việc sử dụng VideoFrame làm nguồn cho lệnh gọi GPUExternalTexturecopyExternalImageToTexture(). Hãy xem ví dụ sau và mục chromestatus.

// Access the GPU device.
const adapter = await navigator.gpu.requestAdapter();
const device = await adapter.requestDevice();

// Create VideoFrame from HTMLVideoElement.
const video = document.querySelector("video");
const videoFrame = new VideoFrame(video);

// Create texture from VideoFrame.
const texture = device.importExternalTexture({ source: videoFrame });
// TODO: Use texture in bind group creation.

Hãy xem mẫu thử nghiệm Tải video lên bằng WebCodecs để thử nghiệm tính năng này.

Thiết bị đã mất bị GPUAdapter requestDevice() trả về

Nếu phương thức requestDevice() trên GPUAdapter không thành công vì phương thức này đã được dùng để tạo GPUDevice, thì phương thức này giờ đây sẽ thực hiện bằng một GPUDevice ngay lập tức được đánh dấu là bị mất, thay vì trả về lời hứa từ chối bằng null. Hãy xem phần vấn đề về chromium:1234617.

const adapter = await navigator.gpu.requestAdapter();
const device1 = await adapter.requestDevice();

// New! The promise is not rejected anymore with null.
const device2 = await adapter.requestDevice();
// And the device is immediately marked as lost.
const info = await device2.lost;

Giữ cho quá trình phát lại video mượt mà nếu importExternalTexture() được gọi

Khi importExternalTexture() được gọi bằng HTMLVideoElement, quá trình phát video có liên quan sẽ không bị điều tiết nữa khi video không hiển thị trong khung nhìn. Hãy xem phần vấn đề về chromium:1425252.

Tuân thủ quy định

Không bắt buộc phải sử dụng đối số message trong hàm khởi tạo GPUPipelineError(). Xem bài viết thay đổi chromium:4613967.

Lỗi sẽ được kích hoạt khi gọi createShaderModule() nếu nguồn WGSL code chứa \0. Xem vấn đề buổi sáng:1345.

Mức chi tiết tối đa mặc định (lodMaxClamp) được sử dụng khi lấy mẫu kết cấu bằng createSampler() là 32. Xem phần thay đổi chromium:4608063.

Cải thiện trải nghiệm của nhà phát triển

Một thông báo sẽ xuất hiện trong bảng điều khiển JavaScript Công cụ cho nhà phát triển để nhắc nhà phát triển khi họ đang sử dụng WebGPU trên một nền tảng không được hỗ trợ. Xem bài viết thay đổi chromium:4589369.

Thông báo lỗi xác thực vùng đệm sẽ xuất hiện ngay lập tức trong bảng điều khiển JavaScript Công cụ cho nhà phát triển khi getMappedRange() không thành công mà không buộc nhà phát triển gửi lệnh đến hàng đợi. Xem phần thay đổi chromium:4597950.

Ảnh chụp màn hình bảng điều khiển JavaScript trong Công cụ cho nhà phát triển, trong đó có thông báo lỗi xác thực vùng đệm.
Thông báo lỗi xác thực vùng đệm trong bảng điều khiển JavaScript Công cụ cho nhà phát triển.

Cập nhật bình minh

Nút bật/tắt gỡ lỗi disallow_unsafe_apis được đổi tên thành allow_unsafe_apis và đặt mặc định thành tắt. Nút bật/tắt này ngăn chặn các lỗi xác thực trên các điểm truy cập API hoặc các tổ hợp tham số chưa được xem là an toàn. Điều này có thể hữu ích khi gỡ lỗi. Xem vấn đề buổi sáng:1685.

Thuộc tính source không dùng nữa wgpu::ShaderModuleWGSLDescriptor sẽ bị xoá và thay vào đó là code. Xem phần thay đổi bình minh:130321.

Đã triển khai phương thức wgpu::RenderBundle::SetLabel() bị thiếu. Xem phần thay đổi bình minh:134502.

Các ứng dụng có thể yêu cầu một phần phụ trợ cụ thể khi nhận bộ chuyển đổi thông qua tuỳ chọn wgpu::RequestAdapterOptionsBackendType. Hãy xem ví dụ bên dưới và vấn đề dawn:1875.

wgpu::RequestAdapterOptionsBackendType backendTypeOptions = {};
backendTypeOptions.backendType = wgpu::BackendType::D3D12;

wgpu::RequestAdapterOptions options = {};
options.nextInChain = &backendTypeOptions;

// Request D3D12 adapter.
myInstance.RequestAdapter(&options, myCallback, myUserData);

Phương thức SwapChain::GetCurrentTexture() mới được thêm vào cùng với các cách sử dụng bổ sung cho kết cấu chuỗi hoán đổi (swapchain) để có thể sử dụng wgpu::Texture trả về trong các bản sao. Hãy xem ví dụ bên dưới và vấn đề dawn:1551.

wgpu::SwapChain swapchain = myDevice.CreateSwapChain(mySurface, &myDesc);
swapchain.GetCurrentTexture();
swapchain.Present();

Bài viết này chỉ đề cập đến một số điểm nổi bật chính. Hãy xem danh sách các thay đổi đầy đủ.

Tính năng mới trong WebGPU

Danh sách mọi nội dung được đề cập trong loạt bài Có gì mới trong WebGPU.

Chrome 127

Chrome 126

Chrome 125

Chrome 124

Chrome 123

Chrome 122

Chrome 121

Chrome 120

Chrome 119

Chrome 118

Chrome 117

Chrome 116

Chrome 115

Chrome 114

Chrome 113