经过多年的开发,Chrome 团队宣布,WebGPU 的第一个版本现已在 ChromeOS、macOS 和 Windows 上的 Chrome 中默认提供。如需了解详情,请参阅 Chrome 发布 WebGPU。
我们还开始在 MDN 上添加有关 WebGPU 的全面文档。
还有更多其他功能。
在 importExternalTexture()
中使用 WebCodecs VideoFrame
源
WebGPU 公开了一个 API,用于通过 importExternalTexture()
从 HTMLVideoElement
创建不透明的“外部纹理”对象。您可以使用这些对象高效地对视频帧进行采样,可能直接从源 YUV 数据以零复制方式进行采样。
不过,最初的 WebGPU 规范不允许通过 WebCodecs VideoFrame
对象创建 GPUExternalTexture
对象。对于已在使用 WebCodecs 且希望将 WebGPU 集成到视频处理流水线中的高级视频处理应用,此功能非常重要。目前,我们正在 gpuweb/gpuweb#1380 问题中进行讨论。
启用该功能
默认情况下,Chrome 中不会启用此功能,但您可以通过明确启用此功能,在 Chrome 113 中对其进行试用。您可以在本地启用该功能,方法是启用 chrome://flags/#enable-webgpu-developer-features
中的“WebGPU 开发者功能”标志。
为了面向应用的所有访问者启用该功能,我们目前正在进行源代码试用,该试用将在 Chrome 118(2023 年 12 月 8 日)结束。如需参与试用,请报名,然后在 HTML 或 HTTP 标头中添加包含来源试用令牌的元元素。如需了解详情,请参阅开始使用源代码试用版一文。
示例代码
// 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);
const texture = device.importExternalTexture({ source: videoFrame });
// TODO: Use texture in bind group creation.
查看使用 WebCodecs 上传视频实验示例,试用一下。
WebGPU 中的新变化
WebGPU 新变化系列中涵盖的所有内容的列表。
Chrome 132
- TextureView 用法
- 32 位浮点纹理混合
- GPUDevice adapterInfo 属性
- 使用无效格式配置画布上下文会抛出 JavaScript 错误
- 过滤纹理上的采样器限制
- 扩展了小组实验
- 改进开发者体验
- 对 16 位归一化纹理格式的实验性支持
- Dawn 更新
Chrome 131
- 在 WGSL 中剪裁距离
- GPUCanvasContext getConfiguration()
- 点和线基元不得有深度偏差
- 针对子群组的包含性扫描内置函数
- 对多绘制间接的实验性支持
- 着色器模块编译选项“严格数学”
- 移除了 GPUAdapter requestAdapterInfo()
- Dawn 更新
Chrome 130
Chrome 129
Chrome 128
Chrome 127
Chrome 126
Chrome 125
Chrome 124
Chrome 123
Chrome 122
Chrome 121
- 支持 Android 上的 WebGPU
- 在 Windows 上使用 DXC 而非 FXC 进行着色器编译
- 计算和渲染通道中的时间戳查询
- 着色器模块的默认入口点
- 支持将 display-p3 用作 GPUExternalTexture 色彩空间
- 内存堆信息
- Dawn 更新
Chrome 120
Chrome 119
Chrome 118
Chrome 117
Chrome 116
- WebCodecs 集成
- GPUAdapter
requestDevice()
返回的丢失设备 - 在调用
importExternalTexture()
时保持视频流畅播放 - 规范合规性
- 改进开发者体验
- Dawn 更新