Away3D 4.1.4 中实现骨骼绑定
骨骼的绑定归根结底就是将目标骨骼的位置以及旋转数据,同步给要绑定的显示对象。
先来看BindingTag.as
package away3d.entities{ import away3d.arcane; import away3d.animators.SkeletonAnimator; import away3d.animators.data.JointPose; import away3d.containers.ObjectContainer3D; use namespace arcane public class BindingTag extends ObjectContainer3D { private var _skeletonAnimator:SkeletonAnimator; private var _skeletonIndex:int; /** * * @param skeletonAnimator * @param skeletonIndex 要绑定的骨骼索引 * */ public function BindingTag(skeletonAnimator:SkeletonAnimator, skeletonIndex:int) { super(); _skeletonAnimator = skeletonAnimator; _skeletonIndex = skeletonIndex; } public function notifyBindingTransformChange():void { invalidateTransform(); } override protected function updateSceneTransform():void { if (_parent) { var jointPoses:Vector.<JointPose> = _skeletonAnimator.globalPose.jointPoses; if(jointPoses && jointPoses.length) { //取到骨骼数据并同步给当前对象 _sceneTransform.copyFrom( jointPoses[_skeletonIndex].toMatrix3D() ); _sceneTransform.append( _parent.sceneTransform ); _sceneTransform.prepend(transform); } } _sceneTransformDirty = false; } override public function dispose():void { //TODO: } }}BindingTag即是绑定在指定骨骼上的容器,假如你想绑定武器或特效,
只要将他们addChild到该BindingTag就可以了。
下面看怎样将BindingTag集成到Away3D里面。
为AnimatorBase添加Exit_Frame事件,至于为什么要加这个Exit_Frame事件,后面再来解释。
分别在start()以及stop()方法里添加、移除Exit_Frame事件
|
1
2
3
4
5
6
7
8
9
10
|
if(!_broadcaster.hasEventListener(Event.EXIT_FRAME)) _broadcaster.addEventListener(Event.ENTER_FRAME, onExitFrame);if(_broadcaster.hasEventListener(Event.EXIT_FRAME)) _broadcaster.removeEventListener(Event.EXIT_FRAME, onExitFrame);protected function onExitFrame(event:Event):void{ //Override} |
为SkeletonAnimator添加addBindingTagByName,addBindingTagByIndex方法
以及复写onExitFrame
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
/** * 绑定至通过名字指定的骨骼上 * @param boneName * @return * */ public function addBindingTagByName(boneName:String):BindingTag { var boneIndex : int = globalPose.jointPoseIndexFromName(boneName); if(boneIndex<0)//骨骼不存在 return null; return addBindingTagByIndex(boneIndex); } /** * 绑定至通过骨骼索引指定的骨骼上 * @param boneIndex * @return * */ public function addBindingTagByIndex(boneIndex:int):BindingTag { var bindingTag:BindingTag = new BindingTag(this, boneIndex); for(var i:int = 0; i < _owners.length; i++) { _owners[i].addChild(bindingTag);//将bindingTag添加至骨骼对应的Mesh } if(!_bindingTags)_bindingTags = new Vector.<BindingTag>(); _bindingTags.push(bindingTag); return bindingTag; } override protected function onExitFrame(event:Event):void { if(_bindingTags && _bindingTags.length) { for (var i:int = 0; i < _bindingTags.length; i++) { _bindingTags[i].notifyBindingTransformChange(); } } } |
到这里就已经代码已经都修改添加完成了,下面来说下为什么要在Exit_Frame事件中通知
BindingTag更新.骨骼的更新是在skeletonAnimatior的updateGlobalProperties方法中
进行的,他的更新是在引擎执行完traverse后执行的,所以为了保证每次执行traverse时都能让
BindingTag根据骨骼更新,需在Exit_Frame时通知,否则BindingTag的更新总会延迟一帧,
从而导致跟随出现错位问题。
Away3D 4.1.4 中实现骨骼绑定的更多相关文章
- jQuery中的事件绑定方法
在jQuery中,事件绑定方法大致有四种:bind(),live(), delegate(),和on(). 那么在工作中应该如何选择呢?首先要了解四种方法的区别和各自的特点. 在了解这些之前,首先要知 ...
- MVC中Action参数绑定的过程
一.题外话 上一篇:MVC中Action的执行过程 ControllerContext 封装有了与指定的 RouteBase 和 ControllerBase 实例匹配的 HTTP 请求的信息. 二. ...
- activity中实现Spinner绑定
(1)须要一个基本的布局文件activity_main <RelativeLayout xmlns:android="http://schemas.android.com/apk/re ...
- Jquery中的事件绑定$("#btn").bind("click",function(){ })
Jquery中的事件绑定:$("#btn").bind("click",function(){ }) 由于每次都这么调用太麻烦,所以jquery就用$(&qu ...
- Asp.net Mvc 中的模型绑定
asp.net mvc中的模型绑定可以在提交http请求的时候,进行数据的映射. 1.没有模型绑定的时候 public ActionResult Example0() { ) { string id ...
- AngularJS中数据双向绑定(two-way data-binding)
1.切换工作目录 git checkout step-4 #切换分支,切换到第4步 npm start #启动项目 2.代码 app/index.html Search: <input ng-m ...
- jQuery 中的事件绑定
一.事件概念 和数据库中的触发器一样,当操作了数据的时候会引发对应的触发器程序执行 一样,JS 中的事件就是对用户特定的行为作出相应的响应的过程,其实上就是浏览器 监听到用户的某些行为的时候会执行对应 ...
- js中this的绑定规则及优先级
一. this绑定规则 函数调用位置决定了this的绑定对象,必须找到正确的调用位置判断需要应用下面四条规则中的哪一条. 1.1 默认绑定 看下面代码: function foo() { cons ...
- React中的“双向绑定”
概述 React并不是一个MVVM框架,其实它连一个框架都算不上,它只是一个库,但是react生态系统中的flux却是一个MVVM框架,所以我研究了一下flux官方实现中的"双向绑定&quo ...
随机推荐
- maven+jetty项目在tomcat部署
步骤1:项目打包 clean install 步骤二:拷贝war 包到tomcat下 步骤三:修改server.xml文件的端口 步骤四:启动tomcat,注意jetty的项目是不需要带项目名的,To ...
- (JAVA)从零开始之--对象输入输出流ObjectInputStream、ObjectOutputStream(对象序列化与反序列化)
对象的输入输出流 : 主要的作用是用于写入对象信息与读取对象信息. 对象信息一旦写到文件上那么对象的信息就可以做到持久化了 对象的输出流: ObjectOutputStream 对象的输入流: Ob ...
- Magento 编译 php5.6.21 命令
./configure '--prefix=/alidata/server/php' '--enable-opcache' '--with-config-file-path=/alidata/ser ...
- Python Tutorial 学习(六)--Modules
6. Modules 当你退出Python的shell模式然后又重新进入的时候,之前定义的变量,函数等都会没有了. 因此, 推荐的做法是将这些东西写入文件,并在适当的时候调用获取他们. 这就是为人所知 ...
- 【转】近百个Android优秀开源项目
近百个Android优秀开源项目 Android开发又将带来新一轮热潮,很多开发者都投入到这个浪潮中去了,创造了许许多多相当优秀的应用.其中也有许许多多的开发者提供了应用开源项目,贡献出他们的智慧 ...
- BZOJ 1072 排列
Description 给一个数字串\(s\)和正整数\(d\), 统计\(s\)有多少种不同的排列能被\(d\)整除(可以有前导\(0\)).例如\(123434\)有\(90\)种排列能被\(2\ ...
- Unity NGUI 网络斗地主 -界面制作
Unity NGUI 网络斗地主 -界面制作 源文件在群(63438968群共享!) @灰太龙 这一节说一下NGUI的界面摆放,并且教会大家使用NGUI的自适应功能! 在这里感谢@Gamer,是他给我 ...
- Tomcat error: A child container failed during start
Tomcat error: A child container failed during start java.lang.NoClassDefFoundError: org/quartz/Sched ...
- yii分页
关于分页有一个重要的类CPagination. CPagination represents information relevant to pagination. http://www.yiifra ...
- Powerful Regex
Online test Regex http://rubular.com An example src="http:\/\/localhost:3000\/preveiw-tool\/iph ...