Three.js实现多个物体以中心位置各自向周围移动

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>物体以中心点朝着四方八方移动</title>
    <style>
        body{margin: 0;}
        canvas{width:100%;height: 100%}
    </style>
</head>
<body>
    <script src="js/three.min.js"></script>
    <script>
        var scene = new THREE.Scene();
        var camera = new THREE.PerspectiveCamera(75,window.innerWidth/window.innerHeight,0.1,1000);
        var centerPosition;

        var renderer = new THREE.WebGLRenderer();
        renderer.setSize(window.innerWidth,window.innerHeight);
        document.body.appendChild(renderer.domElement);

        var geometry = new THREE.BoxGeometry(1,1,1);
        var material = new THREE.MeshBasicMaterial({color:0x00ff00});
        var cube1 = new THREE.Mesh(geometry,material);
        var cube2 = cube1.clone();          //物体克隆
        var cube3 = cube1.clone();
        var cube4 = cube1.clone();

        cube1.position.x = 5;
        cube2.position.y = 5;
        cube3.position.z = 5;
        cube3.position.x = 5;
        cube4.position.x = 4;
        cube4.position.y = 4;
        cube4.position.z = 4;
        scene.add(cube1);
        scene.add(cube2);
        scene.add(cube3);
        scene.add(cube4);

        camera.position.z = 50;
        centerPosition = SetCenterPosition();

        //计算每个物体移动的方向,物体位置减去中心位置
        var direction1 = cube1.position.sub(centerPosition);
        var direction2 = cube2.position.sub(centerPosition);
        var direction3 = cube3.position.sub(centerPosition);
        var direction4 = cube4.position.sub(centerPosition);

        var cubeCenter = cube1.clone();
        cubeCenter.position.set(centerPosition.x,centerPosition.y,centerPosition.z);
        console.log("cubeCenter:"+cubeCenter.position.x);
        scene.add(cubeCenter);

        var animate = function()
        {
            requestAnimationFrame(animate);

            BaoZhaUpdate(cube1,direction1);
            BaoZhaUpdate(cube2,direction2);
            BaoZhaUpdate(cube3,direction3);
            BaoZhaUpdate(cube4,direction4);

            renderer.render(scene,camera);
        };

        animate();

        //设置中心点
        function SetCenterPosition()
        {
            var pos=new THREE.Vector3(0,0,0);
            //四个物体位置相加
            pos.add(cube1.position);
            pos.add(cube2.position);
            pos.add(cube3.position);
            pos.add(cube4.position);
            var count = 4;
            pos = pos.divideScalar(count);             //得出平均位置
            console.log("pos:"+pos.x);
            return pos;
        }

        function BaoZhaUpdate(cube,direction)
        {
            //console.log("direction:"+direction.x);
            //设置物体移动
            cube.position.set(cube.position.x+direction.x*0.01,cube.position.y+direction.y*0.01,cube.position.z+direction.z*0.01);
        }
    </script>
</body>
</html>

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

YanisWu

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值