当前位置: 首页 > news >正文

建设银行武威分行网站购物网站开发介绍

建设银行武威分行网站,购物网站开发介绍,多媒体网页设计是什么,wordpress redis缓存定时推荐:将NSDT场景编辑器加入你3D工具链其他工具系列:NSDT简石数字孪生基于WebGL技术开发在线游戏、商品展示、室内漫游往往都会涉及到动画,初步了解three.js可以做什么,深入讲解three.js动画之前,本节课先制作一个简单的…
推荐:将NSDT场景编辑器加入你3D工具链
其他工具系列:NSDT简石数字孪生

基于WebGL技术开发在线游戏、商品展示、室内漫游往往都会涉及到动画,初步了解three.js可以做什么,深入讲解three.js动画之前,本节课先制作一个简单的立方体旋转动画。 本节课是在1.1节 第一个3D场景已绘制好的立方体代码基础上进行更改。

周期性渲染

在1.1节中讲解过,每执行一次渲染器对象WebGLRenderer的渲染方法.render(),浏览器就会渲染出一帧图像并显示在Web页面上,这就是说你按照一定的周期不停地调用渲染方法.render()就可以不停地生成新的图像覆盖原来的图像。这也就是说只要一边旋转立方体,一边执行渲染方法.render()重新渲染,就可以实现立方体的旋转效果。

为了实现周期性渲染可以通过浏览器全局对象window对象的一个方法setInterval(),可以通过window对象调用该方法window.setInterval(),也可以直接以函数形式调用setInterval()

setInterval()是一个周期性函数,就像一个定时器,每隔多少毫秒ms执行一次某个函数。

// 间隔20ms周期性调用函数fun
setInterval("render()",20)

为了实现立方体旋转动画效果,直接使用下面的代码代替1.1节中代码renderer.render(scene,camera);即可。

// 渲染函数
function render() {renderer.render(scene,camera);//执行渲染操作mesh.rotateY(0.01);//每次绕y轴旋转0.01弧度
}
//间隔20ms周期性调用函数fun,20ms也就是刷新频率是50FPS(1s/20ms),每秒渲染50次
setInterval("render()",20);

上面代码定义了一个渲染函数render(),函数中定义了三个语句,通过setInterval("render()",20);可以实现m每间隔20毫秒调用一次函数render(),每次调用渲染函数的时候,执行renderer.render(scene,camera);渲染出一帧图像,执行mesh.rotateY(0.01);语句使立方体网格模型绕y轴旋转0.01弧度。

渲染频率

调用渲染方法.render()进行渲染的渲染频率不能太低,比如执行setInterval("render()",200);间隔200毫秒调用渲染函数渲染一次,相当于每秒渲染5次,你会感觉到比较卡顿。渲染频率除了不能太低,也不能太高,太高的话计算机的硬件资源跟不上,函数setInterval()设定的渲染方式也未必能够正常实现。一般调用渲染方法.render()进行渲染的渲染频率控制在每秒30~60次,人的视觉效果都很正常,也可以兼顾渲染性能。

//设置调用render函数的周期为200ms,刷新频率相当于5你能明显的感受到卡顿
setInterval("render()",200);

函数requestAnimationFrame()

前面讲解threejs动画效果,使用了setInterval()函数,实际开发中,为了更好的利用浏览器渲染,可以使用函数requestAnimationFrame()代替setInterval()函数,requestAnimationFrame()setInterval()一样都是浏览器window对象的方法。

requestAnimationFrame()参数是将要被调用函数的函数名,requestAnimationFrame()调用一个函数不是立即调用而是向浏览器发起一个执行某函数的请求, 什么时候会执行由浏览器决定,一般默认保持60FPS的频率,大约每16.7ms调用一次requestAnimationFrame()方法指定的函数,60FPS是理想的情况下,如果渲染的场景比较复杂或者说硬件性能有限可能会低于这个频率。可以查看文章《requestAnimationFrame()》了解更多requestAnimationFrame()函数的知识。

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

均匀旋转

在实际执行程序的时候,可能requestAnimationFrame(render)请求的函数并不一定能按照理想的60FPS频率执行,两次执行渲染函数的时间间隔也不一定相同,如果执行旋转命令的rotateY的时间间隔不同,旋转运动就不均匀,为了解决这个问题需要记录两次执行绘制函数的时间间隔。

使用下面的渲染函数替换原来的渲染函数即可,rotateY()的参数是0.001*t,也意味着两次调用渲染函数执行渲染操作的间隔t毫秒时间内,立方体旋转了0.001*t弧度,很显然立方体的角速度是0.001弧度每毫秒(0.0001 rad/ms = 1 rad/s = 180度/s)。CPU和GPU执行一条指令时间是纳秒ns级,相比毫秒ms低了6个数量级,所以一般不用考虑渲染函数中几个计时语句占用的时间,除非你编写的是要精确到纳秒ns的级别的标准时钟程序。

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建模学习工作室

专注数字孪生、3D建模、3D仿真、虚拟现实

正在上传…重新上传取消3D建模学习工作室

http://www.yayakq.cn/news/563667/

相关文章:

  • 如何做360购物网站德州网站建设的公司
  • 宝洁公司网站建设案例wordpress使用缩略图
  • 祥云平台 网站建设企业管理系统设计
  • 怎么在网站视频做字幕wordpress文章自动分类
  • 厦门网站建设找哪家比较好百度百家号怎么赚钱
  • 做网站策划薪酬网站用cms
  • 哪个网站有适合小学生做的题目网站建设方案范文2000字
  • 法语网站建站公司养生网站设计
  • 山西中交建设工程招标有限公司网站深圳seo优化服务
  • 嘉兴企业网站建设推广网站开发图片框
  • 制作小程序网站源码无锡定制网站
  • 手机网站后台网站悬浮二维码
  • 站长工具2023最新国产iis ip访问网站
  • 广西网站制作海拉尔网站设计
  • 网站建设管理昆山市建设监察大队网站
  • 做网站要学会什么语言手机上传视频网站开发
  • 兰亭集势的网站平台建设怎么制作微信小程序游戏
  • 网站站长需要具备什么素质天津网站建设 泰姆仕
  • 广东建设厅的网站查询中国建设银行国际互联网网站
  • 电子商务网站建设方案书建站源码下载
  • wordpress开通多站点好处海淀搜索引擎优化seo
  • 校园网站制作模板网站建站平台开发服务服务采购公告
  • 西安分类信息网站下载站源码cms
  • python做视频点播网站房屋装修设计师培训
  • 开发一个网站需要多长时间额尔古纳网站建设价格
  • 重庆市网站推广wordpress淘宝客手机
  • 网站开发移动端小程序推广赚佣金平台
  • 网站形象首页flash黑龙江今天最新消息
  • 做企业网站通常哪找素材二维码转链接在线生成器
  • 北京公司做网站建网站要几个域名