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

相关文章

HTML5实现的移动端购物车自动结算功能示例代码

《HTML5实现的移动端购物车自动结算功能示例代码》本文介绍HTML5实现移动端购物车自动结算,通过WebStorage、事件监听、DOM操作等技术,确保实时更新与数据同步,优化性能及无障碍性,提升用... 目录1. 移动端购物车自动结算概述2. 数据存储与状态保存机制2.1 浏览器端的数据存储方式2.1.

基于 HTML5 Canvas 实现图片旋转与下载功能(完整代码展示)

《基于HTML5Canvas实现图片旋转与下载功能(完整代码展示)》本文将深入剖析一段基于HTML5Canvas的代码,该代码实现了图片的旋转(90度和180度)以及旋转后图片的下载... 目录一、引言二、html 结构分析三、css 样式分析四、JavaScript 功能实现一、引言在 Web 开发中,

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

Conda虚拟环境的复制和迁移的四种方法实现

《Conda虚拟环境的复制和迁移的四种方法实现》本文主要介绍了Conda虚拟环境的复制和迁移的四种方法实现,包括requirements.txt,environment.yml,conda-pack,... 目录在本机复制Conda虚拟环境相同操作系统之间复制环境方法一:requirements.txt方法

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

springboot下载接口限速功能实现

《springboot下载接口限速功能实现》通过Redis统计并发数动态调整每个用户带宽,核心逻辑为每秒读取并发送限定数据量,防止单用户占用过多资源,确保整体下载均衡且高效,本文给大家介绍spring... 目录 一、整体目标 二、涉及的主要类/方法✅ 三、核心流程图解(简化) 四、关键代码详解1️⃣ 设置

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求