javascript - 在babylon.js 中渲染之前创建网格

标签 javascript babylonjs

我想在每次渲染之前创建新的网格,这是我的代码(一个最小的演示):

let canvas,
    engine,
    camera,
    scene;

function initEngine(){
    canvas = document.getElementById("renderCanvas");
    engine = new BABYLON.Engine(canvas, true);
}

function createScene(){
    initEngine();

    let scene = new BABYLON.Scene(engine);

    camera = new BABYLON.ArcRotateCamera("camera", Math.PI / 2, Math.PI / 2, 4, BABYLON.Vector3.Zero(), scene);
    camera.attachControl(canvas, true);


    let light1 = new BABYLON.HemisphericLight("light1", new BABYLON.Vector3(0,1,0), scene);

    let ground = BABYLON.MeshBuilder.CreateGround(
        "ground",
        {
            width:30,
            height:30
        },
        scene
    );

    ground.position.y -= 0.5;

    let sphere1 = BABYLON.MeshBuilder.CreateSphere(
        "sphere1",
        {

        },
        scene
    );

    let sphere2 = sphere1.clone("sphere2");
    let sphere3 = sphere1.clone("sphere3");

    sphere1.position.z = -18;
    sphere2.position.z = -19;
    sphere3.position.z = -20;

    let snake = [
        sphere1,
        sphere2,
        sphere3
    ];

    (function(){
        let counter = 4;
        scene.registerBeforeRender(function(){
            let newOne = BABYLON.MeshBuilder.CreateSphere(
                "sphere" + counter,
                {

                },
                scene
            );
            let head = snake[0];
            newOne.position = head.position;
            newOne.position.x += 0.02;
            snake.unshift(newOne);
            ++counter;
        });
    })();

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

    return scene;
}

scene = createScene();

engine.runRenderLoop(function(){
    // box.position.z += 0.01;
    scene.render();
});

我期望的行为是创建一系列球体,每个 position.x 都比前一个稍高。然而,渲染后场景中只有三个网格,如下所示:

结果

enter image description here

我想知道我的代码有什么问题,以及如何正确实现它?

顺便问一下,scene.removeMesh(mesh)mesh.dispose() 有什么区别?

最佳答案

就是因为这句话。

newOne.position = head.position;

它只是复制一个引用。所以现在新的球体和snake[0]共享相同的位置实例,因此所有新创建的球体共享相同的位置实例(通过持有位置引用),并且位于相同的位置。

关于javascript - 在babylon.js 中渲染之前创建网格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50235364/

相关文章:

javascript - 如何选择一个网格而不是在 BabylonJS 中单击的所有网格

android - Cordova 网络应用程序

javascript - 单击时可见列表行下方的全宽 div

javascript - 如何在jsFiddle中传输代码?

javascript - Babylon.js OnIntersectionEnterTrigger 未使用相机触发

next.js - Next Js 中的 @Babylonjs (ES6) 因意外 token 'export' 而失败

javascript - 使用 Babylon.JS 在循环内停止/重新启动动画

javascript - Flash 影片可以将鼠标事件传递到包含页面吗?

javascript - react native : Passing DataSource into Method from Props in _renderRow

Javascript 防止默认值不被执行