axmol/core/2d/CCActionInterval.cpp

2768 lines
60 KiB
C++
Raw Normal View History

/****************************************************************************
Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2010-2012 cocos2d-x.org
Copyright (c) 2011 Zynga Inc.
Copyright (c) 2013-2016 Chukong Technologies Inc.
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
2021-12-25 10:04:45 +08:00
https://axis-project.github.io/
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.
****************************************************************************/
#include "2d/CCActionInterval.h"
2014-09-10 07:50:02 +08:00
#include <stdarg.h>
#include "2d/CCSprite.h"
#include "2d/CCNode.h"
2014-08-26 18:19:28 +08:00
#include "2d/CCSpriteFrame.h"
#include "2d/CCActionInstant.h"
#include "base/CCDirector.h"
#include "base/CCEventCustom.h"
2014-08-26 18:19:28 +08:00
#include "base/CCEventDispatcher.h"
2014-09-10 07:50:02 +08:00
#include "platform/CCStdC.h"
#include "base/CCScriptSupport.h"
NS_AX_BEGIN
// Extra action for making a Sequence or Spawn when only adding one action to it.
class ExtraAction : public FiniteTimeAction
{
public:
static ExtraAction* create();
virtual ExtraAction* clone() const;
virtual ExtraAction* reverse() const;
virtual void update(float time);
virtual void step(float dt);
};
ExtraAction* ExtraAction::create()
{
2021-12-08 00:11:53 +08:00
ExtraAction* ret = new ExtraAction();
ret->autorelease();
return ret;
}
2014-05-28 17:41:34 +08:00
ExtraAction* ExtraAction::clone() const
{
// no copy constructor
return ExtraAction::create();
}
2014-05-28 17:41:34 +08:00
ExtraAction* ExtraAction::reverse() const
{
return ExtraAction::create();
}
2021-12-25 10:04:45 +08:00
void ExtraAction::update(float /*time*/) {}
2021-12-25 10:04:45 +08:00
void ExtraAction::step(float /*dt*/) {}
//
// IntervalAction
//
bool ActionInterval::initWithDuration(float d)
{
_duration = d;
2021-12-25 10:04:45 +08:00
_elapsed = 0;
_firstTick = true;
2021-12-25 10:04:45 +08:00
_done = false;
return true;
}
2021-12-25 10:04:45 +08:00
bool ActionInterval::sendUpdateEventToScript(float dt, Action* actionObject)
{
return false;
}
2014-05-28 17:41:34 +08:00
bool ActionInterval::isDone() const
{
return _done;
}
void ActionInterval::step(float dt)
{
if (_firstTick)
{
_firstTick = false;
2021-12-25 10:04:45 +08:00
_elapsed = 0;
}
else
{
_elapsed += dt;
}
2021-12-25 10:04:45 +08:00
float updateDt = std::max(0.0f, // needed for rewind. elapsed could be negative
std::min(1.0f, _elapsed / _duration));
if (sendUpdateEventToScript(updateDt, this))
return;
this->update(updateDt);
_done = _elapsed >= _duration;
}
void ActionInterval::setAmplitudeRate(float /*amp*/)
{
// Abstract class needs implementation
2022-07-16 10:43:05 +08:00
AXASSERT(0, "Subclass should implement this method!");
}
2014-05-28 17:41:34 +08:00
float ActionInterval::getAmplitudeRate()
{
// Abstract class needs implementation
2022-07-16 10:43:05 +08:00
AXASSERT(0, "Subclass should implement this method!");
return 0;
}
2021-12-25 10:04:45 +08:00
void ActionInterval::startWithTarget(Node* target)
{
FiniteTimeAction::startWithTarget(target);
2021-12-25 10:04:45 +08:00
_elapsed = 0.0f;
_firstTick = true;
2021-12-25 10:04:45 +08:00
_done = false;
}
//
// Sequence
//
2021-12-25 10:04:45 +08:00
Sequence* Sequence::createWithTwoActions(FiniteTimeAction* actionOne, FiniteTimeAction* actionTwo)
{
2021-12-25 10:04:45 +08:00
Sequence* sequence = new Sequence();
2021-12-08 00:11:53 +08:00
if (sequence->initWithTwoActions(actionOne, actionTwo))
{
sequence->autorelease();
return sequence;
}
2021-12-25 10:04:45 +08:00
delete sequence;
return nullptr;
}
2021-12-25 10:04:45 +08:00
Sequence* Sequence::create(FiniteTimeAction* action1, ...)
{
va_list params;
va_start(params, action1);
2021-12-25 10:04:45 +08:00
Sequence* ret = Sequence::createWithVariableList(action1, params);
2012-11-15 17:16:51 +08:00
va_end(params);
2021-12-25 10:04:45 +08:00
return ret;
2012-11-15 17:16:51 +08:00
}
2021-12-25 10:04:45 +08:00
Sequence* Sequence::createWithVariableList(FiniteTimeAction* action1, va_list args)
2012-11-15 17:16:51 +08:00
{
2021-12-25 10:04:45 +08:00
FiniteTimeAction* now;
FiniteTimeAction* prev = action1;
bool bOneAction = true;
while (action1)
{
now = va_arg(args, FiniteTimeAction*);
if (now)
{
2021-12-25 10:04:45 +08:00
prev = createWithTwoActions(prev, now);
bOneAction = false;
}
else
{
// If only one action is added to Sequence, make up a Sequence by adding a simplest finite time action.
if (bOneAction)
{
prev = createWithTwoActions(prev, ExtraAction::create());
}
break;
}
}
2021-12-25 10:04:45 +08:00
return ((Sequence*)prev);
}
Sequence* Sequence::create(const Vector<FiniteTimeAction*>& arrayOfActions)
{
2021-12-08 00:11:53 +08:00
Sequence* seq = new Sequence;
2021-12-25 10:04:45 +08:00
2021-12-08 00:11:53 +08:00
if (seq->init(arrayOfActions))
{
seq->autorelease();
return seq;
}
2021-12-25 10:04:45 +08:00
delete seq;
return nullptr;
}
bool Sequence::init(const Vector<FiniteTimeAction*>& arrayOfActions)
{
auto count = arrayOfActions.size();
if (count == 0)
return false;
if (count == 1)
return initWithTwoActions(arrayOfActions.at(0), ExtraAction::create());
// else size > 1
auto prev = arrayOfActions.at(0);
2021-12-25 10:04:45 +08:00
for (int i = 1; i < count - 1; ++i)
{
prev = createWithTwoActions(prev, arrayOfActions.at(i));
}
2021-12-25 10:04:45 +08:00
return initWithTwoActions(prev, arrayOfActions.at(count - 1));
}
2021-12-25 10:04:45 +08:00
bool Sequence::initWithTwoActions(FiniteTimeAction* actionOne, FiniteTimeAction* actionTwo)
{
2022-07-16 10:43:05 +08:00
AXASSERT(actionOne != nullptr, "actionOne can't be nullptr!");
AXASSERT(actionTwo != nullptr, "actionTwo can't be nullptr!");
if (actionOne == nullptr || actionTwo == nullptr)
{
log("Sequence::initWithTwoActions error: action is nullptr!!");
return false;
}
float d = actionOne->getDuration() + actionTwo->getDuration();
ActionInterval::initWithDuration(d);
_actions[0] = actionOne;
actionOne->retain();
_actions[1] = actionTwo;
actionTwo->retain();
return true;
}
bool Sequence::isDone() const
{
// fix issue #17884
if (dynamic_cast<ActionInstant*>(_actions[1]))
return (_done && _actions[1]->isDone());
else
return _done;
}
2014-05-28 17:41:34 +08:00
Sequence* Sequence::clone() const
{
// no copy constructor
if (_actions[0] && _actions[1])
{
return Sequence::create(_actions[0]->clone(), _actions[1]->clone(), nullptr);
2021-12-25 10:04:45 +08:00
}
else
{
return nullptr;
}
}
2021-12-25 10:04:45 +08:00
Sequence::Sequence() : _split(0)
{
_actions[0] = nullptr;
_actions[1] = nullptr;
}
Sequence::~Sequence()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_actions[0]);
AX_SAFE_RELEASE(_actions[1]);
}
2021-12-25 10:04:45 +08:00
void Sequence::startWithTarget(Node* target)
{
if (target == nullptr)
{
log("Sequence::startWithTarget error: target is nullptr!");
return;
}
if (_actions[0] == nullptr || _actions[1] == nullptr)
{
log("Sequence::startWithTarget error: _actions[0] or _actions[1] is nullptr!");
return;
}
if (_duration > FLT_EPSILON)
2021-12-25 10:04:45 +08:00
// fix #14936 - FLT_EPSILON (instant action) / very fast duration (0.001) leads to wrong split, that leads to
// call instant action few times
_split = _actions[0]->getDuration() > FLT_EPSILON ? _actions[0]->getDuration() / _duration : 0;
2021-12-25 10:04:45 +08:00
ActionInterval::startWithTarget(target);
_last = -1;
}
void Sequence::stop()
{
// Issue #1305
2021-12-25 10:04:45 +08:00
if (_last != -1 && _actions[_last])
{
_actions[_last]->stop();
}
ActionInterval::stop();
}
void Sequence::update(float t)
{
2021-12-25 10:04:45 +08:00
int found = 0;
2012-06-08 13:55:28 +08:00
float new_t = 0.0f;
2021-12-25 10:04:45 +08:00
if (t < _split)
{
// action[0]
found = 0;
2021-12-25 10:04:45 +08:00
if (_split != 0)
new_t = t / _split;
else
new_t = 1;
}
else
{
// action[1]
found = 1;
2021-12-25 10:04:45 +08:00
if (_split == 1)
new_t = 1;
else
2021-12-25 10:04:45 +08:00
new_t = (t - _split) / (1 - _split);
}
2021-12-25 10:04:45 +08:00
if (found == 1)
{
2021-12-25 10:04:45 +08:00
if (_last == -1)
{
// action[0] was skipped, execute it.
_actions[0]->startWithTarget(_target);
if (!(sendUpdateEventToScript(1.0f, _actions[0])))
_actions[0]->update(1.0f);
_actions[0]->stop();
}
2021-12-25 10:04:45 +08:00
else if (_last == 0)
{
// switching to action 1. stop action 0.
if (!(sendUpdateEventToScript(1.0f, _actions[0])))
_actions[0]->update(1.0f);
_actions[0]->stop();
}
}
2021-12-25 10:04:45 +08:00
else if (found == 0 && _last == 1)
{
// Reverse mode ?
// FIXME: Bug. this case doesn't contemplate when _last==-1, found=0 and in "reverse mode"
// since it will require a hack to know if an action is on reverse mode or not.
// "step" should be overridden, and the "reverseMode" value propagated to inner Sequences.
if (!(sendUpdateEventToScript(0, _actions[1])))
_actions[1]->update(0);
_actions[1]->stop();
}
// Last action found and it is done.
2021-12-25 10:04:45 +08:00
if (found == _last && _actions[found]->isDone())
{
return;
}
2012-11-15 17:16:51 +08:00
// Last action found and it is done
2021-12-25 10:04:45 +08:00
if (found != _last)
{
_actions[found]->startWithTarget(_target);
}
if (!(sendUpdateEventToScript(new_t, _actions[found])))
_actions[found]->update(new_t);
_last = found;
}
Sequence* Sequence::reverse() const
{
if (_actions[0] && _actions[1])
return Sequence::createWithTwoActions(_actions[1]->reverse(), _actions[0]->reverse());
else
return nullptr;
}
//
// Repeat
//
2021-12-25 10:04:45 +08:00
Repeat* Repeat::create(FiniteTimeAction* action, unsigned int times)
{
2021-12-08 00:11:53 +08:00
Repeat* repeat = new Repeat();
if (repeat->initWithAction(action, times))
{
repeat->autorelease();
return repeat;
}
delete repeat;
return nullptr;
}
2021-12-25 10:04:45 +08:00
bool Repeat::initWithAction(FiniteTimeAction* action, unsigned int times)
{
if (action && ActionInterval::initWithDuration(action->getDuration() * times))
{
2021-12-25 10:04:45 +08:00
_times = times;
_innerAction = action;
action->retain();
_actionInstant = dynamic_cast<ActionInstant*>(action) ? true : false;
2021-12-25 10:04:45 +08:00
// an instant action needs to be executed one time less in the update method since it uses startWithTarget to
// execute the action
// minggo: instant action doesn't execute action in Repeat::startWithTarget(), so comment it.
// if (_actionInstant)
// {
// _times -=1;
// }
_total = 0;
return true;
}
return false;
}
Repeat* Repeat::clone() const
{
// no copy constructor
return Repeat::create(_innerAction->clone(), _times);
}
Repeat::~Repeat()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_innerAction);
}
2021-12-25 10:04:45 +08:00
void Repeat::startWithTarget(Node* target)
{
2021-12-25 10:04:45 +08:00
_total = 0;
_nextDt = _innerAction->getDuration() / _duration;
ActionInterval::startWithTarget(target);
_innerAction->startWithTarget(target);
}
void Repeat::stop()
{
_innerAction->stop();
ActionInterval::stop();
}
2021-12-25 10:04:45 +08:00
// issue #80. Instead of hooking step:, hook update: since it can be called by any
// container action like Repeat, Sequence, Ease, etc..
void Repeat::update(float dt)
{
if (dt >= _nextDt)
{
while (dt >= _nextDt && _total < _times)
{
if (!(sendUpdateEventToScript(1.0f, _innerAction)))
_innerAction->update(1.0f);
_total++;
_innerAction->stop();
_innerAction->startWithTarget(_target);
2021-12-25 10:04:45 +08:00
_nextDt = _innerAction->getDuration() / _duration * (_total + 1);
}
// fix for issue #1288, incorrect end value of repeat
if (std::abs(dt - 1.0f) < FLT_EPSILON && _total < _times)
{
if (!(sendUpdateEventToScript(1.0f, _innerAction)))
_innerAction->update(1.0f);
2021-12-25 10:04:45 +08:00
_total++;
}
// don't set an instant action back or update it, it has no use because it has no duration
if (!_actionInstant)
{
if (_total == _times)
{
// minggo: inner action update is invoked above, don't have to invoke it here
2021-12-25 10:04:45 +08:00
// if (!(sendUpdateEventToScript(1, _innerAction)))
// _innerAction->update(1);
_innerAction->stop();
}
else
{
// issue #390 prevent jerk, use right update
2021-12-25 10:04:45 +08:00
if (!(sendUpdateEventToScript(dt - (_nextDt - _innerAction->getDuration() / _duration), _innerAction)))
_innerAction->update(dt - (_nextDt - _innerAction->getDuration() / _duration));
}
}
}
else
{
2021-12-25 10:04:45 +08:00
if (!(sendUpdateEventToScript(fmodf(dt * _times, 1.0f), _innerAction)))
_innerAction->update(fmodf(dt * _times, 1.0f));
}
}
bool Repeat::isDone() const
{
return _total == _times;
}
Repeat* Repeat::reverse() const
{
return Repeat::create(_innerAction->reverse(), _times);
}
//
// RepeatForever
//
RepeatForever::~RepeatForever()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_innerAction);
}
2021-12-25 10:04:45 +08:00
RepeatForever* RepeatForever::create(ActionInterval* action)
{
2021-12-25 10:04:45 +08:00
RepeatForever* ret = new RepeatForever();
2021-12-08 00:11:53 +08:00
if (ret->initWithAction(action))
{
ret->autorelease();
return ret;
}
2021-12-25 10:04:45 +08:00
delete ret;
return nullptr;
}
2021-12-25 10:04:45 +08:00
bool RepeatForever::initWithAction(ActionInterval* action)
{
2022-07-16 10:43:05 +08:00
AXASSERT(action != nullptr, "action can't be nullptr!");
if (action == nullptr)
{
log("RepeatForever::initWithAction error:action is nullptr!");
return false;
}
2021-12-25 10:04:45 +08:00
action->retain();
_innerAction = action;
2021-12-25 10:04:45 +08:00
return true;
}
2021-12-25 10:04:45 +08:00
RepeatForever* RepeatForever::clone() const
{
// no copy constructor
return RepeatForever::create(_innerAction->clone());
}
void RepeatForever::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_innerAction->startWithTarget(target);
}
void RepeatForever::step(float dt)
{
_innerAction->step(dt);
// only action interval should prevent jerk, issue #17808
if (_innerAction->isDone() && _innerAction->getDuration() > 0)
{
float diff = _innerAction->getElapsed() - _innerAction->getDuration();
if (diff > _innerAction->getDuration())
diff = fmodf(diff, _innerAction->getDuration());
_innerAction->startWithTarget(_target);
// to prevent jerk. cocos2d-iphone issue #390, 1247
_innerAction->step(0.0f);
_innerAction->step(diff);
}
}
bool RepeatForever::isDone() const
{
return false;
}
2021-12-25 10:04:45 +08:00
RepeatForever* RepeatForever::reverse() const
{
return RepeatForever::create(_innerAction->reverse());
}
//
// Spawn
//
2021-12-25 10:04:45 +08:00
Spawn* Spawn::create(FiniteTimeAction* action1, ...)
{
va_list params;
va_start(params, action1);
2021-12-25 10:04:45 +08:00
Spawn* ret = Spawn::createWithVariableList(action1, params);
2012-11-15 17:16:51 +08:00
va_end(params);
2021-12-25 10:04:45 +08:00
return ret;
2012-11-15 17:16:51 +08:00
}
2021-12-25 10:04:45 +08:00
Spawn* Spawn::createWithVariableList(FiniteTimeAction* action1, va_list args)
2012-11-15 17:16:51 +08:00
{
2021-12-25 10:04:45 +08:00
FiniteTimeAction* now;
FiniteTimeAction* prev = action1;
bool oneAction = true;
while (action1)
{
now = va_arg(args, FiniteTimeAction*);
if (now)
{
2021-12-25 10:04:45 +08:00
prev = createWithTwoActions(prev, now);
oneAction = false;
}
else
{
// If only one action is added to Spawn, make up a Spawn by adding a simplest finite time action.
if (oneAction)
2013-02-27 09:38:30 +08:00
{
prev = createWithTwoActions(prev, ExtraAction::create());
}
break;
}
}
return ((Spawn*)prev);
}
Spawn* Spawn::create(const Vector<FiniteTimeAction*>& arrayOfActions)
{
2021-12-08 00:11:53 +08:00
Spawn* ret = new Spawn;
2021-12-25 10:04:45 +08:00
2021-12-08 00:11:53 +08:00
if (ret->init(arrayOfActions))
{
ret->autorelease();
return ret;
}
2021-12-25 10:04:45 +08:00
delete ret;
return nullptr;
}
2021-12-25 10:04:45 +08:00
Spawn* Spawn::createWithTwoActions(FiniteTimeAction* action1, FiniteTimeAction* action2)
{
2021-12-25 10:04:45 +08:00
Spawn* spawn = new Spawn();
2021-12-08 00:11:53 +08:00
if (spawn->initWithTwoActions(action1, action2))
{
spawn->autorelease();
return spawn;
}
2021-12-25 10:04:45 +08:00
delete spawn;
return nullptr;
}
bool Spawn::init(const Vector<FiniteTimeAction*>& arrayOfActions)
{
auto count = arrayOfActions.size();
2021-12-25 10:04:45 +08:00
if (count == 0)
return false;
2021-12-25 10:04:45 +08:00
if (count == 1)
return initWithTwoActions(arrayOfActions.at(0), ExtraAction::create());
2021-12-25 10:04:45 +08:00
// else count > 1
auto prev = arrayOfActions.at(0);
2021-12-25 10:04:45 +08:00
for (int i = 1; i < count - 1; ++i)
{
prev = createWithTwoActions(prev, arrayOfActions.at(i));
}
2021-12-25 10:04:45 +08:00
return initWithTwoActions(prev, arrayOfActions.at(count - 1));
}
2021-12-25 10:04:45 +08:00
bool Spawn::initWithTwoActions(FiniteTimeAction* action1, FiniteTimeAction* action2)
{
2022-07-16 10:43:05 +08:00
AXASSERT(action1 != nullptr, "action1 can't be nullptr!");
AXASSERT(action2 != nullptr, "action2 can't be nullptr!");
if (action1 == nullptr || action2 == nullptr)
{
log("Spawn::initWithTwoActions error: action is nullptr!");
return false;
}
bool ret = false;
float d1 = action1->getDuration();
float d2 = action2->getDuration();
if (ActionInterval::initWithDuration(MAX(d1, d2)))
{
_one = action1;
_two = action2;
if (d1 > d2)
{
_two = Sequence::createWithTwoActions(action2, DelayTime::create(d1 - d2));
2021-12-25 10:04:45 +08:00
}
else if (d1 < d2)
{
_one = Sequence::createWithTwoActions(action1, DelayTime::create(d2 - d1));
}
_one->retain();
_two->retain();
ret = true;
}
return ret;
}
Spawn* Spawn::clone() const
{
// no copy constructor
if (_one && _two)
return Spawn::createWithTwoActions(_one->clone(), _two->clone());
else
return nullptr;
}
2021-12-25 10:04:45 +08:00
Spawn::Spawn() : _one(nullptr), _two(nullptr) {}
Spawn::~Spawn()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_one);
AX_SAFE_RELEASE(_two);
}
2021-12-25 10:04:45 +08:00
void Spawn::startWithTarget(Node* target)
{
if (target == nullptr)
{
log("Spawn::startWithTarget error: target is nullptr!");
return;
}
if (_one == nullptr || _two == nullptr)
{
log("Spawn::startWithTarget error: _one or _two is nullptr!");
return;
}
2021-12-25 10:04:45 +08:00
ActionInterval::startWithTarget(target);
_one->startWithTarget(target);
_two->startWithTarget(target);
}
void Spawn::stop()
{
if (_one)
_one->stop();
if (_two)
_two->stop();
ActionInterval::stop();
}
void Spawn::update(float time)
{
if (_one)
{
if (!(sendUpdateEventToScript(time, _one)))
_one->update(time);
}
if (_two)
{
if (!(sendUpdateEventToScript(time, _two)))
_two->update(time);
}
}
Spawn* Spawn::reverse() const
{
if (_one && _two)
return Spawn::createWithTwoActions(_one->reverse(), _two->reverse());
2021-12-25 10:04:45 +08:00
return nullptr;
}
//
// RotateTo
//
RotateTo* RotateTo::create(float duration, float dstAngle)
{
2021-12-08 00:11:53 +08:00
RotateTo* rotateTo = new RotateTo();
if (rotateTo->initWithDuration(duration, dstAngle, dstAngle))
{
rotateTo->autorelease();
return rotateTo;
}
2021-12-25 10:04:45 +08:00
delete rotateTo;
return nullptr;
}
RotateTo* RotateTo::create(float duration, float dstAngleX, float dstAngleY)
{
2021-12-08 00:11:53 +08:00
RotateTo* rotateTo = new RotateTo();
if (rotateTo->initWithDuration(duration, dstAngleX, dstAngleY))
{
rotateTo->autorelease();
return rotateTo;
}
2021-12-25 10:04:45 +08:00
delete rotateTo;
return nullptr;
}
RotateTo* RotateTo::create(float duration, const Vec3& dstAngle3D)
{
2021-12-08 00:11:53 +08:00
RotateTo* rotateTo = new RotateTo();
2021-12-25 10:04:45 +08:00
if (rotateTo->initWithDuration(duration, dstAngle3D))
{
rotateTo->autorelease();
return rotateTo;
}
delete rotateTo;
return nullptr;
}
2021-12-25 10:04:45 +08:00
RotateTo::RotateTo() : _is3D(false) {}
bool RotateTo::initWithDuration(float duration, float dstAngleX, float dstAngleY)
{
if (ActionInterval::initWithDuration(duration))
{
_dstAngle.x = dstAngleX;
_dstAngle.y = dstAngleY;
2021-12-25 10:04:45 +08:00
return true;
}
2021-12-25 10:04:45 +08:00
return false;
2012-11-15 17:16:51 +08:00
}
bool RotateTo::initWithDuration(float duration, const Vec3& dstAngle3D)
2012-11-15 17:16:51 +08:00
{
if (ActionInterval::initWithDuration(duration))
2012-11-15 17:16:51 +08:00
{
_dstAngle = dstAngle3D;
2021-12-25 10:04:45 +08:00
_is3D = true;
2012-11-15 17:16:51 +08:00
return true;
}
2021-12-25 10:04:45 +08:00
2012-11-15 17:16:51 +08:00
return false;
}
RotateTo* RotateTo::clone() const
{
// no copy constructor
2021-12-08 00:11:53 +08:00
auto a = new RotateTo();
2021-12-25 10:04:45 +08:00
if (_is3D)
a->initWithDuration(_duration, _dstAngle);
else
a->initWithDuration(_duration, _dstAngle.x, _dstAngle.y);
a->autorelease();
return a;
}
2021-12-25 10:04:45 +08:00
void RotateTo::calculateAngles(float& startAngle, float& diffAngle, float dstAngle)
{
if (startAngle > 0)
2013-02-27 09:38:30 +08:00
{
startAngle = fmodf(startAngle, 360.0f);
2013-02-27 09:38:30 +08:00
}
else
{
startAngle = fmodf(startAngle, -360.0f);
}
diffAngle = dstAngle - startAngle;
if (diffAngle > 180)
2012-11-15 17:16:51 +08:00
{
diffAngle -= 360;
2012-11-15 17:16:51 +08:00
}
if (diffAngle < -180)
2012-11-15 17:16:51 +08:00
{
diffAngle += 360;
2012-11-15 17:16:51 +08:00
}
}
2021-12-25 10:04:45 +08:00
void RotateTo::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
2021-12-25 10:04:45 +08:00
if (_is3D)
{
_startAngle = _target->getRotation3D();
}
else
{
_startAngle.x = _target->getRotationSkewX();
_startAngle.y = _target->getRotationSkewY();
}
calculateAngles(_startAngle.x, _diffAngle.x, _dstAngle.x);
calculateAngles(_startAngle.y, _diffAngle.y, _dstAngle.y);
calculateAngles(_startAngle.z, _diffAngle.z, _dstAngle.z);
}
void RotateTo::update(float time)
{
if (_target)
{
2021-12-25 10:04:45 +08:00
if (_is3D)
{
2021-12-25 10:04:45 +08:00
_target->setRotation3D(Vec3(_startAngle.x + _diffAngle.x * time, _startAngle.y + _diffAngle.y * time,
_startAngle.z + _diffAngle.z * time));
}
else
{
2022-07-15 19:17:01 +08:00
#if AX_USE_PHYSICS
if (_startAngle.x == _startAngle.y && _diffAngle.x == _diffAngle.y)
{
_target->setRotation(_startAngle.x + _diffAngle.x * time);
}
else
{
_target->setRotationSkewX(_startAngle.x + _diffAngle.x * time);
_target->setRotationSkewY(_startAngle.y + _diffAngle.y * time);
}
#else
_target->setRotationSkewX(_startAngle.x + _diffAngle.x * time);
_target->setRotationSkewY(_startAngle.y + _diffAngle.y * time);
2022-07-15 19:17:01 +08:00
#endif // AX_USE_PHYSICS
}
}
}
2021-12-25 10:04:45 +08:00
RotateTo* RotateTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "RotateTo doesn't support the 'reverse' method");
return nullptr;
}
//
// RotateBy
//
RotateBy* RotateBy::create(float duration, float deltaAngle)
{
2021-12-25 10:04:45 +08:00
RotateBy* rotateBy = new RotateBy();
2021-12-08 00:11:53 +08:00
if (rotateBy->initWithDuration(duration, deltaAngle))
{
rotateBy->autorelease();
return rotateBy;
}
2021-12-25 10:04:45 +08:00
delete rotateBy;
return nullptr;
}
2014-02-23 11:16:42 +08:00
RotateBy* RotateBy::create(float duration, float deltaAngleX, float deltaAngleY)
{
2021-12-25 10:04:45 +08:00
RotateBy* rotateBy = new RotateBy();
2021-12-08 00:11:53 +08:00
if (rotateBy->initWithDuration(duration, deltaAngleX, deltaAngleY))
{
rotateBy->autorelease();
return rotateBy;
}
delete rotateBy;
return nullptr;
2014-02-23 11:16:42 +08:00
}
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
RotateBy* RotateBy::create(float duration, const Vec3& deltaAngle3D)
2014-02-23 11:16:42 +08:00
{
2021-12-25 10:04:45 +08:00
RotateBy* rotateBy = new RotateBy();
if (rotateBy->initWithDuration(duration, deltaAngle3D))
{
rotateBy->autorelease();
return rotateBy;
}
2014-02-23 11:16:42 +08:00
delete rotateBy;
return nullptr;
2014-02-23 11:16:42 +08:00
}
2021-12-25 10:04:45 +08:00
RotateBy::RotateBy() : _is3D(false) {}
2014-02-23 11:16:42 +08:00
bool RotateBy::initWithDuration(float duration, float deltaAngle)
{
if (ActionInterval::initWithDuration(duration))
{
_deltaAngle.x = _deltaAngle.y = deltaAngle;
return true;
}
return false;
}
2014-02-23 11:16:42 +08:00
bool RotateBy::initWithDuration(float duration, float deltaAngleX, float deltaAngleY)
2012-11-15 17:16:51 +08:00
{
2014-02-23 11:16:42 +08:00
if (ActionInterval::initWithDuration(duration))
{
_deltaAngle.x = deltaAngleX;
_deltaAngle.y = deltaAngleY;
2014-02-23 11:16:42 +08:00
return true;
}
2021-12-25 10:04:45 +08:00
2014-02-23 11:16:42 +08:00
return false;
2012-11-15 17:16:51 +08:00
}
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
bool RotateBy::initWithDuration(float duration, const Vec3& deltaAngle3D)
2012-11-15 17:16:51 +08:00
{
if (ActionInterval::initWithDuration(duration))
2012-11-15 17:16:51 +08:00
{
_deltaAngle = deltaAngle3D;
2021-12-25 10:04:45 +08:00
_is3D = true;
2012-11-15 17:16:51 +08:00
return true;
}
2014-02-23 11:16:42 +08:00
2012-11-15 17:16:51 +08:00
return false;
}
2014-05-28 17:41:34 +08:00
RotateBy* RotateBy::clone() const
{
// no copy constructor
2021-12-08 00:11:53 +08:00
auto a = new RotateBy();
2021-12-25 10:04:45 +08:00
if (_is3D)
a->initWithDuration(_duration, _deltaAngle);
2014-02-23 11:16:42 +08:00
else
a->initWithDuration(_duration, _deltaAngle.x, _deltaAngle.y);
a->autorelease();
return a;
}
2021-12-25 10:04:45 +08:00
void RotateBy::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
2021-12-25 10:04:45 +08:00
if (_is3D)
2014-02-23 11:16:42 +08:00
{
_startAngle = target->getRotation3D();
2014-02-23 11:16:42 +08:00
}
else
{
_startAngle.x = target->getRotationSkewX();
_startAngle.y = target->getRotationSkewY();
2014-02-23 11:16:42 +08:00
}
}
void RotateBy::update(float time)
{
// FIXME: shall I add % 360
if (_target)
{
2021-12-25 10:04:45 +08:00
if (_is3D)
2014-02-23 11:16:42 +08:00
{
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
Vec3 v;
v.x = _startAngle.x + _deltaAngle.x * time;
v.y = _startAngle.y + _deltaAngle.y * time;
v.z = _startAngle.z + _deltaAngle.z * time;
2014-02-23 11:16:42 +08:00
_target->setRotation3D(v);
}
else
{
2022-07-15 19:17:01 +08:00
#if AX_USE_PHYSICS
if (_startAngle.x == _startAngle.y && _deltaAngle.x == _deltaAngle.y)
{
_target->setRotation(_startAngle.x + _deltaAngle.x * time);
}
else
{
_target->setRotationSkewX(_startAngle.x + _deltaAngle.x * time);
_target->setRotationSkewY(_startAngle.y + _deltaAngle.y * time);
}
#else
_target->setRotationSkewX(_startAngle.x + _deltaAngle.x * time);
_target->setRotationSkewY(_startAngle.y + _deltaAngle.y * time);
2022-07-15 19:17:01 +08:00
#endif // AX_USE_PHYSICS
2014-02-23 11:16:42 +08:00
}
}
}
RotateBy* RotateBy::reverse() const
{
2021-12-25 10:04:45 +08:00
if (_is3D)
2014-02-23 11:16:42 +08:00
{
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
Vec3 v;
2021-12-25 10:04:45 +08:00
v.x = -_deltaAngle.x;
v.y = -_deltaAngle.y;
v.z = -_deltaAngle.z;
2014-02-23 11:16:42 +08:00
return RotateBy::create(_duration, v);
}
else
{
return RotateBy::create(_duration, -_deltaAngle.x, -_deltaAngle.y);
}
}
//
// MoveBy
//
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
MoveBy* MoveBy::create(float duration, const Vec2& deltaPosition)
{
2014-12-22 14:34:35 +08:00
return MoveBy::create(duration, Vec3(deltaPosition.x, deltaPosition.y, 0));
}
2021-12-25 10:04:45 +08:00
MoveBy* MoveBy::create(float duration, const Vec3& deltaPosition)
2014-12-22 14:34:35 +08:00
{
2021-12-25 10:04:45 +08:00
MoveBy* ret = new MoveBy();
2021-12-08 00:11:53 +08:00
if (ret->initWithDuration(duration, deltaPosition))
2014-12-22 14:34:35 +08:00
{
ret->autorelease();
return ret;
2014-12-22 14:34:35 +08:00
}
2021-12-25 10:04:45 +08:00
delete ret;
return nullptr;
}
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
bool MoveBy::initWithDuration(float duration, const Vec2& deltaPosition)
{
2014-12-22 14:34:35 +08:00
return MoveBy::initWithDuration(duration, Vec3(deltaPosition.x, deltaPosition.y, 0));
}
bool MoveBy::initWithDuration(float duration, const Vec3& deltaPosition)
{
bool ret = false;
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(duration))
{
_positionDelta = deltaPosition;
2021-12-25 10:04:45 +08:00
_is3D = true;
ret = true;
}
2021-12-25 10:04:45 +08:00
2014-12-22 14:34:35 +08:00
return ret;
}
2014-05-28 17:41:34 +08:00
MoveBy* MoveBy::clone() const
{
// no copy constructor
return MoveBy::create(_duration, _positionDelta);
}
2021-12-25 10:04:45 +08:00
void MoveBy::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
2014-12-22 14:34:35 +08:00
_previousPosition = _startPosition = target->getPosition3D();
}
MoveBy* MoveBy::reverse() const
{
2014-12-22 14:34:35 +08:00
return MoveBy::create(_duration, -_positionDelta);
}
void MoveBy::update(float t)
{
if (_target)
2013-02-27 09:38:30 +08:00
{
2022-07-15 19:17:01 +08:00
#if AX_ENABLE_STACKABLE_ACTIONS
2014-12-22 14:34:35 +08:00
Vec3 currentPos = _target->getPosition3D();
2021-12-25 10:04:45 +08:00
Vec3 diff = currentPos - _previousPosition;
_startPosition = _startPosition + diff;
Vec3 newPos = _startPosition + (_positionDelta * t);
2014-12-22 14:34:35 +08:00
_target->setPosition3D(newPos);
_previousPosition = newPos;
2013-02-27 09:38:30 +08:00
#else
2014-12-22 14:34:35 +08:00
_target->setPosition3D(_startPosition + _positionDelta * t);
2022-07-15 19:17:01 +08:00
#endif // AX_ENABLE_STACKABLE_ACTIONS
}
}
//
// MoveTo
//
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
MoveTo* MoveTo::create(float duration, const Vec2& position)
{
2014-12-22 14:34:35 +08:00
return MoveTo::create(duration, Vec3(position.x, position.y, 0));
}
2014-12-22 14:34:35 +08:00
MoveTo* MoveTo::create(float duration, const Vec3& position)
{
2021-12-25 10:04:45 +08:00
MoveTo* ret = new MoveTo();
2021-12-08 00:11:53 +08:00
if (ret->initWithDuration(duration, position))
2014-12-22 14:34:35 +08:00
{
ret->autorelease();
return ret;
2014-12-22 14:34:35 +08:00
}
2021-12-25 10:04:45 +08:00
delete ret;
return nullptr;
}
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
bool MoveTo::initWithDuration(float duration, const Vec2& position)
{
2014-12-22 14:34:35 +08:00
return initWithDuration(duration, Vec3(position.x, position.y, 0));
}
bool MoveTo::initWithDuration(float duration, const Vec3& position)
{
bool ret = false;
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(duration))
{
_endPosition = position;
2021-12-25 10:04:45 +08:00
ret = true;
}
2021-12-25 10:04:45 +08:00
2014-12-22 14:34:35 +08:00
return ret;
}
2014-05-28 17:41:34 +08:00
MoveTo* MoveTo::clone() const
{
// no copy constructor
return MoveTo::create(_duration, _endPosition);
}
2021-12-25 10:04:45 +08:00
void MoveTo::startWithTarget(Node* target)
{
MoveBy::startWithTarget(target);
2014-12-22 14:34:35 +08:00
_positionDelta = _endPosition - target->getPosition3D();
}
2015-03-10 13:50:53 +08:00
MoveTo* MoveTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "reverse() not supported in MoveTo");
2015-03-10 13:50:53 +08:00
return nullptr;
}
//
// SkewTo
//
SkewTo* SkewTo::create(float t, float sx, float sy)
{
2021-12-25 10:04:45 +08:00
SkewTo* skewTo = new SkewTo();
2021-12-08 00:11:53 +08:00
if (skewTo->initWithDuration(t, sx, sy))
{
skewTo->autorelease();
return skewTo;
}
delete skewTo;
return nullptr;
}
bool SkewTo::initWithDuration(float t, float sx, float sy)
{
bool bRet = false;
if (ActionInterval::initWithDuration(t))
{
_endSkewX = sx;
_endSkewY = sy;
bRet = true;
}
return bRet;
}
2014-05-28 17:41:34 +08:00
SkewTo* SkewTo::clone() const
{
// no copy constructor
return SkewTo::create(_duration, _endSkewX, _endSkewY);
}
SkewTo* SkewTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "reverse() not supported in SkewTo");
return nullptr;
}
2021-12-25 10:04:45 +08:00
void SkewTo::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_startSkewX = target->getSkewX();
if (_startSkewX > 0)
{
_startSkewX = fmodf(_startSkewX, 180.f);
}
else
{
_startSkewX = fmodf(_startSkewX, -180.f);
}
_deltaX = _endSkewX - _startSkewX;
if (_deltaX > 180)
{
_deltaX -= 360;
}
if (_deltaX < -180)
{
_deltaX += 360;
}
_startSkewY = target->getSkewY();
if (_startSkewY > 0)
{
_startSkewY = fmodf(_startSkewY, 360.f);
}
else
{
_startSkewY = fmodf(_startSkewY, -360.f);
}
_deltaY = _endSkewY - _startSkewY;
if (_deltaY > 180)
{
_deltaY -= 360;
}
if (_deltaY < -180)
{
_deltaY += 360;
}
}
void SkewTo::update(float t)
{
_target->setSkewX(_startSkewX + _deltaX * t);
_target->setSkewY(_startSkewY + _deltaY * t);
}
SkewTo::SkewTo()
2021-12-25 10:04:45 +08:00
: _skewX(0.0)
, _skewY(0.0)
, _startSkewX(0.0)
, _startSkewY(0.0)
, _endSkewX(0.0)
, _endSkewY(0.0)
, _deltaX(0.0)
, _deltaY(0.0)
{}
//
// SkewBy
//
SkewBy* SkewBy::create(float t, float sx, float sy)
{
2021-12-25 10:04:45 +08:00
SkewBy* skewBy = new SkewBy();
2021-12-08 00:11:53 +08:00
if (skewBy->initWithDuration(t, sx, sy))
{
skewBy->autorelease();
2021-12-25 10:04:45 +08:00
return skewBy;
}
delete skewBy;
return nullptr;
}
2021-12-25 10:04:45 +08:00
SkewBy* SkewBy::clone() const
{
// no copy constructor
return SkewBy::create(_duration, _skewX, _skewY);
}
bool SkewBy::initWithDuration(float t, float deltaSkewX, float deltaSkewY)
{
bool ret = false;
if (SkewTo::initWithDuration(t, deltaSkewX, deltaSkewY))
{
_skewX = deltaSkewX;
_skewY = deltaSkewY;
ret = true;
}
return ret;
}
2021-12-25 10:04:45 +08:00
void SkewBy::startWithTarget(Node* target)
{
SkewTo::startWithTarget(target);
2021-12-25 10:04:45 +08:00
_deltaX = _skewX;
_deltaY = _skewY;
_endSkewX = _startSkewX + _deltaX;
_endSkewY = _startSkewY + _deltaY;
}
SkewBy* SkewBy::reverse() const
{
return SkewBy::create(_duration, -_skewX, -_skewY);
}
2021-10-23 23:27:14 +08:00
ResizeTo* ResizeTo::create(float duration, const Vec2& final_size)
{
2021-12-25 10:04:45 +08:00
ResizeTo* ret = new ResizeTo();
2021-12-08 00:11:53 +08:00
if (ret->initWithDuration(duration, final_size))
{
2021-12-08 00:11:53 +08:00
ret->autorelease();
2021-12-25 10:04:45 +08:00
}
2021-12-08 00:11:53 +08:00
else
{
delete ret;
ret = nullptr;
}
2021-12-25 10:04:45 +08:00
return ret;
}
ResizeTo* ResizeTo::clone() const
{
// no copy constructor
2021-12-08 00:11:53 +08:00
ResizeTo* a = new ResizeTo();
a->initWithDuration(_duration, _finalSize);
a->autorelease();
return a;
}
void ResizeTo::startWithTarget(axis::Node* target)
{
ActionInterval::startWithTarget(target);
_initialSize = target->getContentSize();
2021-12-25 10:04:45 +08:00
_sizeDelta = _finalSize - _initialSize;
}
void ResizeTo::update(float time)
{
if (_target)
{
auto new_size = _initialSize + (_sizeDelta * time);
_target->setContentSize(new_size);
}
}
2021-10-23 23:27:14 +08:00
bool ResizeTo::initWithDuration(float duration, const Vec2& final_size)
{
if (axis::ActionInterval::initWithDuration(duration))
{
_finalSize = final_size;
return true;
}
return false;
}
//
// ResizeBy
//
2021-10-23 23:27:14 +08:00
ResizeBy* ResizeBy::create(float duration, const Vec2& deltaSize)
{
2021-12-25 10:04:45 +08:00
ResizeBy* ret = new ResizeBy();
2021-12-08 00:11:53 +08:00
if (ret->initWithDuration(duration, deltaSize))
{
2021-12-08 00:11:53 +08:00
ret->autorelease();
2021-12-25 10:04:45 +08:00
}
2021-12-08 00:11:53 +08:00
else
{
2021-12-25 10:04:45 +08:00
delete ret;
ret = nullptr;
}
2021-12-25 10:04:45 +08:00
return ret;
}
ResizeBy* ResizeBy::clone() const
{
// no copy constructor
2021-12-08 00:11:53 +08:00
auto a = new ResizeBy();
a->initWithDuration(_duration, _sizeDelta);
a->autorelease();
return a;
}
2021-12-25 10:04:45 +08:00
void ResizeBy::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_previousSize = _startSize = target->getContentSize();
}
ResizeBy* ResizeBy::reverse() const
{
2021-10-23 23:27:14 +08:00
Vec2 newSize(-_sizeDelta.width, -_sizeDelta.height);
return ResizeBy::create(_duration, newSize);
}
void ResizeBy::update(float t)
{
if (_target)
{
_target->setContentSize(_startSize + (_sizeDelta * t));
}
}
2021-10-23 23:27:14 +08:00
bool ResizeBy::initWithDuration(float duration, const Vec2& deltaSize)
{
bool ret = false;
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(duration))
{
_sizeDelta = deltaSize;
2021-12-25 10:04:45 +08:00
ret = true;
}
2021-12-25 10:04:45 +08:00
return ret;
}
//
// JumpBy
//
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
JumpBy* JumpBy::create(float duration, const Vec2& position, float height, int jumps)
{
2021-12-25 10:04:45 +08:00
JumpBy* jumpBy = new JumpBy();
2021-12-08 00:11:53 +08:00
if (jumpBy->initWithDuration(duration, position, height, jumps))
{
jumpBy->autorelease();
return jumpBy;
}
2021-12-25 10:04:45 +08:00
delete jumpBy;
return nullptr;
}
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
bool JumpBy::initWithDuration(float duration, const Vec2& position, float height, int jumps)
{
2022-07-16 10:43:05 +08:00
AXASSERT(jumps >= 0, "Number of jumps must be >= 0");
if (jumps < 0)
{
log("JumpBy::initWithDuration error: Number of jumps must be >= 0");
return false;
}
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(duration) && jumps >= 0)
{
2021-12-25 10:04:45 +08:00
_delta = position;
_height = height;
2021-12-25 10:04:45 +08:00
_jumps = jumps;
return true;
}
return false;
}
2014-05-28 17:41:34 +08:00
JumpBy* JumpBy::clone() const
{
// no copy constructor
return JumpBy::create(_duration, _delta, _height, _jumps);
}
2021-12-25 10:04:45 +08:00
void JumpBy::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_previousPos = _startPosition = target->getPosition();
}
void JumpBy::update(float t)
{
// parabolic jump (since v0.8.2)
if (_target)
{
2021-12-25 10:04:45 +08:00
float frac = fmodf(t * _jumps, 1.0f);
float y = _height * 4 * frac * (1 - frac);
y += _delta.y * t;
2013-02-27 09:38:30 +08:00
float x = _delta.x * t;
2022-07-15 19:17:01 +08:00
#if AX_ENABLE_STACKABLE_ACTIONS
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
Vec2 currentPos = _target->getPosition();
2013-02-27 09:38:30 +08:00
2021-12-25 10:04:45 +08:00
Vec2 diff = currentPos - _previousPos;
_startPosition = diff + _startPosition;
2013-02-27 09:38:30 +08:00
2021-12-25 10:04:45 +08:00
Vec2 newPos = _startPosition + Vec2(x, y);
_target->setPosition(newPos);
2013-02-27 09:38:30 +08:00
_previousPos = newPos;
2013-02-27 09:38:30 +08:00
#else
2021-12-25 10:04:45 +08:00
_target->setPosition(_startPosition + Vec2(x, y));
2022-07-15 19:17:01 +08:00
#endif // !AX_ENABLE_STACKABLE_ACTIONS
}
}
JumpBy* JumpBy::reverse() const
{
2021-12-25 10:04:45 +08:00
return JumpBy::create(_duration, Vec2(-_delta.x, -_delta.y), _height, _jumps);
}
//
// JumpTo
//
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
JumpTo* JumpTo::create(float duration, const Vec2& position, float height, int jumps)
{
2021-12-25 10:04:45 +08:00
JumpTo* jumpTo = new JumpTo();
2021-12-08 00:11:53 +08:00
if (jumpTo->initWithDuration(duration, position, height, jumps))
{
jumpTo->autorelease();
return jumpTo;
}
2021-12-25 10:04:45 +08:00
delete jumpTo;
return nullptr;
}
bool JumpTo::initWithDuration(float duration, const Vec2& position, float height, int jumps)
{
2022-07-16 10:43:05 +08:00
AXASSERT(jumps >= 0, "Number of jumps must be >= 0");
if (jumps < 0)
{
log("JumpTo::initWithDuration error:Number of jumps must be >= 0");
return false;
}
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(duration) && jumps >= 0)
{
_endPosition = position;
2021-12-25 10:04:45 +08:00
_height = height;
_jumps = jumps;
return true;
}
return false;
}
2014-05-28 17:41:34 +08:00
JumpTo* JumpTo::clone() const
{
// no copy constructor
return JumpTo::create(_duration, _endPosition, _height, _jumps);
}
JumpTo* JumpTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "reverse() not supported in JumpTo");
return nullptr;
}
2021-12-25 10:04:45 +08:00
void JumpTo::startWithTarget(Node* target)
{
JumpBy::startWithTarget(target);
_delta.set(_endPosition.x - _startPosition.x, _endPosition.y - _startPosition.y);
}
// Bezier cubic formula:
2021-12-25 10:04:45 +08:00
// ((1 - t) + t)3 = 1
// Expands to ...
2021-12-25 10:04:45 +08:00
// (1 - t)3 + 3t(1-t)2 + 3t2(1 - t) + t3 = 1
static inline float bezierat(float a, float b, float c, float d, float t)
{
2021-12-25 10:04:45 +08:00
return (powf(1 - t, 3) * a + 3 * t * (powf(1 - t, 2)) * b + 3 * powf(t, 2) * (1 - t) * c + powf(t, 3) * d);
}
//
// BezierBy
//
BezierBy* BezierBy::create(float t, const ccBezierConfig& c)
{
2021-12-25 10:04:45 +08:00
BezierBy* bezierBy = new BezierBy();
2021-12-08 00:11:53 +08:00
if (bezierBy->initWithDuration(t, c))
{
bezierBy->autorelease();
return bezierBy;
}
2021-12-25 10:04:45 +08:00
delete bezierBy;
return nullptr;
}
bool BezierBy::initWithDuration(float t, const ccBezierConfig& c)
{
if (ActionInterval::initWithDuration(t))
{
_config = c;
return true;
}
return false;
}
2021-12-25 10:04:45 +08:00
void BezierBy::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_previousPosition = _startPosition = target->getPosition();
}
2014-05-28 17:41:34 +08:00
BezierBy* BezierBy::clone() const
{
// no copy constructor
return BezierBy::create(_duration, _config);
}
void BezierBy::update(float time)
{
if (_target)
{
float xa = 0;
float xb = _config.controlPoint_1.x;
float xc = _config.controlPoint_2.x;
float xd = _config.endPosition.x;
float ya = 0;
float yb = _config.controlPoint_1.y;
float yc = _config.controlPoint_2.y;
float yd = _config.endPosition.y;
float x = bezierat(xa, xb, xc, xd, time);
float y = bezierat(ya, yb, yc, yd, time);
2013-02-27 09:38:30 +08:00
2022-07-15 19:17:01 +08:00
#if AX_ENABLE_STACKABLE_ACTIONS
Squashed commit of the following: commit a9572b8913f3a38b59adbd7b4017ab9848a6b2b5 Author: Ricardo Quesada <ricardoquesada@gmail.com> Date: Wed May 14 10:03:44 2014 -0700 math renames `Vector2` -> `Vec2` `Vector3` -> `Vec3` `Vector4` -> `Vec4` `Matrix` -> `Mat4` commit 4e107f4bd854c26bfceb52b063d6bd9cea02d6a3 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:24:28 2014 -0700 raw version of rename Vector3 commit 1d115573ebe96a5fc815fa44fbe6417ea7dba841 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:07:14 2014 -0700 rename Vector2 after merge commit ab2ed58c129dbc30a4c0970ed94568c5d271657b Merge: 1978d2d 86fb75a Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 09:05:30 2014 -0700 Merge branch 'v3' into v3_renameMathClassName Conflicts: tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UIButtonTest/UIButtonTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UICheckBoxTest/UICheckBoxTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UISliderTest/UISliderTest_Editor.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest.cpp tests/cpp-tests/Classes/UITest/CocoStudioGUITest/UITextFieldTest/UITextFieldTest_Editor.cpp commit 1978d2d174877172ccddc083020a1bbf43ad3b39 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 08:51:45 2014 -0700 rename vector2 in tests/cpp-empty-test folder commit d4e0ff13dcce62724d2fece656543f26aa28e467 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:58:23 2014 -0700 rename vector2 in tests/cpp-tests cpp files commit be50ca2ec75e0fd32a6fcdaa15fe1ebb4cafe79f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:52:57 2014 -0700 rename vector2 in tests/cpp-tests head files commit 6daef564400d4e28c4ce20859a68e0f583fed125 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:49:48 2014 -0700 rename vector2 in extension folder commit 8f3f0f65ceea92c9e7a0d87ab54e62220c5572e2 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:47:22 2014 -0700 rename vector2 in cocos/2d cpp files commit e1f3105aae06d595661a3030f519f7cc13aefbed Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:44:39 2014 -0700 rename vector2 in cocos/2d head files commit 6708d890bfe486109120c3cd4b9fe5c078b7108f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:59 2014 -0700 rename vector2 in cocos/base folder commit d3978fa5447c31ea2f3ece5469b7e746dfba4248 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:43 2014 -0700 rename vector2 in cocos/deprecated folder commit 4bff45139363d6b9706edbbcf9f322d48b4fd019 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:40:26 2014 -0700 rename vector2 in cocos/editor-support folder commit 353d244c995f8b5d14f635c52aed8bc5e5fc1a6f Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:36:48 2014 -0700 rename vector2 in cocos/ui folder commit 758b8f4d513084b9922d7242e9b8f2c7f316de6c Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:39 2014 -0700 rename vector2 in cocos/renderer folder commit 0bd2710dd8714cecb993880bc37affd9ecb05c27 Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:32:15 2014 -0700 rename vector2 in cocos/physics folder commit b7f0581c4587348bdbc1478d5374c2325735f21d Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:25:01 2014 -0700 rename vector2 in cocos/math folder commit a8631a8e1a4e2740807ccd9be9d70de6ecaad7dd Author: Huabing.Xu <dabingnn@gmail.com> Date: Wed May 14 00:16:55 2014 -0700 rename Vector2 to Vec2 deprecate typedef Vector2
2014-05-15 01:07:09 +08:00
Vec2 currentPos = _target->getPosition();
2021-12-25 10:04:45 +08:00
Vec2 diff = currentPos - _previousPosition;
_startPosition = _startPosition + diff;
2013-02-27 09:38:30 +08:00
2021-12-25 10:04:45 +08:00
Vec2 newPos = _startPosition + Vec2(x, y);
_target->setPosition(newPos);
2013-02-27 09:38:30 +08:00
_previousPosition = newPos;
2013-02-27 09:38:30 +08:00
#else
2021-12-25 10:04:45 +08:00
_target->setPosition(_startPosition + Vec2(x, y));
2022-07-15 19:17:01 +08:00
#endif // !AX_ENABLE_STACKABLE_ACTIONS
}
}
2014-05-28 17:41:34 +08:00
BezierBy* BezierBy::reverse() const
{
ccBezierConfig r;
2021-12-25 10:04:45 +08:00
r.endPosition = -_config.endPosition;
r.controlPoint_1 = _config.controlPoint_2 + (-_config.endPosition);
r.controlPoint_2 = _config.controlPoint_1 + (-_config.endPosition);
2021-12-25 10:04:45 +08:00
BezierBy* action = BezierBy::create(_duration, r);
return action;
}
//
// BezierTo
//
BezierTo* BezierTo::create(float t, const ccBezierConfig& c)
{
2021-12-25 10:04:45 +08:00
BezierTo* bezierTo = new BezierTo();
2021-12-08 00:11:53 +08:00
if (bezierTo->initWithDuration(t, c))
{
bezierTo->autorelease();
return bezierTo;
}
2021-12-25 10:04:45 +08:00
delete bezierTo;
return nullptr;
}
2021-12-25 10:04:45 +08:00
bool BezierTo::initWithDuration(float t, const ccBezierConfig& c)
2012-11-15 17:16:51 +08:00
{
if (ActionInterval::initWithDuration(t))
2012-11-15 17:16:51 +08:00
{
_toConfig = c;
return true;
2012-11-15 17:16:51 +08:00
}
2021-12-25 10:04:45 +08:00
return false;
2012-11-15 17:16:51 +08:00
}
2014-05-28 17:41:34 +08:00
BezierTo* BezierTo::clone() const
{
// no copy constructor
return BezierTo::create(_duration, _toConfig);
}
2021-12-25 10:04:45 +08:00
void BezierTo::startWithTarget(Node* target)
{
BezierBy::startWithTarget(target);
_config.controlPoint_1 = _toConfig.controlPoint_1 - _startPosition;
_config.controlPoint_2 = _toConfig.controlPoint_2 - _startPosition;
2021-12-25 10:04:45 +08:00
_config.endPosition = _toConfig.endPosition - _startPosition;
}
BezierTo* BezierTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "CCBezierTo doesn't support the 'reverse' method");
return nullptr;
}
//
// ScaleTo
//
ScaleTo* ScaleTo::create(float duration, float s)
{
2021-12-25 10:04:45 +08:00
ScaleTo* scaleTo = new ScaleTo();
2021-12-08 00:11:53 +08:00
if (scaleTo->initWithDuration(duration, s))
{
scaleTo->autorelease();
2021-12-25 10:04:45 +08:00
return scaleTo;
}
2021-12-25 10:04:45 +08:00
delete scaleTo;
return nullptr;
}
ScaleTo* ScaleTo::create(float duration, float sx, float sy)
{
2021-12-25 10:04:45 +08:00
ScaleTo* scaleTo = new ScaleTo();
2021-12-08 00:11:53 +08:00
if (scaleTo->initWithDuration(duration, sx, sy))
{
scaleTo->autorelease();
return scaleTo;
}
2021-12-25 10:04:45 +08:00
delete scaleTo;
return nullptr;
}
ScaleTo* ScaleTo::create(float duration, float sx, float sy, float sz)
{
2021-12-25 10:04:45 +08:00
ScaleTo* scaleTo = new ScaleTo();
2021-12-08 00:11:53 +08:00
if (scaleTo->initWithDuration(duration, sx, sy, sz))
{
scaleTo->autorelease();
return scaleTo;
}
2021-12-25 10:04:45 +08:00
delete scaleTo;
return nullptr;
}
bool ScaleTo::initWithDuration(float duration, float s)
{
if (ActionInterval::initWithDuration(duration))
{
_endScaleX = s;
_endScaleY = s;
_endScaleZ = s;
return true;
}
return false;
}
bool ScaleTo::initWithDuration(float duration, float sx, float sy)
{
if (ActionInterval::initWithDuration(duration))
{
_endScaleX = sx;
_endScaleY = sy;
_endScaleZ = 1.f;
return true;
}
return false;
}
bool ScaleTo::initWithDuration(float duration, float sx, float sy, float sz)
{
if (ActionInterval::initWithDuration(duration))
{
_endScaleX = sx;
_endScaleY = sy;
_endScaleZ = sz;
return true;
}
return false;
}
2014-05-28 17:41:34 +08:00
ScaleTo* ScaleTo::clone() const
{
// no copy constructor
return ScaleTo::create(_duration, _endScaleX, _endScaleY, _endScaleZ);
}
ScaleTo* ScaleTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "reverse() not supported in ScaleTo");
return nullptr;
}
2021-12-25 10:04:45 +08:00
void ScaleTo::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_startScaleX = target->getScaleX();
_startScaleY = target->getScaleY();
_startScaleZ = target->getScaleZ();
2021-12-25 10:04:45 +08:00
_deltaX = _endScaleX - _startScaleX;
_deltaY = _endScaleY - _startScaleY;
_deltaZ = _endScaleZ - _startScaleZ;
}
void ScaleTo::update(float time)
{
if (_target)
{
_target->setScaleX(_startScaleX + _deltaX * time);
_target->setScaleY(_startScaleY + _deltaY * time);
_target->setScaleZ(_startScaleZ + _deltaZ * time);
}
}
//
// ScaleBy
//
ScaleBy* ScaleBy::create(float duration, float s)
{
2021-12-25 10:04:45 +08:00
ScaleBy* scaleBy = new ScaleBy();
2021-12-08 00:11:53 +08:00
if (scaleBy->initWithDuration(duration, s))
{
scaleBy->autorelease();
return scaleBy;
}
2021-12-25 10:04:45 +08:00
delete scaleBy;
return nullptr;
}
ScaleBy* ScaleBy::create(float duration, float sx, float sy)
{
2021-12-25 10:04:45 +08:00
ScaleBy* scaleBy = new ScaleBy();
2021-12-08 00:11:53 +08:00
if (scaleBy->initWithDuration(duration, sx, sy, 1.f))
{
scaleBy->autorelease();
return scaleBy;
}
2021-12-25 10:04:45 +08:00
delete scaleBy;
return nullptr;
}
ScaleBy* ScaleBy::create(float duration, float sx, float sy, float sz)
{
2021-12-25 10:04:45 +08:00
ScaleBy* scaleBy = new ScaleBy();
2021-12-08 00:11:53 +08:00
if (scaleBy->initWithDuration(duration, sx, sy, sz))
{
scaleBy->autorelease();
return scaleBy;
}
2021-12-25 10:04:45 +08:00
delete scaleBy;
return nullptr;
}
2014-05-28 17:41:34 +08:00
ScaleBy* ScaleBy::clone() const
{
// no copy constructor
return ScaleBy::create(_duration, _endScaleX, _endScaleY, _endScaleZ);
}
2021-12-25 10:04:45 +08:00
void ScaleBy::startWithTarget(Node* target)
{
ScaleTo::startWithTarget(target);
_deltaX = _startScaleX * _endScaleX - _startScaleX;
_deltaY = _startScaleY * _endScaleY - _startScaleY;
_deltaZ = _startScaleZ * _endScaleZ - _startScaleZ;
}
ScaleBy* ScaleBy::reverse() const
{
2021-12-25 10:04:45 +08:00
return ScaleBy::create(_duration, 1 / _endScaleX, 1 / _endScaleY, 1 / _endScaleZ);
}
//
// Blink
//
Blink* Blink::create(float duration, int blinks)
{
2021-12-25 10:04:45 +08:00
Blink* blink = new Blink();
2021-12-08 00:11:53 +08:00
if (blink->initWithDuration(duration, blinks))
{
blink->autorelease();
return blink;
}
delete blink;
return nullptr;
}
bool Blink::initWithDuration(float duration, int blinks)
{
2022-07-16 10:43:05 +08:00
AXASSERT(blinks >= 0, "blinks should be >= 0");
if (blinks < 0)
{
log("Blink::initWithDuration error:blinks should be >= 0");
return false;
}
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(duration) && blinks >= 0)
{
_times = blinks;
return true;
}
return false;
}
void Blink::stop()
2012-11-15 17:16:51 +08:00
{
2016-05-25 02:09:11 +08:00
if (nullptr != _target)
_target->setVisible(_originalState);
ActionInterval::stop();
2012-11-15 17:16:51 +08:00
}
2021-12-25 10:04:45 +08:00
void Blink::startWithTarget(Node* target)
2012-11-15 17:16:51 +08:00
{
ActionInterval::startWithTarget(target);
_originalState = target->isVisible();
2012-11-15 17:16:51 +08:00
}
Blink* Blink::clone() const
{
// no copy constructor
return Blink::create(_duration, _times);
}
void Blink::update(float time)
{
2021-12-25 10:04:45 +08:00
if (_target && !isDone())
{
float slice = 1.0f / _times;
2021-12-25 10:04:45 +08:00
float m = fmodf(time, slice);
_target->setVisible(m > slice / 2 ? true : false);
}
}
Blink* Blink::reverse() const
{
return Blink::create(_duration, _times);
}
//
// FadeIn
//
FadeIn* FadeIn::create(float d)
{
2021-12-08 00:11:53 +08:00
FadeIn* action = new FadeIn();
2021-12-25 10:04:45 +08:00
if (action->initWithDuration(d, 255))
{
action->autorelease();
return action;
}
delete action;
return nullptr;
}
FadeIn* FadeIn::clone() const
{
// no copy constructor
return FadeIn::create(_duration);
}
void FadeIn::setReverseAction(axis::FadeTo* ac)
{
_reverseAction = ac;
}
FadeTo* FadeIn::reverse() const
{
auto action = FadeOut::create(_duration);
action->setReverseAction(const_cast<FadeIn*>(this));
return action;
}
void FadeIn::startWithTarget(axis::Node* target)
{
ActionInterval::startWithTarget(target);
2021-12-25 10:04:45 +08:00
if (nullptr != _reverseAction)
this->_toOpacity = this->_reverseAction->_fromOpacity;
else
_toOpacity = 255;
2021-12-25 10:04:45 +08:00
if (target)
_fromOpacity = target->getOpacity();
}
//
// FadeOut
//
FadeOut* FadeOut::create(float d)
{
2021-12-08 00:11:53 +08:00
FadeOut* action = new FadeOut();
2021-12-25 10:04:45 +08:00
if (action->initWithDuration(d, 0))
{
action->autorelease();
return action;
}
2021-12-25 10:04:45 +08:00
delete action;
return nullptr;
}
FadeOut* FadeOut::clone() const
{
// no copy constructor
return FadeOut::create(_duration);
}
void FadeOut::startWithTarget(axis::Node* target)
{
ActionInterval::startWithTarget(target);
2021-12-25 10:04:45 +08:00
if (nullptr != _reverseAction)
_toOpacity = _reverseAction->_fromOpacity;
else
_toOpacity = 0;
2021-12-25 10:04:45 +08:00
if (target)
_fromOpacity = target->getOpacity();
}
void FadeOut::setReverseAction(axis::FadeTo* ac)
{
_reverseAction = ac;
}
FadeTo* FadeOut::reverse() const
{
auto action = FadeIn::create(_duration);
action->setReverseAction(const_cast<FadeOut*>(this));
return action;
}
//
// FadeTo
//
2019-06-05 17:58:33 +08:00
FadeTo* FadeTo::create(float duration, uint8_t opacity)
{
2021-12-25 10:04:45 +08:00
FadeTo* fadeTo = new FadeTo();
2021-12-08 00:11:53 +08:00
if (fadeTo->initWithDuration(duration, opacity))
{
fadeTo->autorelease();
return fadeTo;
}
2021-12-25 10:04:45 +08:00
delete fadeTo;
return nullptr;
}
2019-06-05 17:58:33 +08:00
bool FadeTo::initWithDuration(float duration, uint8_t opacity)
{
if (ActionInterval::initWithDuration(duration))
{
_toOpacity = opacity;
return true;
}
return false;
}
FadeTo* FadeTo::clone() const
{
// no copy constructor
return FadeTo::create(_duration, _toOpacity);
}
FadeTo* FadeTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "reverse() not supported in FadeTo");
return nullptr;
}
2021-12-25 10:04:45 +08:00
void FadeTo::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
if (target)
{
_fromOpacity = target->getOpacity();
}
}
void FadeTo::update(float time)
{
if (_target)
{
2019-06-05 17:58:33 +08:00
_target->setOpacity((uint8_t)(_fromOpacity + (_toOpacity - _fromOpacity) * time));
}
}
//
// TintTo
//
2019-06-05 17:58:33 +08:00
TintTo* TintTo::create(float duration, uint8_t red, uint8_t green, uint8_t blue)
{
2021-12-25 10:04:45 +08:00
TintTo* tintTo = new TintTo();
2021-12-08 00:11:53 +08:00
if (tintTo->initWithDuration(duration, red, green, blue))
{
tintTo->autorelease();
return tintTo;
}
2021-12-25 10:04:45 +08:00
delete tintTo;
return nullptr;
}
TintTo* TintTo::create(float duration, const Color3B& color)
{
return create(duration, color.r, color.g, color.b);
}
2019-06-05 17:58:33 +08:00
bool TintTo::initWithDuration(float duration, uint8_t red, uint8_t green, uint8_t blue)
{
if (ActionInterval::initWithDuration(duration))
{
_to = Color3B(red, green, blue);
return true;
}
return false;
}
TintTo* TintTo::clone() const
{
// no copy constructor
return TintTo::create(_duration, _to.r, _to.g, _to.b);
}
TintTo* TintTo::reverse() const
{
2022-07-16 10:43:05 +08:00
AXASSERT(false, "reverse() not supported in TintTo");
return nullptr;
}
2021-12-25 10:04:45 +08:00
void TintTo::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
if (_target)
{
_from = _target->getColor();
}
}
void TintTo::update(float time)
{
if (_target)
{
2019-06-05 17:58:33 +08:00
_target->setColor(Color3B(uint8_t(_from.r + (_to.r - _from.r) * time),
2021-12-25 10:04:45 +08:00
(uint8_t)(_from.g + (_to.g - _from.g) * time),
(uint8_t)(_from.b + (_to.b - _from.b) * time)));
}
}
//
// TintBy
//
2019-06-05 17:58:33 +08:00
TintBy* TintBy::create(float duration, int16_t deltaRed, int16_t deltaGreen, int16_t deltaBlue)
{
2021-12-25 10:04:45 +08:00
TintBy* tintBy = new TintBy();
2021-12-08 00:11:53 +08:00
if (tintBy->initWithDuration(duration, deltaRed, deltaGreen, deltaBlue))
{
tintBy->autorelease();
return tintBy;
}
2021-12-25 10:04:45 +08:00
delete tintBy;
return nullptr;
}
2019-06-05 17:58:33 +08:00
bool TintBy::initWithDuration(float duration, int16_t deltaRed, int16_t deltaGreen, int16_t deltaBlue)
{
if (ActionInterval::initWithDuration(duration))
{
_deltaR = deltaRed;
_deltaG = deltaGreen;
_deltaB = deltaBlue;
return true;
}
return false;
}
TintBy* TintBy::clone() const
{
// no copy constructor
return TintBy::create(_duration, _deltaR, _deltaG, _deltaB);
}
2021-12-25 10:04:45 +08:00
void TintBy::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
if (target)
{
Color3B color = target->getColor();
2021-12-25 10:04:45 +08:00
_fromR = color.r;
_fromG = color.g;
_fromB = color.b;
}
}
void TintBy::update(float time)
{
if (_target)
{
2021-12-25 10:04:45 +08:00
_target->setColor(Color3B((uint8_t)(_fromR + _deltaR * time), (uint8_t)(_fromG + _deltaG * time),
(uint8_t)(_fromB + _deltaB * time)));
}
}
TintBy* TintBy::reverse() const
{
return TintBy::create(_duration, -_deltaR, -_deltaG, -_deltaB);
}
//
// DelayTime
//
DelayTime* DelayTime::create(float d)
{
2021-12-08 00:11:53 +08:00
DelayTime* action = new DelayTime();
if (action->initWithDuration(d))
{
action->autorelease();
return action;
}
2021-12-25 10:04:45 +08:00
delete action;
return nullptr;
}
DelayTime* DelayTime::clone() const
{
// no copy constructor
return DelayTime::create(_duration);
}
void DelayTime::update(float /*time*/)
{
return;
}
DelayTime* DelayTime::reverse() const
{
return DelayTime::create(_duration);
}
//
// ReverseTime
//
2021-12-25 10:04:45 +08:00
ReverseTime* ReverseTime::create(FiniteTimeAction* action)
{
// casting to prevent warnings
2021-12-25 10:04:45 +08:00
ReverseTime* reverseTime = new ReverseTime();
if (reverseTime->initWithAction(action->clone()))
{
reverseTime->autorelease();
return reverseTime;
}
2021-12-25 10:04:45 +08:00
delete reverseTime;
return nullptr;
}
2021-12-25 10:04:45 +08:00
bool ReverseTime::initWithAction(FiniteTimeAction* action)
{
2022-07-16 10:43:05 +08:00
AXASSERT(action != nullptr, "action can't be nullptr!");
AXASSERT(action != _other, "action doesn't equal to _other!");
if (action == nullptr || action == _other)
{
log("ReverseTime::initWithAction error: action is null or action equal to _other");
return false;
}
if (ActionInterval::initWithDuration(action->getDuration()))
{
// Don't leak if action is reused
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_other);
_other = action;
action->retain();
return true;
}
return false;
}
ReverseTime* ReverseTime::clone() const
{
// no copy constructor
return ReverseTime::create(_other->clone());
}
2021-12-25 10:04:45 +08:00
ReverseTime::ReverseTime() : _other(nullptr) {}
2014-05-28 17:41:34 +08:00
ReverseTime::~ReverseTime()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_other);
}
2021-12-25 10:04:45 +08:00
void ReverseTime::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_other->startWithTarget(target);
}
void ReverseTime::stop()
{
_other->stop();
ActionInterval::stop();
}
void ReverseTime::update(float time)
{
if (_other)
{
if (!(sendUpdateEventToScript(1 - time, _other)))
_other->update(1 - time);
}
}
ReverseTime* ReverseTime::reverse() const
{
// FIXME: This looks like a bug
return (ReverseTime*)_other->clone();
}
//
// Animate
//
2021-12-25 10:04:45 +08:00
Animate* Animate::create(Animation* animation)
{
2021-12-25 10:04:45 +08:00
Animate* animate = new Animate();
2021-12-08 00:11:53 +08:00
if (animate->initWithAnimation(animation))
{
animate->autorelease();
return animate;
}
2021-12-25 10:04:45 +08:00
delete animate;
return nullptr;
}
2021-12-25 10:04:45 +08:00
Animate::Animate() {}
Animate::~Animate()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_animation);
AX_SAFE_RELEASE(_origFrame);
AX_SAFE_DELETE(_splitTimes);
AX_SAFE_RELEASE(_frameDisplayedEvent);
}
bool Animate::initWithAnimation(Animation* animation)
{
2022-07-16 10:43:05 +08:00
AXASSERT(animation != nullptr, "Animate: argument Animation must be non-nullptr");
if (animation == nullptr)
{
log("Animate::initWithAnimation: argument Animation must be non-nullptr");
return false;
}
float singleDuration = animation->getDuration();
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(singleDuration * animation->getLoops()))
{
_nextFrame = 0;
setAnimation(animation);
2021-12-25 10:04:45 +08:00
_origFrame = nullptr;
_executedLoops = 0;
_splitTimes->reserve(animation->getFrames().size());
2021-12-25 10:04:45 +08:00
float accumUnitsOfTime = 0;
float newUnitOfTimeValue = singleDuration / animation->getTotalDelayUnits();
2014-12-21 00:22:23 +08:00
auto& frames = animation->getFrames();
for (auto&& frame : frames)
{
float value = (accumUnitsOfTime * newUnitOfTimeValue) / singleDuration;
accumUnitsOfTime += frame->getDelayUnits();
_splitTimes->push_back(value);
2021-12-25 10:04:45 +08:00
}
return true;
}
return false;
}
void Animate::setAnimation(axis::Animation* animation)
{
if (_animation != animation)
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RETAIN(animation);
AX_SAFE_RELEASE(_animation);
_animation = animation;
}
}
Animate* Animate::clone() const
{
// no copy constructor
return Animate::create(_animation->clone());
}
2021-12-25 10:04:45 +08:00
void Animate::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
2021-12-25 10:04:45 +08:00
Sprite* sprite = static_cast<Sprite*>(target);
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_origFrame);
if (_animation->getRestoreOriginalFrame())
{
2013-12-25 16:06:39 +08:00
_origFrame = sprite->getSpriteFrame();
_origFrame->retain();
}
2021-12-25 10:04:45 +08:00
_nextFrame = 0;
_executedLoops = 0;
}
2014-05-28 17:41:34 +08:00
void Animate::stop()
{
if (_animation->getRestoreOriginalFrame() && _target)
{
auto blend = static_cast<Sprite*>(_target)->getBlendFunc();
2013-12-25 16:06:39 +08:00
static_cast<Sprite*>(_target)->setSpriteFrame(_origFrame);
static_cast<Sprite*>(_target)->setBlendFunc(blend);
}
ActionInterval::stop();
}
void Animate::update(float t)
{
// if t==1, ignore. Animation should finish with t==1
2021-12-25 10:04:45 +08:00
if (t < 1.0f)
{
t *= _animation->getLoops();
// new loop? If so, reset frame counter
unsigned int loopNumber = (unsigned int)t;
2021-12-25 10:04:45 +08:00
if (loopNumber > _executedLoops)
{
_nextFrame = 0;
_executedLoops++;
}
// new t for animations
t = fmodf(t, 1.0f);
}
2021-12-25 10:04:45 +08:00
auto& frames = _animation->getFrames();
auto numberOfFrames = frames.size();
SpriteFrame* frameToDisplay = nullptr;
2021-12-25 10:04:45 +08:00
for (int i = _nextFrame; i < numberOfFrames; i++)
{
float splitTime = _splitTimes->at(i);
2021-12-25 10:04:45 +08:00
if (splitTime <= t)
{
2021-12-25 10:04:45 +08:00
auto blend = static_cast<Sprite*>(_target)->getBlendFunc();
_currFrameIndex = i;
2015-07-13 10:40:43 +08:00
AnimationFrame* frame = frames.at(_currFrameIndex);
2021-12-25 10:04:45 +08:00
frameToDisplay = frame->getSpriteFrame();
2013-12-25 16:06:39 +08:00
static_cast<Sprite*>(_target)->setSpriteFrame(frameToDisplay);
static_cast<Sprite*>(_target)->setBlendFunc(blend);
const ValueMap& dict = frame->getUserInfo();
2021-12-25 10:04:45 +08:00
if (!dict.empty())
{
if (_frameDisplayedEvent == nullptr)
2021-12-08 00:11:53 +08:00
_frameDisplayedEvent = new EventCustom(AnimationFrameDisplayedNotification);
2021-12-25 10:04:45 +08:00
_frameDisplayedEventInfo.target = _target;
_frameDisplayedEventInfo.userInfo = &dict;
_frameDisplayedEvent->setUserData(&_frameDisplayedEventInfo);
Director::getInstance()->getEventDispatcher()->dispatchEvent(_frameDisplayedEvent);
}
2021-12-25 10:04:45 +08:00
_nextFrame = i + 1;
2013-02-27 09:38:30 +08:00
}
// Issue 1438. Could be more than one frame per tick, due to low frame rate or frame delta < 1/FPS
2021-12-25 10:04:45 +08:00
else
{
break;
}
}
}
Animate* Animate::reverse() const
{
2014-12-21 00:42:55 +08:00
auto& oldArray = _animation->getFrames();
Vector<AnimationFrame*> newArray(oldArray.size());
2021-12-25 10:04:45 +08:00
if (!oldArray.empty())
{
for (auto iter = oldArray.crbegin(), iterCrend = oldArray.crend(); iter != iterCrend; ++iter)
{
AnimationFrame* animFrame = *iter;
if (!animFrame)
{
break;
}
newArray.pushBack(animFrame->clone());
}
}
2021-12-25 10:04:45 +08:00
Animation* newAnim = Animation::create(newArray, _animation->getDelayPerUnit(), _animation->getLoops());
newAnim->setRestoreOriginalFrame(_animation->getRestoreOriginalFrame());
return Animate::create(newAnim);
}
// TargetedAction
2021-12-25 10:04:45 +08:00
TargetedAction::TargetedAction() : _action(nullptr), _forcedTarget(nullptr) {}
TargetedAction::~TargetedAction()
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RELEASE(_forcedTarget);
AX_SAFE_RELEASE(_action);
}
TargetedAction* TargetedAction::create(Node* target, FiniteTimeAction* action)
{
2021-12-08 00:11:53 +08:00
TargetedAction* p = new TargetedAction();
if (p->initWithTarget(target, action))
{
p->autorelease();
return p;
}
2021-12-25 10:04:45 +08:00
delete p;
return nullptr;
}
bool TargetedAction::initWithTarget(Node* target, FiniteTimeAction* action)
{
2021-12-25 10:04:45 +08:00
if (ActionInterval::initWithDuration(action->getDuration()))
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RETAIN(target);
_forcedTarget = target;
2022-07-15 19:17:01 +08:00
AX_SAFE_RETAIN(action);
_action = action;
return true;
}
return false;
}
TargetedAction* TargetedAction::clone() const
{
// no copy constructor
// win32 : use the _other's copy object.
return TargetedAction::create(_forcedTarget, _action->clone());
}
2014-05-28 17:41:34 +08:00
TargetedAction* TargetedAction::reverse() const
{
// just reverse the internal action
2021-12-08 00:11:53 +08:00
auto a = new TargetedAction();
a->initWithTarget(_forcedTarget, _action->reverse());
a->autorelease();
return a;
}
2021-12-25 10:04:45 +08:00
void TargetedAction::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_action->startWithTarget(_forcedTarget);
}
2014-05-28 17:41:34 +08:00
void TargetedAction::stop()
{
_action->stop();
}
void TargetedAction::update(float time)
{
if (!(sendUpdateEventToScript(time, _action)))
_action->update(time);
}
void TargetedAction::setForcedTarget(Node* forcedTarget)
{
2021-12-25 10:04:45 +08:00
if (_forcedTarget != forcedTarget)
{
2022-07-15 19:17:01 +08:00
AX_SAFE_RETAIN(forcedTarget);
AX_SAFE_RELEASE(_forcedTarget);
_forcedTarget = forcedTarget;
}
}
// ActionFloat
ActionFloat* ActionFloat::create(float duration, float from, float to, ActionFloatCallback callback)
{
2021-12-08 00:11:53 +08:00
auto ref = new ActionFloat();
if (ref->initWithDuration(duration, from, to, callback))
{
ref->autorelease();
return ref;
}
2021-12-25 10:04:45 +08:00
delete ref;
return nullptr;
}
bool ActionFloat::initWithDuration(float duration, float from, float to, ActionFloatCallback callback)
{
if (ActionInterval::initWithDuration(duration))
{
2021-12-25 10:04:45 +08:00
_from = from;
_to = to;
_callback = callback;
return true;
}
return false;
}
ActionFloat* ActionFloat::clone() const
{
return ActionFloat::create(_duration, _from, _to, _callback);
}
2021-12-25 10:04:45 +08:00
void ActionFloat::startWithTarget(Node* target)
{
ActionInterval::startWithTarget(target);
_delta = _to - _from;
}
void ActionFloat::update(float delta)
{
float value = _to - _delta * (1 - delta);
if (_callback)
{
// report back value to caller
_callback(value);
}
}
ActionFloat* ActionFloat::reverse() const
{
return ActionFloat::create(_duration, _to, _from, _callback);
}
NS_AX_END