axmol/samples/Cpp/TestCpp/Classes/ExtensionsTest/CocoStudioSceneTest/TriggerCode/acts.cpp

759 lines
14 KiB
C++
Executable File

#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");
}