最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • three.js学习(三)

    正文概述 掘金(我是臭猪猪)   2021-06-12   746

    第三天:

    关于让自己创建的3D模型动起来的一些基础知识,毕竟动起来才会显得逼格很高,动的更快,更炫酷岂不是求职利器

    每执行一次渲染器对象的render()方法,浏览器就会通过CPU把相关的图形数据发送到GPU和显存,然后渲染出一帧图像,这就是说你按照一定的周期调用该方法就可以不停地生成新的图像覆盖原来的图像, 这时要注意我为了产生立方体的旋转动画效果,每执行一次render()渲染方法,要把立方体绕一个坐标轴旋转一定的角度,立方体不停地旋转,相机不停地拍照自然就会形成动画的效果。

          function render() {
              renderer.render(scene,camera);//执行渲染操作
              spereMesh.rotateY(0.01);//立方体每次绕y轴旋转0.01弧度
              boxMesh.rotateY(0.01);//球体每次绕y轴旋转0.01弧度
              requestAnimationFrame(render);//请求再次执行渲染函数render
          }
          render();
    

    这里用到了一个用于动画的方法requestAnimationFrame(),该方法属于浏览器的window对象可以直接调用,参数是将要被调用函数的函数名,该方法调用函数不是立即调用而是向浏览器发起一个执行某函数的请求, 什么事会执行由浏览器决定,一般默认保持60FPS的频率,就是肉眼所见不会卡顿的一个频率

    实际动画过程中会出现不均匀旋转的情况,这时候就需要用到时间戳来控制(当然代码是我复制来的,实际中出现不均匀情况就来复制代码吧):

    let T0 = new Date();//上次时间
    function render() {
            let T1 = new Date();//本次时间
            let t = T1-T0;//时间差
            T0 = T1;//把本次时间赋值给上次时间
            requestAnimationFrame(render);
            renderer.render(scene,camera);//执行渲染操作
            mesh.rotateY(0.001*t);//旋转角速度0.001弧度每毫秒
        }
    render();
    

    就先写到旋转,下一篇就写如何用鼠标操作3D模型图


    起源地下载网 » three.js学习(三)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元