位置: 编程技术 - 正文
推荐整理分享Bullet有关六自由度弹性约束研究(六个自由),希望有所帮助,仅作参考,欢迎阅读内容。
文章相关热门搜索词:六个自由度英文,六自由度stewart平台,六种自由是什么,六个自由度英文,六自由度stewart平台,六个自由,六个自由,六种自由是什么,内容如对您有帮助,希望把文章链接给更多的朋友!
这段时间打算将物理引擎整合进来,于是对Bullet这款开源的物理引擎进行了一些研究。Bullet的研究也有了一段时间了,Bullet这个引擎其实很久之前就接触了,只是一直以来,只是跑跑它的例子,也没有研究例子以及源代码,想要整合进入渲染引擎中也就井中月水中花了。今年3月,我曾经制作了一个整合Bullet最简单的一个例子。即模拟物体坠落的,并且写了博客《QtQuick OpenGL Bullet初次测试》。这个例子开了一个好头。这段时间开始研究Bullet的一些其它有趣儿的特性了。
Bullet的约束(也称关节),是一个非常有意思的部分,因为它表示了两个碰撞物体之间的物理关系。比如说如果两个珠子是由一根绳子串起来的,那么绳子就代表了两个珠子之间的约束,当然你可以将绳子换成一根橡皮筋或者一根弹簧,它们都代表了不同的约束。这些约束,都有它们的名称,我最近在研究的就是六自由度弹性约束。
研究一个引擎最好的方法就是研究它的例子。对于Bullet也是如此。在Bullet自带的ConstraintDemo中,我看到了由一些非常有意思的约束组织而成的场景。因此从这个地方入手还不错。例子的截图如下:
你可以使用鼠标右键发射方块,来测试一下约束对于这些物体有什么作用。
这个场景包含了多种约束,每一种约束的处理方法都包含了相应的力学公式以及它的加成。我这回只对六自由度弹性约束进行研究,因此将其单独拉了出来。
六自由度弹性约束是一种约束,顾名思义,它可以作六个维度的旋转,并且在平移方面可以保持一定的弹性。上图中的右上角中黄色和蓝色方块形成的就是一个六自由度弹性约束。这个场景将Bullet的约束都显示出来了,让大家都可以了解,约束究竟能够怎样地影响物体。
六自由度弹性约束它具有一下的属性,它们分别如下:
英文名
中文名
RigidBodyA
此约束作用的刚体A
RigidBodyB
此约束作用的刚体B
frameInA
从刚体A到此约束的变换
frameInB
从刚体B到此约束的变换
LinearUpperLimit
平移(线性)最高的限制
LinearLowerLimit
平移(线性)最低的限制
AngularUpperLimit
旋转(角)最高的限制
AngularLowerLimit
旋转(角)最低的限制
Spring
弹簧效果
Stiffness
弹簧的刚性(劲度)
Damping
弹簧的衰减
我们将默认的例子效果修改一下,设计成我们想要的带有弹簧的效果:
将这些代码替换掉ConstraintDemo.cpp的到行,然后重新查看效果。发现约束改变了,如下图:
黄色的方块变成一个在六个自由度中都只有-°到°的约束。尝试用方块碰撞它,发现会绕着约束进行旋转。
接下来就是模仿的过程了,话说我要亲自尝试一下在Qt Quick OpenGL下跑Bullet中约束的例子,因此在前期做了很多的工作,初始化相关的类就花费了很多的精力,由于代码篇幅较长,这里只贴出重要的部分:
这里创建的是一个简单的场景:只有一个六自由度弹性约束,两个刚体,还有一个质量非常大的物体,通过点击按钮来启用物理引擎,这样物体会通过做自由落体运动来将重力势能转化为动能,冲击这个刚体。由于设置了旋转弹性因子,因此处于约束另一方的刚体很自然地通过旋转避开了质量大的物体,最终该物体被弹出……
翻开源码,究竟弹性是怎么实现的呢?原来这用到了一个经典的公式:胡克定律。胡克定律的公式是F= k·x,其中k是物体的劲度系数,这里对应的也就是stiffness。看来要了解Bullet这个库的原理,还要我们复习很多物理知识呢。
FTGL库剖析之二----纹理文字 纹理文字是一种常用的在opengl下显示文字的方式,其过程大体说来就是将文字的位图数据作为纹理(仅使用alpha通道),贴到一个四边形,并且,纹理映
对用OpenGL ES 2.0实现OpenGL ES 1.1的顶点着色器的研究 对用OpenGLES2.0实现OpenGLES1.1的顶点着色器的研究想要彻底研究OpenGLES2.0与前一代OpenGL的区别,还是要费很大一番精力的。最近在仔细研读《OpenGLES2.0Programmi
OpenGL--贝塞尔曲线或曲面 理论基础贝塞尔曲线和曲面:OpenGL只能直接绘制基本图元,对于曲线和曲面我们一般采用一系列线段或多边形来模拟的,这样当线段或多边形增多时必
标签: 六个自由
本文链接地址:https://www.jiuchutong.com/biancheng/369488.html 转载请保留说明!友情链接: 武汉网站建设