ThreeJs中使用Cannon实现方块自由落体效果

2023-12-07 04:28

本文主要是介绍ThreeJs中使用Cannon实现方块自由落体效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        之前有做过小球的掉落效果,不过那个从画面上只能看出来重力加速度和接触地面反弹的效果,可能没有那么直观,也许用一些js加物理公式也能实现类似的效果,这节用小方块来演示,可以很直观的看出物理世界的现象,因为方块是有棱角的,掉落的时候与地面接触是棱或者角的话就会弹开翻转再落地。        

        同样,我们先设置一个物理世界,在物理世界中放置一个方块和地面,并设置地面和方块之间的反弹恢复系数,同样在Threejs中使用boxGermory设置一个长方体,在渲染的时候保持此长方体和物理世界的小方块保持角度和位置一致,便于在画面上观察小方块的掉落效果。核心代码在下面了,如果自己尝试有问题可以留言向我要完整的源码。

initCarton(){//新建一个物理模型世界this.world = new CANNON.World();// 设置物理世界重力加速度,此处设置为y轴的反方向,也就是往y轴反方向存在重力this.world.gravity.set(0, -20, 0);// 新建一个物理小方块:对应threejs的网格小方块const boxMaterial = new CANNON.Material()this.box = new CANNON.Body({mass: 0.3,//碰撞体质量material: boxMaterial,//设置小方块的材质shape:new CANNON.Box(new CANNON.Vec3(15, 6, 15)),//设置方形大小});this.box.position.y = 100;//设置小方块的位置this.box.quaternion.setFromEuler(Math.PI / 3, Math.PI / 3, Math.PI / 3);this.world.addBody(this.box);//将小方块添加到物理世界中// 新建物理地面const groundMaterial = new CANNON.Material()const groundBody = new CANNON.Body({mass: 0, // 质量为0,始终保持静止,不会受到力碰撞或加速度影响shape:new CANNON.Plane(),//新建物理模型的底面material: groundMaterial,//地面材质});// 改变平面默认的方向,法线默认沿着z轴,旋转到平面向上朝着y方向groundBody.quaternion.setFromEuler(-Math.PI / 2, 0, 0);this.world.addBody(groundBody);// 设置地面材质和小方块材质之间的碰撞反弹恢复系数,也就是底面和小方块的材质之间存在的反弹系数,const contactMaterial = new CANNON.ContactMaterial(groundMaterial, boxMaterial, {restitution: 0.2 //反弹恢复系数})// 把关联的材质添加到物理世界中this.world.addContactMaterial(contactMaterial)// 实体模型的网格小方块,这里是用来对应显示物理模型下的小方块位置const geometry = new THREE.BoxGeometry(15,6, 15);const material = new THREE.MeshLambertMaterial({color: 0x00ffff,});this.boxmesh = new THREE.Mesh(geometry, material);this.boxmesh.position.y = 100;this.boxmesh.rotation.set(Math.PI / 3, Math.PI / 3, Math.PI / 3);this.scene.add(this.boxmesh)//实体地面的网格模型,这里用来显示对应物理对应的地面const planeGeometry = new THREE.PlaneGeometry(200, 200);const planeMaterial = new THREE.MeshLambertMaterial({color:0x777777,});const planeMesh = new THREE.Mesh(planeGeometry, planeMaterial);planeMesh.rotateX(-Math.PI / 2);this.scene.add(planeMesh)},

效果视频:

小方块自由落体

这篇关于ThreeJs中使用Cannon实现方块自由落体效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/464479

相关文章

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Redis分片集群的实现

《Redis分片集群的实现》Redis分片集群是一种将Redis数据库分散到多个节点上的方式,以提供更高的性能和可伸缩性,本文主要介绍了Redis分片集群的实现,具有一定的参考价值,感兴趣的可以了解一... 目录1. Redis Cluster的核心概念哈希槽(Hash Slots)主从复制与故障转移2.