nape.dynamics.InteractionGroup
(转载http://tomyail.com/blog/1123)
说明:
Filter只是Shape的属性,Nape为Interactor类提供了group属性,这个属性是一个InteractionGroup类型.Shape,Body和Compound都是Interactor的子类,所以它们都能使用InteractionGroup的一些特性.
过滤规则:
把需要一起控制的对象指向同一个group,并且改变这个group的ignore(布尔值)属性来控制这些对象是否需要交互,true是不交互,false(默认)是交互.
group版本小球碰撞的源码:
private function testSimpleGroup():void
{
var group:InteractionGroup = new InteractionGroup();
var ball:Body = createCircleBody(BodyType.DYNAMIC, 60, 40, 30);
ball.shapes.at(0).material = new Material(Number.POSITIVE_INFINITY);
var box:Body = createRectBody(BodyType.KINEMATIC,110, 150, 200,20);
ball.group = box.group = group;
var btn:PushButton = new PushButton(this, 400, 100, "group.ignore=false(交互)", clickCallback);
btn.width = 200;
function clickCallback(e:MouseEvent):void
{
group.ignore = !group.ignore;
if (group.ignore) btn.label = "group.ignore=true(不交互)";
if (!group.ignore) btn.label = "group.ignore=false(交互)";
}
}
控制三组对象碰撞关系的group版本源码:
private function testMultiGroup():void
{
var groupA:InteractionGroup = new InteractionGroup(true);
var groupB:InteractionGroup = new InteractionGroup(false);
var groupC:InteractionGroup = new InteractionGroup(true); var groupAB:InteractionGroup = new InteractionGroup(false);
var groupBC:InteractionGroup = new InteractionGroup(true);
var groupAC:InteractionGroup = new InteractionGroup(false); groupA.group = groupAB;
groupA.group = groupAC; groupB.group = groupAB;
groupB.group = groupBC; groupC.group = groupAC;
groupC.group = groupBC; var Ba1:Body = createCircleBody(BodyType.DYNAMIC,50,100,120);
var Ba2:Body = createCircleBody(BodyType.DYNAMIC,150,100,120);
Ba1.group = groupA;
Ba2.group = groupA; var Bb1:Body = createCircleBody(BodyType.DYNAMIC,250,100,80);
var Bb2:Body = createCircleBody(BodyType.DYNAMIC,250,100,80);
Bb1.group = groupB;
Bb2.group = groupB; var Bc1:Body = createCircleBody(BodyType.DYNAMIC,300,100,30);
var Bc2:Body = createCircleBody(BodyType.DYNAMIC,300,100,30);
Bc1.group = groupC;
Bc2.group = groupC;
}
图示:
A(a1a2) | B(b1b2) | C(c1c2) | |
A(a1a2) | 0 | 1 | 1 |
B(b1b2) | 1 | 1 | 0 |
C(c1c2) | 1 | 0 | 0 |
0代表不交互:group.ignore=true;
1代表不交互:group.ignore=false;
比如:MRCA(a1,b2)==groupAB,而groupAB.ignore=false,这样a1,b2就有交互;(由大到小对应abc)
在这个例子中用到了InteractionGroup的一个树结构的特征.也就是任何InteractionGroup都有一个group属性说明这个group的父group是什么.这个group是一个列表所以支持
groupA.group = groupAB;
groupA.group = groupAC;
这种多重赋值,意思就是groupA有两个父节点分别是groupAB和groupAC.
对于多次嵌套树结构,需要通过查找他们的最近共同祖先(MRCA)来确定是属于哪一个group的.这里拿官方手册上的例子好了.
Group1
/ |
/ Group2 Group3
/ | \ |
Body1 / Cmp1 |
/ \ / / \ |
Shp1 Shp2 Body2 Cmp2
| |
Shp3 Body3
|
Shp4
这是它们的原始结构关系,这里着重看看shape之间的关系.
shape4 | shape3 | shape2 | shape1 | |
shape4 | g3(单独) | 无共同组 | 无共同组 | 无共同组 |
shape3 | 无共同组 | g2 | g2 | g1 |
shape2 | 无共同组 | g2 | g2 | 同一刚体 |
shape1 | 无共同组 | g1 | 同一刚体 | g1 |
要确定两两shape的关系.
1:先要确定每个shape属于哪一个group,所以
Shp1依次往上递归得到碰到的第一个group是G1.
Shp2依次往上递归得到碰到的第一个group是G2.
Shp3依次往上递归得到碰到的第一个group是G2.
Shp4依次往上递归得到碰到的第一个group是G3.
2:结合这几个Group的关系就能确定最终得到的Group关系图:
Group1
/ \ Group3
Shp1 Group2 |
/ \ Shp4
Shp2 Shp3
Shp1和Shp2属于同一个刚体,所以他们是一起运动的也就不存在交互作用了.
MRCA(Shp1, Shp3) == Group1;
MRCA(Shp2, Shp3) == Group2;
Shp4是孤立的,所以不存在Shp1和Shp4之类的交互控制,所以Shp4和所有其他对象默认都是发生碰撞的.
在确定了各个Shape的MRCA之后就能很容易的看出他们的碰撞关系了.
比如
Group1.ignore = true && Group2.ignore = false就能得出:Shp1和Shp3不会交互,Shp2和Shp3会交互.由大到小对应shp4、shp3、shp2、shp1
Group1.ignore = false&& Group2.ignore = true就能得出:Shp1和Shp3会交互,Shp2和Shp3不会交互.由大到小对应shp4、shp3、shp2、shp1
总结
1:Filter是Shape的属性,在一开始就创建好了,Group是所有Interactor的属性,但默认是null的.需要自己new
2:创建的数量区别,filter很多,但是group是无限的
3:Filter有特定类型的Filter,比如Collision有对应的group和mask,Sensor又有对应的group和mask,但Group是不需要这么指定的.
4:Filter的操作更加底层,需要熟悉位运。
nape.dynamics.InteractionGroup的更多相关文章
- nape.dynamics.InteractionFilter
(转载http://tomyail.com/blog/1123) Nape定义了三种交互方式: Collision(碰撞) Sensor(感应) Fluid(浮力) 默认情况下两个物体只会发生Coll ...
- Nape 获取碰撞点加特效
package { import nape.phys.Body; import nape.shape.Shape; import nape.shape.Circle; import flash.dis ...
- Nape实现坐标旋转角度回弹
乒乓球以一个向量运动,碰到障碍后反弹以一个新的向量运动,如下图: 要实现回弹只需要求出向量v1,把向量v0取反,再旋转(a+b)度就可以得到向量v1. 向量取反: var v:vec2 = new V ...
- Dynamics CRM 2015-超大Solution导入问题
我们在将比较大的solution导入CRM的时候,经常会遇到超时的问题,这是因为CRM的本身的优化限制导致的,那么如何解决呢? 官方已经有了解决方案了. 在浏览完两种解决方法之后,我们要知道的是: 1 ...
- Dynamics CRM导出数据到Excel
原创地址:http://www.cnblogs.com/jfzhu/p/4276212.html 转载请注明出处 Pivot Table是微软BI的一个重要工具,所以这里讲一下Dynamics CRM ...
- Step by step Dynamics CRM 2011升级到Dynamics CRM 2013
原创地址:http://www.cnblogs.com/jfzhu/p/4018153.html 转载请注明出处 (一)检查Customizations 从2011升级到2013有一些legacy f ...
- Step by Step 创建一个新的Dynamics CRM Organization
原创地址:http://www.cnblogs.com/jfzhu/p/4012833.html 转载请注明出处 前面演示过如何安装Dynamics CRM 2013,参见<Step by st ...
- Step by step Dynamics CRM 2013安装
原创地址:http://www.cnblogs.com/jfzhu/p/4008391.html 转载请注明出处 SQL Server可以与CRM装在同一台计算机上,也可安装在不同的计算机上.演示 ...
- Session for SSRS Report of Microsoft Dynamics AX
Session for SSRS Report of Microsoft Dynamics AX 版权声明:本文为博主原创文章,未经博主允许不得转载. Contract •A data contrac ...
随机推荐
- 条件与(&&)和逻辑与(&)以及条件或(||)和逻辑或(|)区别
条件与(&&)和逻辑与(&)以及条件或(||)和逻辑或(|)区别在于它们的运算结果是不相同的. 条件与(&&)和条件或(||)采用的是所谓的"短路规则 ...
- WinAPI——钩子函数大全
SetWindowsHookEx 函数功能:该函数将一个应用程序定义的挂钩处理过程安装到挂钩链中去,您可以通过安装挂钩处理过程来对系统的某些类型事件进行监控,这些事件与某个特定的线程或系统中的所有事件 ...
- Codeforces Round #228 (Div. 2) C. Fox and Box Accumulation(贪心)
题目:http://codeforces.com/contest/389/problem/C 题意:给n个箱子,给n个箱子所能承受的重量,每个箱子的重量为1: 很简单的贪心,比赛的时候没想出来.... ...
- 对同一个项目下的多个数据库Context进行迁移Migrations
PM> Enable-Migrations -MigrationsDirectory "Migrations\ContextA" -ContextTypeName MyPro ...
- 51nod水题记
妈呀51nod已经刷不动了又开始跟bzoj一样总是得看题解了...那么发一下总结吧... 1051:最大子矩阵 #include<cstdio> #include<cstring&g ...
- poj2752 水题
又2b了一次…… var s:ansistring; ans,pre:..] of longint; i,k,tot:longint; procedure main; begin pre[]:=;k: ...
- 使用Zxing实现扫二维码描
1.集成Zxing.bar 2.复制代码到项目中 3.修改 MipacActivityCapture.java 的扫描结果方法 handleDecode() /** * 处理扫描结果,实现活动页面跳 ...
- JAVA分布式事务原理及应用
JTA(Java Transaction API)允许应用程序执行分布式事务处理--在两个或多个网络计算机资源上访问并且更新数据.JDBC驱动程序的JTA支持极大地增强了数据访问能力. 本文的目的是要 ...
- 【转】如何下载并编译Android4.0内核源码goldfish(图文)
原文网址:http://blog.csdn.net/flydream0/article/details/7070392 关于如何下载Android4.0源码,请查看我的博客内另一篇文章(同样是图文教程 ...
- jquery的一些select操作小记
添加option $("#ID option").each(function(){ if($(this).val() == 111){ $(this).remove(); } }) ...