THREE实战2_正交投影相机与透视相机

正交投影相机

特点:看见物体的远近高低比例都是相同
就像maya中的三视图。
看一下鄙人以前做的一个简单模型伞。

  • 侧视图

在这里插入图片描述

  • 俯视图

在这里插入图片描述
正交投影构造函数OrthographicCamera

OrthographicCamera( left, right, top, bottom, near, far );

在这里插入图片描述

参数含义
left左平面距离相机中心的垂直距离
right右平面距离相机中心的垂直距离
top顶平面距离相机中心的垂直距离
bottom低平面距离相机中心的垂直位置
near近平面距离相机中心的垂直位置
far远平面距离相机中心的垂直距离

maya的顶视图相机,相机中心就是它的焦点位置。
在这里插入图片描述

透视相机

  • 透视图
    在这里插入图片描述
    透视相机就像我们的人眼
    在这里插入图片描述
    透视投影相机的构造函数PerspectiveCamera
PerspectiveCamera(fov,aspect,near,far);
参数含义
fov视角
aspect纵横比
near近平面
far原平面

maya的透视相机
在这里插入图片描述

THREE实战

前期的工作重构代码:

        <script>
        //场景的物体
        var cube=null,mesh=null,scene=null;
        function initObject() {
            var geometry = new THREE.CubeGeometry(300,300,300,);//正方体
            //白色反射所有光线,利于检测灯光
            var material = new THREE.MeshLambertMaterial( { color:0xFFFFFF} );//白色
            mesh = new THREE.Mesh( geometry,material);
            mesh.position = new THREE.Vector3(0,0,0);
            scene.add(mesh);
        }
        //灯光
        function initLight() {
            light_direction=new THREE.DirectionalLight(0x0000FF,1);//方向光蓝色
            light_direction.position.set(10,20,6);
        }
        //函数入口
        function threeStart() {
            initThree();
            initCamera();
            initScene();
            initLight();
            initObject();
            animation();
        }
        // 循环渲染
        function animation()
        {
            renderer.render(scene, camera);
            requestAnimationFrame(animation);//递归调用
        }
        </script>
<body onload="threeStart();">
<div id="canvas-frame"></div>
</body>

case1:正交投影相机的使用

相机中心视为原点,left与bottom为负值

        //正交投影相机
        function initCamera() {
        var camera;
        camera=new THREE.OrthographicCamera(-width/2,width/2,height/2,-height/2,1,1000);
        camera.position.x = 0;
        camera.position.y = 0;
        camera.position.z = 700;

        camera.up.x = 0;//相机朝向位置
        camera.up.y = 1;
        camera.up.z = 0;
        camera.lookAt(new THREE.Vector3(0,0,0));
        }

在这里插入图片描述
调整左侧距离left=-width时
在这里插入图片描述

case2:透视相机的使用
        //透视相机45视角,屏幕纵横比,1-1000的距离区间
        function initCamera() {
        var camera;
        camera = new THREE.PerspectiveCamera(45, width/height, 1, 1000);
        camera.position.x = 0;
        camera.position.y = 0;
        camera.up.x = 0;//相机朝向位置
        camera.up.y = 1;
        camera.up.z = 0;
        camera.lookAt(new THREE.Vector3(0,0,0));
        }

在这里插入图片描述
调整视角120度,视角0-180度之间看到的物体会越来越小
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yma16

感谢支持!共勉!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值