Cocos Creator控制龙骨DragonBones动画
前言
Cocos Creator要是用龙骨DragonBones动画,可以使用自带的组件:DragonBones组件: dragonBones.ArmatureDisplay
官方文档:https://docs.cocos.com/creator/manual/zh/components/dragonbones.html
接口文档:https://docs.cocos.com/creator/api/zh/modules/dragonBones.html
仔细看的话,会发现,这个组件只暴露了一些非常简单也很有限的接口,文档也写的过于简单。
如果要对龙骨动画进行精细化控制,则需要调用DragonBones库的接口,而这个库的接口是没有文档的。
DragonBones库的代码,在Cocos Creator的引擎代码中可以找到,然后可以从dragonBonse.d.ts文件里查看相应的接口。
这里整理一下相关的操作。
操作列表
1. 播放动画
术语
骨架 = Armatrue
动画 = Animation
通常一个龙骨项目包含多个Armature,而每个Armature可以包含多个Animation。
所以,一般来说,我们实际的需求是切换动画,而不是切换骨架。
接口
这个功能可以通过修改dragonBones.ArmatureDisplay组件的属性来实现:
-
指定骨架
dragonBones.ArmatureDisplay.armatureName = 骨架名称 -
播放该骨架下的动画
dragonBones.ArmatureDisplay.playAnimation("动作名", 循环次数);
参数
-1 表示使用配置文件中的默认值;
0 表示无限循环;
>0 表示循环次数
示例
@property(dragonBones.ArmatureDisplay)
display:dragonBones.ArmatureDisplay = null;
display.armatureName = "move";
display.playAnimation("跑", -1);
文档
https://docs.cocos.com/creator/api/zh/classes/ArmatureDisplay.html#armatureName
2. 中止动画
dragonBones.ArmatureDisplay组件并没有提供stop方法,只能去dragonBones库去找了。
在dragonBonse.d.ts文件中发现,dragonBones.Animation类有很多方法可以用。
接口
-
获取骨骼
dragonBones.ArmatureDisplay.armature() -
获取动画
dragonBones.ArmatureDisplay.armature().Animation
注意,这个方法返回的是dragonBones.Animation对象。
- 停止动画
dragonBones.Animation.stop("动画名")
参数
要停止的指定动画名,如果,不指定,则停止所有动画。
示例
// 终止所有的动作
display.armature().animation.stop();
3. 从动画中间开始播放
有时候,我们需要从动画的中间开始播放,这个功能也只能通过dragonBones.Animation对象来实现。
接口
-
从指定帧播放
gotoAndPlayByFrame(animationName: string, frame?: number, playTimes?: number): AnimationState | null; -
从指定时间播放
gotoAndPlayByTime(animationName: string, time?: number, playTimes?: number): AnimationState | null; -
从指定的百分比进度播放
gotoAndPlayByProgress(animationName: string, progress?: number, playTimes?: number): AnimationState | null;
示例
display.armature().animation.gotoAndPlayByFrame(animationName, nFrame, loop);
4. 根据事件中止动画
这个功能需要先监听指定动画事件,然后在事件处理方法中调用2.的中止方法。
dragonBones.ArmatureDisplay组件提供了事件监听方法
https://docs.cocos.com/creator/api/zh/classes/ArmatureDisplay.html#addeventlistener
接口
-
监听
dragonBones.ArmatureDisplay.addEventListener(eventType, callback, target) -
取消监听
dragonBones.ArmatureDisplay.removeEventListener(eventType, callback, target) -
事件列表
** 帧事件(需在龙骨动画里添加动画事件)
dragonBones.EventObject.FRAME_EVENT
** 动画循环播放完成一次。
dragonBones.EventObject.LOOP_COMPLETE
** 动画播放完成。
dragonBones.EventObject.COMPLETE
事件对象的细节,以及更多事件可以在ArmatureDisplay.js文件中找到。
/**
* !#en
* Animation start play.
* !#zh
* 动画开始播放。
*
* @event dragonBones.EventObject.START
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation loop play complete once.
* !#zh
* 动画循环播放完成一次。
*
* @event dragonBones.EventObject.LOOP_COMPLETE
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation play complete.
* !#zh
* 动画播放完成。
*
* @event dragonBones.EventObject.COMPLETE
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation fade in start.
* !#zh
* 动画淡入开始。
*
* @event dragonBones.EventObject.FADE_IN
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation fade in complete.
* !#zh
* 动画淡入完成。
*
* @event dragonBones.EventObject.FADE_IN_COMPLETE
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation fade out start.
* !#zh
* 动画淡出开始。
*
* @event dragonBones.EventObject.FADE_OUT
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation fade out complete.
* !#zh
* 动画淡出完成。
*
* @event dragonBones.EventObject.FADE_OUT_COMPLETE
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
*/
/**
* !#en
* Animation frame event.
* !#zh
* 动画帧事件。
*
* @event dragonBones.EventObject.FRAME_EVENT
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {String} [callback.event.name]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
* @param {dragonBones.Bone} [callback.event.bone]
* @param {dragonBones.Slot} [callback.event.slot]
*/
/**
* !#en
* Animation frame sound event.
* !#zh
* 动画帧声音事件。
*
* @event dragonBones.EventObject.SOUND_EVENT
* @param {String} type - A string representing the event type to listen for.
* @param {Function} callback - The callback that will be invoked when the event is dispatched.
* The callback is ignored if it is a duplicate (the callbacks are unique).
* @param {dragonBones.EventObject} [callback.event]
* @param {String} [callback.event.type]
* @param {String} [callback.event.name]
* @param {dragonBones.Armature} [callback.event.armature]
* @param {dragonBones.AnimationState} [callback.event.animationState]
* @param {dragonBones.Bone} [callback.event.bone]
* @param {dragonBones.Slot} [callback.event.slot]
*/
示例
// 监听
display.addEventListener(dragonBones.EventObject.FRAME_EVENT, this.onFrameEvent, this);
// 事件处理
onFrameEvent(evt){
if(this._stopEvent == evt.name){
evt.armature.animation.stop(this._currentAnimation);
this._stopEvent = undefined;
}
}