2021-12-28 21:00:45 +08:00
|
|
|
|
/****************************************************************************
|
2019-11-23 20:27:39 +08:00
|
|
|
|
Copyright (c) 2013 cocos2d-x.org
|
|
|
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
|
THE SOFTWARE.
|
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
|
|
#ifndef __CCTIMELINE_ACTION_H__
|
|
|
|
|
#define __CCTIMELINE_ACTION_H__
|
|
|
|
|
|
2020-10-21 10:12:00 +08:00
|
|
|
|
#include "ActionTimeline/CCTimeLine.h"
|
|
|
|
|
#include "ActionTimeline/CCActionTimelineData.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
#include "base/CCProtocols.h"
|
2020-10-21 10:12:00 +08:00
|
|
|
|
#include "CocosStudioExport.h"
|
2019-11-23 20:27:39 +08:00
|
|
|
|
#include "2d/CCAction.h"
|
|
|
|
|
|
|
|
|
|
NS_TIMELINE_BEGIN
|
|
|
|
|
|
|
|
|
|
typedef struct AnimationInfo
|
|
|
|
|
{
|
2021-12-25 10:04:45 +08:00
|
|
|
|
AnimationInfo() : startIndex(0), endIndex(0) {}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
2021-12-28 21:00:45 +08:00
|
|
|
|
AnimationInfo(const std::string& otherName, int otherStartIndex, int otherEndIndex)
|
2021-12-25 10:04:45 +08:00
|
|
|
|
: name(otherName), startIndex(otherStartIndex), endIndex(otherEndIndex)
|
|
|
|
|
{}
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
|
|
std::string name;
|
|
|
|
|
int startIndex;
|
|
|
|
|
int endIndex;
|
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
|
// need set call back before clip added to ActionTimeline
|
|
|
|
|
// or see @ActionTimeline::setAnimationEndCallBack
|
2019-11-23 20:27:39 +08:00
|
|
|
|
std::function<void()> clipEndCallBack;
|
|
|
|
|
} AnimationClip;
|
|
|
|
|
|
2020-10-17 16:32:16 +08:00
|
|
|
|
#if 0
|
|
|
|
|
class CCS_DLL ActionTimelineData : public cocos2d::Ref
|
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
static ActionTimelineData* create(int actionTag);
|
|
|
|
|
|
|
|
|
|
virtual void setActionTag(int actionTag) { _actionTag = actionTag; }
|
|
|
|
|
virtual int getActionTag() const { return _actionTag; }
|
|
|
|
|
CC_CONSTRUCTOR_ACCESS:
|
|
|
|
|
ActionTimelineData();
|
|
|
|
|
virtual bool init(int actionTag);
|
|
|
|
|
protected:
|
|
|
|
|
int _actionTag;
|
|
|
|
|
};
|
|
|
|
|
#endif
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
2020-10-17 16:32:16 +08:00
|
|
|
|
class CCS_DLL ActionTimeline : public cocos2d::Action, public cocos2d::PlayableProtocol
|
2019-11-23 20:27:39 +08:00
|
|
|
|
{
|
|
|
|
|
public:
|
|
|
|
|
friend class Frame;
|
|
|
|
|
|
|
|
|
|
static ActionTimeline* create();
|
|
|
|
|
|
|
|
|
|
ActionTimeline();
|
|
|
|
|
virtual ~ActionTimeline();
|
|
|
|
|
|
|
|
|
|
virtual void play(std::string animationName, bool loop);
|
|
|
|
|
|
|
|
|
|
virtual bool init();
|
|
|
|
|
|
|
|
|
|
/** Goto the specified frame index, and start playing from this index.
|
|
|
|
|
* @param startIndex The animation will play from this index.
|
|
|
|
|
*/
|
|
|
|
|
virtual void gotoFrameAndPlay(int startIndex);
|
|
|
|
|
|
|
|
|
|
/** Goto the specified frame index, and start playing from this index.
|
|
|
|
|
* @param startIndex The animation will play from this index.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
* @param loop Whether or not the animation need loop.
|
2019-11-23 20:27:39 +08:00
|
|
|
|
*/
|
|
|
|
|
virtual void gotoFrameAndPlay(int startIndex, bool loop);
|
|
|
|
|
|
|
|
|
|
/** Goto the specified frame index, and start playing from start index, end at end index.
|
|
|
|
|
* @param startIndex The animation will play from this index.
|
|
|
|
|
* @param endIndex The animation will end at this index.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
* @param loop Whether or not the animation need loop.
|
2019-11-23 20:27:39 +08:00
|
|
|
|
*/
|
|
|
|
|
virtual void gotoFrameAndPlay(int startIndex, int endIndex, bool loop);
|
|
|
|
|
|
|
|
|
|
/** Goto the specified frame index, and start playing from start index, end at end index.
|
|
|
|
|
* @param startIndex The animation will play from this index.
|
|
|
|
|
* @param endIndex The animation will end at this index.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
* @param currentFrameIndex set current frame index.
|
|
|
|
|
* @param loop Whether or not the animation need loop.
|
2019-11-23 20:27:39 +08:00
|
|
|
|
*/
|
|
|
|
|
virtual void gotoFrameAndPlay(int startIndex, int endIndex, int currentFrameIndex, bool loop);
|
|
|
|
|
|
|
|
|
|
/** Goto the specified frame index, and pause at this index.
|
|
|
|
|
* @param startIndex The animation will pause at this index.
|
|
|
|
|
*/
|
|
|
|
|
virtual void gotoFrameAndPause(int startIndex);
|
|
|
|
|
|
|
|
|
|
/** Pause the animation. */
|
|
|
|
|
virtual void pause();
|
|
|
|
|
/** Resume the animation. */
|
|
|
|
|
virtual void resume();
|
|
|
|
|
|
|
|
|
|
/** Whether or not Action is playing. */
|
|
|
|
|
virtual bool isPlaying() const;
|
|
|
|
|
|
|
|
|
|
/** Set the animation speed, this will speed up or slow down the speed. */
|
2021-12-25 10:04:45 +08:00
|
|
|
|
virtual void setTimeSpeed(float speed) { _timeSpeed = speed; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
/** Get current animation speed. */
|
|
|
|
|
virtual float getTimeSpeed() const { return _timeSpeed; }
|
|
|
|
|
|
|
|
|
|
/** duration of the whole action*/
|
|
|
|
|
virtual void setDuration(int duration) { _duration = duration; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
virtual int getDuration() const { return _duration; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
|
|
/** Start frame index of this action*/
|
|
|
|
|
virtual int getStartFrame() const { return _startFrame; }
|
|
|
|
|
|
|
|
|
|
/** End frame of this action.
|
2021-12-25 10:04:45 +08:00
|
|
|
|
* When action play to this frame, if action is not loop, then it will stop,
|
|
|
|
|
* or it will play from start frame again. */
|
|
|
|
|
virtual int getEndFrame() const { return _endFrame; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
|
|
/** Set current frame index, this will cause action plays to this frame. */
|
|
|
|
|
virtual void setCurrentFrame(int frameIndex);
|
|
|
|
|
/** Get current frame. */
|
2021-12-25 10:04:45 +08:00
|
|
|
|
virtual int getCurrentFrame() const { return _currentFrame; }
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
|
|
/** add Timeline to ActionTimeline */
|
|
|
|
|
virtual void addTimeline(Timeline* timeline);
|
|
|
|
|
virtual void removeTimeline(Timeline* timeline);
|
|
|
|
|
|
|
|
|
|
virtual const cocos2d::Vector<Timeline*>& getTimelines() const { return _timelineList; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
|
/** AnimationInfo*/
|
|
|
|
|
virtual void addAnimationInfo(const AnimationInfo& animationInfo);
|
|
|
|
|
virtual void removeAnimationInfo(std::string animationName);
|
2021-12-28 21:00:45 +08:00
|
|
|
|
virtual bool IsAnimationInfoExists(const std::string& animationName);
|
|
|
|
|
virtual const AnimationInfo& getAnimationInfo(const std::string& animationName);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
/**add a frame end call back to animation's end frame
|
|
|
|
|
* @param animationName @addFrameEndCallFunc, make the animationName as funcKey
|
|
|
|
|
* @param func the callback function
|
|
|
|
|
*/
|
|
|
|
|
virtual void setAnimationEndCallFunc(const std::string animationName, std::function<void()> func);
|
|
|
|
|
|
|
|
|
|
/** Set ActionTimeline's frame event callback function */
|
2021-12-25 10:04:45 +08:00
|
|
|
|
void setFrameEventCallFunc(std::function<void(Frame*)> listener);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
void clearFrameEventCallFunc();
|
|
|
|
|
|
|
|
|
|
/** Last frame callback will call when arriving last frame */
|
|
|
|
|
void setLastFrameCallFunc(std::function<void()> listener);
|
|
|
|
|
void clearLastFrameCallFunc();
|
|
|
|
|
|
|
|
|
|
/** add a callback function after played frameIndex
|
|
|
|
|
* @param frameIndex the frame index call back after
|
|
|
|
|
* @param funcKey for identity the callback function
|
|
|
|
|
* @param func the callback function
|
|
|
|
|
*/
|
2021-12-28 21:00:45 +08:00
|
|
|
|
virtual void addFrameEndCallFunc(int frameIndex, const std::string& funcKey, std::function<void()> func);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
// remove callback function after frameIndex which identified with funcKey
|
2021-12-28 21:00:45 +08:00
|
|
|
|
virtual void removeFrameEndCallFunc(int frameIndex, const std::string& funcKey);
|
2019-11-23 20:27:39 +08:00
|
|
|
|
// clear callback functions after frameIndex
|
|
|
|
|
virtual void removeFrameEndCallFuncs(int frameIndex);
|
|
|
|
|
// clear all the callback functions after frameIndexs in this actiontimeline
|
|
|
|
|
virtual void clearFrameEndCallFuncs();
|
|
|
|
|
|
|
|
|
|
/** Inherit from Action. */
|
|
|
|
|
|
|
|
|
|
/** Returns a clone of ActionTimeline */
|
2021-12-25 10:04:45 +08:00
|
|
|
|
virtual ActionTimeline* clone() const override;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
|
/** Returns a reverse of ActionTimeline.
|
2019-11-23 20:27:39 +08:00
|
|
|
|
* Not implement yet.
|
|
|
|
|
*/
|
|
|
|
|
virtual ActionTimeline* reverse() const override { return nullptr; }
|
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
|
virtual void step(float delta) override;
|
|
|
|
|
virtual void startWithTarget(cocos2d::Node* target) override;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
virtual bool isDone() const override { return false; }
|
2021-12-25 10:04:45 +08:00
|
|
|
|
|
2019-11-23 20:27:39 +08:00
|
|
|
|
/// @{
|
|
|
|
|
/// @name implement Playable Protocol
|
|
|
|
|
virtual void start() override;
|
|
|
|
|
virtual void stop() override;
|
|
|
|
|
/// @} end of PlayableProtocol
|
|
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
virtual void gotoFrame(int frameIndex);
|
|
|
|
|
virtual void stepToFrame(int frameIndex);
|
|
|
|
|
|
|
|
|
|
// emit call back after frameIndex played
|
|
|
|
|
virtual void emitFrameEndCallFuncs(int frameIndex);
|
|
|
|
|
|
|
|
|
|
/** emit frame event, call it when enter a frame*/
|
|
|
|
|
virtual void emitFrameEvent(Frame* frame);
|
|
|
|
|
|
|
|
|
|
std::map<int, cocos2d::Vector<Timeline*>> _timelineMap;
|
|
|
|
|
cocos2d::Vector<Timeline*> _timelineList;
|
|
|
|
|
|
2021-12-25 10:04:45 +08:00
|
|
|
|
int _duration;
|
|
|
|
|
double _time;
|
|
|
|
|
float _timeSpeed;
|
|
|
|
|
float _frameInternal;
|
|
|
|
|
bool _playing;
|
|
|
|
|
int _currentFrame;
|
|
|
|
|
int _startFrame;
|
|
|
|
|
int _endFrame;
|
|
|
|
|
bool _loop;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
|
|
|
|
|
std::function<void(Frame*)> _frameEventListener;
|
|
|
|
|
std::function<void()> _lastFrameListener;
|
2021-12-28 21:00:45 +08:00
|
|
|
|
std::map<int, std::map<std::string, std::function<void()>>> _frameEndCallFuncs;
|
|
|
|
|
std::map<std::string, AnimationInfo> _animationInfos;
|
2019-11-23 20:27:39 +08:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
NS_TIMELINE_END
|
|
|
|
|
|
|
|
|
|
#endif /*__CCTIMELINE_ACTION_H__*/
|