如何在三个js中为相机添加dat gui控件?

时间:2012-09-27 10:24:52

标签: javascript three.js dat.gui

我想在本页的基本threejs示例中为threejs相机启用dat-gui控件:

https://github.com/mrdoob/three.js/

var camera, scene, renderer;
var geometry, material, mesh;

init();
animate();

function init() {

    camera = new THREE.PerspectiveCamera( 75, window.innerWidth / window.innerHeight, 1, 10000 );
    camera.position.z = 1000;

    scene = new THREE.Scene();

    geometry = new THREE.CubeGeometry( 200, 200, 200 );
    material = new THREE.MeshBasicMaterial( { color: 0xff0000, wireframe: true } );

    mesh = new THREE.Mesh( geometry, material );
    scene.add( mesh );

    renderer = new THREE.CanvasRenderer();
    renderer.setSize( window.innerWidth, window.innerHeight );

    document.body.appendChild( renderer.domElement );

}

function animate() {

    // note: three.js includes requestAnimationFrame shim
    requestAnimationFrame( animate );

    mesh.rotation.x += 0.01;
    mesh.rotation.y += 0.02;

    renderer.render( scene, camera );

}

我尝试过以下代码:

var params = {
    z: 100
}

var gui = new dat.GUI();

gui.add(params, 'z', -500,500).step(5).onChange(function(value){
        changeCameraZ(value);
    });
function changeCameraZ(value){
    camera.position.z = value;
}

有效,但这意味着我必须编写一个新函数: changeBlah();

我希望从GUI更改每个three.js变量。是否有更好,更清洁的方法来实现这一目标?

2 个答案:

答案 0 :(得分:9)

您还可以使用DAT.gui如何使用引用。

gui.add( camera.position , 'z', -500, 500 ).step(5)

和一个例子

http://jsfiddle.net/2WKqL/2/

答案 1 :(得分:3)

这个单行应该可以工作。

gui.add( params, 'z', -500, 500 ).step(5).onChange( function( value ){ camera.position.z = value; } );