为THREEJS场景添加光影效果

添加光影效果主要用到的代码如下:

//使渲染器支持阴影贴图

THREE.Render.shadowMapEnabled= true;

//设置灯光阴影属性

//设置灯光生成阴影

THREE.Light.castShadow= true;

//如果是调试状态,还可以把灯光的调试帮助框显示出来

THREE.Light.shadowCameraVisible= true;

//设置阴影贴图质量

THREE.Light.shadowMapWidth = THREE.Light.shadowMapHeight = 1024*4;

//设置模型属性

//设置物体生成阴影

THREE.Mesh.castShadow = true;
//设置物体接收阴影,即其它物体的阴影可以显示在该物体上

THREE.Mesh.receiveShadow= true;

完整的测试代码如下:

<!DOCTYPE html>
<html>
<head>
    <title></title>
</head>
<body>
<script src="ThreeJS/build/three.js"></script>
<script src="ThreeJS/examples/js/controls/OrbitControls.js"></script>
<script src="ThreeJS/examples/js/loaders/OBJMTLLoader.js"></script>
<script src="ThreeJS/examples/js/loaders/MTLLoader.js"></script>
<script>
    var _scene,_camera,_control,_render,_ambient,_spotLight;
    Init();
    Animate();
    function Init()
    {
        _scene = new THREE.Scene();

        _camera = new THREE.PerspectiveCamera(45,window.innerWidth/window.innerHeight,0.1,2000);
        _camera.position.z = 50;

        _render = new THREE.WebGLRenderer();
        //设置渲染器大小
        _render.setSize(window.innerWidth,window.innerHeight);
        //设置渲染器阴影可用
        _render.shadowMapEnabled = true;
        document.body.appendChild(_render.domElement);

        //场景控制器,用以控制场景中的摄相机,方便观察场景
        _control = new THREE.OrbitControls(_camera,_render.domElement);

        //添加环境光
        _ambient = new THREE.AmbientLight(0xffffff);
        _scene.add(_ambient);
        //灯光属性
        _spotLight = new THREE.SpotLight(0xffffff);
        _spotLight.castShadow = true;
        _spotLight.shadowCameraVisible = true;
        _spotLight.position.set(100,100,100);
        //设置阴影贴图精度
        _spotLight.shadowMapWidth = _spotLight.shadowMapHeight = 1024*4;
        _scene.add(_spotLight);
        //加载模型
        LoadModel();
    }
    function Animate()
    {
        requestAnimationFrame(Animate);
        Render();
    }
    function Render()
    {
        //更新摄相机角度
        _control.update();
        _render.render(_scene,_camera);
    }
    function LoadModel()
    {
        //调用OBJMTLLoader加载模型
        var loader = new THREE.OBJMTLLoader();
        loader.load('Model/tc_tm/tc.obj','Model/tc_tm/tc.mtl',
        function(obj)
        {
            //traverse:回调,该模型以及所有子模型均执行该函数
            //相当于遍历obj的children数组
            obj.traverse(function(child)
            {
                if (child instanceof THREE.Mesh)
                {
                    //设置模型生成阴影并接收阴影
                    child.castShadow = true;
                    child.receiveShadow = true;
                }
            });
            _scene.add(obj);
        });
    }
</script>
</body>
</html>

效果如下图所示:

远观:

近看:

posted @ 2015-04-30 11:41  夏夜_fly  阅读(11935)  评论(3编辑  收藏  举报