Babylon.js WebGPU Ocean Demo — 完整踩坑记录

换成军舰后的图片

源码运行后效果

最后代码正常启动

Babylon.js WebGPU Ocean Demo 本地运行踩坑全记录

环境

  • Chrome 145
  • Babylon.js 6.26.0
  • Windows 10

问题一:depth24unorm-stencil8 类型错误

报错:

复制代码
TS2322: Type '"depth24unorm-stencil8"' is not assignable to type 'GPUFeatureName'

原因: 该特性已从 WebGPU 规范移除。

修复: 直接删除这一行。


问题二:requestAdapterInfo is not a function

报错:

复制代码
TypeError: this._adapter.requestAdapterInfo is not a function

原因: Chrome 新版将 requestAdapterInfo() 改为 adapter.info 属性,Babylon.js 6.x 内部还在调用旧 API。

修复:index.ts 最顶部加 polyfill:

typescript

复制代码
if (typeof navigator !== "undefined" && navigator.gpu) {
    const origRequestAdapter = navigator.gpu.requestAdapter.bind(navigator.gpu);
    (navigator.gpu as any).requestAdapter = async (options?: GPURequestAdapterOptions) => {
        const adapter = await origRequestAdapter(options);
        if (adapter && typeof (adapter as any).requestAdapterInfo !== "function") {
            (adapter as any).requestAdapterInfo = async () => {
                return (adapter as any).info ?? {};
            };
        }
        return adapter;
    };
}
```

---

### 问题三:`onResizeObservable` 类型错误

**报错:**
```
TS2339: Property 'onResizeObservable' does not exist on type 'ThinEngine'

原因: onResizeObservableEngine 上,不在 ThinEngine 上。

修复: RTTDebug.ts 两处修改:

typescript

复制代码
// 1. 私有变量类型改为 any
private _engine: any;

// 2. 第178行加可选链
(this._engine as any).onResizeObservable?.add(this._resize.bind(this));
```

---

### 问题四:`WebGPUEngine` 与 `Engine` 类型不兼容

**报错:**
```
TS2740: Type 'WebGPUEngine' is missing the following properties from type 'Engine'

修复: index.ts 里 engine 类型直接用 any

typescript

复制代码
let engine: any;

最终完整 index.ts

typescript

复制代码
import * as BABYLON from "@babylonjs/core";
import { WebGPUEngine } from "@babylonjs/core/Engines/webgpuEngine";
import { Engine } from "@babylonjs/core/Engines/engine";
import { getSceneModuleWithName } from "./createScene";

// 修复 Chrome 新版移除了 requestAdapterInfo
if (typeof navigator !== "undefined" && navigator.gpu) {
    const origRequestAdapter = navigator.gpu.requestAdapter.bind(navigator.gpu);
    (navigator.gpu as any).requestAdapter = async (options?: GPURequestAdapterOptions) => {
        const adapter = await origRequestAdapter(options);
        if (adapter && typeof (adapter as any).requestAdapterInfo !== "function") {
            (adapter as any).requestAdapterInfo = async () => {
                return (adapter as any).info ?? {};
            };
        }
        return adapter;
    };
}

const getModuleToLoad = (): string | undefined => location.search.split("scene=")[1];

export const babylonInit = async (): Promise<void> => {
    const moduleName = getModuleToLoad();
    const createSceneModule = await getSceneModuleWithName(moduleName);

    (window as any).BABYLON = BABYLON;

    await Promise.all(createSceneModule.preTasks || []);
    const canvas = document.getElementById("renderCanvas") as HTMLCanvasElement;

    let engine: any;
    const webgpuSupported = await WebGPUEngine.IsSupportedAsync;

    if (webgpuSupported) {
        const webgpuEngine = new WebGPUEngine(canvas, {
            deviceDescriptor: {
                requiredFeatures: [
                    "depth-clip-control",
                    "depth32float-stencil8",
                    "texture-compression-bc",
                    "texture-compression-etc2",
                    "texture-compression-astc",
                    "indirect-first-instance",
                ],
            },
        });
        await webgpuEngine.initAsync();
        engine = webgpuEngine;
    } else {
        engine = new Engine(canvas, true);
    }

    (window as any).engine = engine;

    const scene = await createSceneModule.createScene(engine, canvas);
    (window as any).scene = scene;

    engine.runRenderLoop(function () {
        scene.render();
    });

    window.addEventListener("resize", function () {
        engine.resize();
    });
};

babylonInit().then(() => {});

package.json 依赖版本

json

复制代码
"dependencies": {
    "@babylonjs/core": "6.26.0",
    "@babylonjs/gui": "6.26.0",
    "@babylonjs/inspector": "6.26.0",
    "@babylonjs/loaders": "6.26.0",
    "@babylonjs/materials": "6.26.0",
    "lil-gui": "0.16.0"
}

注意去掉 ^,防止自动升级到不兼容版本。

修正后源码:https://download.csdn.net/download/zhanglixin999/92736547

相关推荐
kgduu2 小时前
js之json处理
前端·javascript·json
Code知行合壹2 小时前
JDK10新特性
开发语言·jdk
qq_390760392 小时前
简单的线程安全日志记录器
开发语言·数据库·c#
T1an-12 小时前
C++11智能指针shared_ptr的控制块内都有什么?
开发语言·c++
迈巴赫车主2 小时前
天梯赛 L2-004 这是二叉搜索树吗?java
java·开发语言·数据结构·算法·天梯赛
小鸡吃米…2 小时前
基准测试与性能分析
开发语言·python
神仙别闹2 小时前
基于MATLAB实现(GUI)汽车出入库识别系统
开发语言·matlab·汽车
今儿敲了吗2 小时前
python基础学习笔记第一章
开发语言·python
badhope2 小时前
C语言二级考点全解析与真题精讲
c语言·开发语言·c++·人工智能·python·microsoft·职场和发展