#include "acts.h" using namespace cocos2d; using namespace cocostudio; IMPLEMENT_CLASS_INFO(PlayMusic) PlayMusic::PlayMusic(void) :_nTag(-1) { } PlayMusic::~PlayMusic(void) { } bool PlayMusic::init() { return true; } void PlayMusic::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ComAudio *audio = (ComAudio*)(pNode->getComponent(_comName.c_str())); CC_BREAK_IF(audio == nullptr); if (_nType == 0) { audio->playBackgroundMusic(); } else if (_nType == 1) { audio->playEffect(); } } while (0); } void PlayMusic::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "componentName") { _comName = DICTOOL->getStringValue_json(subDict, "value"); continue; } else if (key == "type") { _nType = DICTOOL->getIntValue_json(subDict, "value"); continue; } } } void PlayMusic::removeAll() { } IMPLEMENT_CLASS_INFO(TMoveTo) TMoveTo::TMoveTo(void) :_nTag(-1) ,_fDuration(0.0f) { } TMoveTo::~TMoveTo(void) { } bool TMoveTo::init() { return true; } void TMoveTo::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionTo = MoveTo::create(_fDuration, _pos); CC_BREAK_IF(actionTo == nullptr); pNode->runAction(actionTo); } while (0); } void TMoveTo::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "x") { _pos.x = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "y") { _pos.y = DICTOOL->getIntValue_json(subDict, "value"); continue; } } } void TMoveTo::removeAll() { } IMPLEMENT_CLASS_INFO(TMoveBy) TMoveBy::TMoveBy(void) :_nTag(-1) ,_fDuration(0.0f) ,_bReverse(false) { } TMoveBy::~TMoveBy(void) { } bool TMoveBy::init() { return true; } void TMoveBy::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionBy = MoveBy::create(_fDuration, _pos); CC_BREAK_IF(actionBy == nullptr); if (_bReverse == true) { ActionInterval* actionByBack = actionBy->reverse(); pNode->runAction( CCSequence::create(actionBy, actionByBack, nullptr)); } else { pNode->runAction(actionBy); } } while (0); } void TMoveBy::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "x") { _pos.x = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "y") { _pos.y = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "IsReverse") { _bReverse = (bool)(DICTOOL->getIntValue_json(subDict, "value")); continue; } } } void TMoveBy::removeAll() { CCLOG("TMoveBy::removeAll"); } IMPLEMENT_CLASS_INFO(TRotateTo) TRotateTo::TRotateTo(void) : _nTag(-1) , _fDuration(0.0f) , _fDeltaAngle(0.0f) { } TRotateTo::~TRotateTo(void) { } bool TRotateTo::init() { return true; } void TRotateTo::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionTo = RotateTo::create(_fDuration, _fDeltaAngle); CC_BREAK_IF(actionTo == nullptr); pNode->runAction(actionTo); } while (0); } void TRotateTo::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "DeltaAngle") { _fDeltaAngle = DICTOOL->getFloatValue_json(subDict, "value"); continue; } } } void TRotateTo::removeAll() { CCLOG("TRotateTo::removeAll"); } IMPLEMENT_CLASS_INFO(TRotateBy) TRotateBy::TRotateBy(void) : _nTag(-1) , _fDuration(0.0f) , _fDeltaAngle(0.0f) , _bReverse(false) { } TRotateBy::~TRotateBy(void) { } bool TRotateBy::init() { return true; } void TRotateBy::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionBy = RotateBy::create(_fDuration, _fDeltaAngle); CC_BREAK_IF(actionBy == nullptr); if (_bReverse == true) { ActionInterval* actionByBack = actionBy->reverse(); pNode->runAction( Sequence::create(actionBy, actionByBack, nullptr)); } else { pNode->runAction(actionBy); } } while (0); } void TRotateBy::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "DeltaAngle") { _fDeltaAngle = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "IsReverse") { _bReverse = (int)(DICTOOL->getIntValue_json(subDict, "value")); continue; } } } void TRotateBy::removeAll() { CCLOG("TRotateBy::removeAll"); } IMPLEMENT_CLASS_INFO(TScaleTo) TScaleTo::TScaleTo(void) : _nTag(-1) , _fDuration(0.0f) { } TScaleTo::~TScaleTo(void) { } bool TScaleTo::init() { return true; } void TScaleTo::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionTo = ScaleTo::create(_fDuration, _scale.x, _scale.y); CC_BREAK_IF(actionTo == nullptr); pNode->runAction(actionTo); } while (0); } void TScaleTo::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "ScaleX") { _scale.x = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "ScaleY") { _scale.y = DICTOOL->getFloatValue_json(subDict, "value"); continue; } } } void TScaleTo::removeAll() { CCLOG("TScaleTo::removeAll"); } IMPLEMENT_CLASS_INFO(TScaleBy) TScaleBy::TScaleBy(void) : _nTag(-1) , _fDuration(0.0f) , _bReverse(false) { } TScaleBy::~TScaleBy(void) { } bool TScaleBy::init() { return true; } void TScaleBy::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionBy = ScaleBy::create(_fDuration, _scale.x, _scale.y); CC_BREAK_IF(actionBy == nullptr); if (_bReverse == true) { ActionInterval* actionByBack = actionBy->reverse(); pNode->runAction(Sequence::create(actionBy, actionByBack, nullptr)); } else { pNode->runAction(actionBy); } } while (0); } void TScaleBy::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "ScaleX") { _scale.x = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "ScaleY") { _scale.y = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "IsReverse") { _bReverse = (bool)(DICTOOL->getIntValue_json(subDict, "value")); continue; } } } void TScaleBy::removeAll() { CCLOG("TScaleBy::removeAll"); } IMPLEMENT_CLASS_INFO(TSkewTo) TSkewTo::TSkewTo(void) : _nTag(-1) , _fDuration(0.0f) { } TSkewTo::~TSkewTo(void) { } bool TSkewTo::init() { return true; } void TSkewTo::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionTo = SkewTo::create(_fDuration, _skew.x, _skew.y); CC_BREAK_IF(actionTo == nullptr); pNode->runAction(actionTo); } while (0); } void TSkewTo::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "SkewX") { _skew.x = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "SkewY") { _skew.y = DICTOOL->getFloatValue_json(subDict, "value"); continue; } } } void TSkewTo::removeAll() { CCLOG("TSkewTo::removeAll"); } IMPLEMENT_CLASS_INFO(TSkewBy) TSkewBy::TSkewBy(void) : _nTag(-1) , _fDuration(0.0f) , _bReverse(false) { } TSkewBy::~TSkewBy(void) { } bool TSkewBy::init() { return true; } void TSkewBy::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ActionInterval* actionBy = SkewBy::create(_fDuration, _skew.x, _skew.y); CC_BREAK_IF(actionBy == nullptr); if (_bReverse == true) { ActionInterval* actionByBack = actionBy->reverse(); pNode->runAction(Sequence::create(actionBy, actionByBack, nullptr)); } else { pNode->runAction(actionBy); } } while (0); } void TSkewBy::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "Duration") { _fDuration = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "SKewX") { _skew.x = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "SKewY") { _skew.y = DICTOOL->getFloatValue_json(subDict, "value"); continue; } else if (key == "IsReverse") { _bReverse = (bool)(DICTOOL->getIntValue_json(subDict, "value")); } } } void TSkewBy::removeAll() { CCLOG("TSkewBy::removeAll"); } IMPLEMENT_CLASS_INFO(TriggerState) TriggerState::TriggerState(void) :_nID(-1) ,_nState(0) { } TriggerState::~TriggerState(void) { } bool TriggerState::init() { return true; } void TriggerState::done() { TriggerObj *obj = TriggerMng::getInstance()->getTriggerObj(_nID); if (obj != nullptr) { if (_nState == 0) { obj->setEnabled(false); } else if (_nState == 1) { obj->setEnabled(true); } else if (_nState == 2) { TriggerMng::getInstance()->removeTriggerObj(_nID); } } } void TriggerState::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "ID") { _nID = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "State") { _nState = DICTOOL->getIntValue_json(subDict, "value"); continue; } } } void TriggerState::removeAll() { CCLOG("TriggerState::removeAll"); } IMPLEMENT_CLASS_INFO(ArmaturePlayAction) ArmaturePlayAction::ArmaturePlayAction(void) : _nTag(-1) { } ArmaturePlayAction::~ArmaturePlayAction(void) { } bool ArmaturePlayAction::init() { return true; } void ArmaturePlayAction::done() { do { Node *pNode = SceneReader::getInstance()->getNodeByTag(_nTag); CC_BREAK_IF(pNode == nullptr); ComRender *pRender = (ComRender*)(pNode->getComponent(_ComName.c_str())); CC_BREAK_IF(pRender == nullptr); Armature *pAr = (Armature *)(pRender->getNode()); CC_BREAK_IF(pAr == nullptr); pAr->getAnimation()->play(_aniname.c_str()); } while (0); } void ArmaturePlayAction::serialize(const rapidjson::Value &val) { int count = DICTOOL->getArrayCount_json(val, "dataitems"); for (int i = 0; i < count; ++i) { const rapidjson::Value &subDict = DICTOOL->getSubDictionary_json(val, "dataitems", i); std::string key = DICTOOL->getStringValue_json(subDict, "key"); if (key == "Tag") { _nTag = DICTOOL->getIntValue_json(subDict, "value"); continue; } else if (key == "componentName") { _ComName = DICTOOL->getStringValue_json(subDict, "value"); continue; } else if (key == "AnimationName") { _aniname = DICTOOL->getStringValue_json(subDict, "value"); continue; } } } void ArmaturePlayAction::removeAll() { CCLOG("ArmaturePlayAction::removeAll"); }