mirror of https://github.com/axmolengine/axmol.git
commit
50c9617d25
7
AUTHORS
7
AUTHORS
|
@ -677,10 +677,17 @@ Developers:
|
|||
|
||||
seobyeongky
|
||||
Updates spine runtime.
|
||||
Fixed a potential bug in Data's copy constructor.
|
||||
|
||||
luocker
|
||||
Fix a bug that string itself is also modified in `String::componentsSeparatedByString`.
|
||||
|
||||
omersaeed
|
||||
Fix a bug that game will crash if connection breaks during download using AssetManager.
|
||||
|
||||
SBKarr
|
||||
AngelCode binary file format support for LabelBMFont.
|
||||
|
||||
Retired Core Developers:
|
||||
WenSheng Yang
|
||||
Author of windows port, CCTextField,
|
||||
|
|
|
@ -16,6 +16,9 @@ cocos2d-x-3.0beta0 ?? 2013
|
|||
[FIX] Deprecates FileUtils::getFileData, adds FileUtils::getStringFromFile/getDataFromFile.
|
||||
[FIX] GUI refactoring: Removes UI prefix, Widget is inherited from Node, uses new containers(Vector<T>, Map<K,V>).
|
||||
[FIX] String itself is also modified in `String::componentsSeparatedByString`.
|
||||
[FIX] Sprites with PhysicsBody move to a wrong position when game resume from background.
|
||||
[FIX] Crash if connection breaks during download using AssetManager.
|
||||
[NEW] AngelCode binary file format support for LabelBMFont.
|
||||
[Android]
|
||||
[NEW] build/android-build.sh: add supporting to generate .apk file
|
||||
[FIX] XMLHttpRequest receives wrong binary array.
|
||||
|
@ -27,6 +30,7 @@ cocos2d-x-3.0beta0 ?? 2013
|
|||
[Bindings]
|
||||
[FIX] Don't bind override functions for JSB and LuaBining since they aren't needed at all.
|
||||
[NEW] Adds spine JS binding support.
|
||||
[FIX] The order of onEnter and onExit is wrong.
|
||||
|
||||
cocos2d-x-3.0alpha1 Nov.19 2013
|
||||
[all platforms]
|
||||
|
|
|
@ -269,8 +269,6 @@ endif(BUILD_EDITOR_COCOSBUILDER)
|
|||
if(BUILD_EDITOR_COCOSTUDIO)
|
||||
# cocostudio
|
||||
add_subdirectory(cocos/editor-support/cocostudio)
|
||||
# jsoncpp library, cocostuido depends on jsoncpp
|
||||
add_subdirectory(external/json)
|
||||
endif(BUILD_EDITOR_COCOSTUDIO)
|
||||
|
||||
if(BUILD_LIBS_LUA)
|
||||
|
|
|
@ -1 +1 @@
|
|||
ff210e4a55306fce7f69c41995a746c084b6b074
|
||||
812ab716d10a52b752f0d15b2393b2b0a7c8e969
|
|
@ -1 +1 @@
|
|||
90bb8f93ddfe16e1337c0e278efe123ca1b92891
|
||||
b83c3a0fd60d6b1b1a032495615afd77fccd5050
|
|
@ -43,7 +43,7 @@ NS_CC_BEGIN;
|
|||
* Implementation of PointArray
|
||||
*/
|
||||
|
||||
PointArray* PointArray::create(int capacity)
|
||||
PointArray* PointArray::create(ssize_t capacity)
|
||||
{
|
||||
PointArray* pointArray = new PointArray();
|
||||
if (pointArray)
|
||||
|
@ -63,7 +63,7 @@ PointArray* PointArray::create(int capacity)
|
|||
}
|
||||
|
||||
|
||||
bool PointArray::initWithCapacity(int capacity)
|
||||
bool PointArray::initWithCapacity(ssize_t capacity)
|
||||
{
|
||||
_controlPoints = new vector<Point*>();
|
||||
|
||||
|
@ -126,19 +126,19 @@ void PointArray::addControlPoint(Point controlPoint)
|
|||
_controlPoints->push_back(new Point(controlPoint.x, controlPoint.y));
|
||||
}
|
||||
|
||||
void PointArray::insertControlPoint(Point &controlPoint, int index)
|
||||
void PointArray::insertControlPoint(Point &controlPoint, ssize_t index)
|
||||
{
|
||||
Point *temp = new Point(controlPoint.x, controlPoint.y);
|
||||
_controlPoints->insert(_controlPoints->begin() + index, temp);
|
||||
}
|
||||
|
||||
Point PointArray::getControlPointAtIndex(int index)
|
||||
Point PointArray::getControlPointAtIndex(ssize_t index)
|
||||
{
|
||||
index = static_cast<int>(MIN(_controlPoints->size()-1, MAX(index, 0)));
|
||||
return *(_controlPoints->at(index));
|
||||
}
|
||||
|
||||
void PointArray::replaceControlPoint(cocos2d::Point &controlPoint, int index)
|
||||
void PointArray::replaceControlPoint(cocos2d::Point &controlPoint, ssize_t index)
|
||||
{
|
||||
|
||||
Point *temp = _controlPoints->at(index);
|
||||
|
@ -146,7 +146,7 @@ void PointArray::replaceControlPoint(cocos2d::Point &controlPoint, int index)
|
|||
temp->y = controlPoint.y;
|
||||
}
|
||||
|
||||
void PointArray::removeControlPointAtIndex(int index)
|
||||
void PointArray::removeControlPointAtIndex(ssize_t index)
|
||||
{
|
||||
vector<Point*>::iterator iter = _controlPoints->begin() + index;
|
||||
Point* removedPoint = *iter;
|
||||
|
@ -154,9 +154,9 @@ void PointArray::removeControlPointAtIndex(int index)
|
|||
delete removedPoint;
|
||||
}
|
||||
|
||||
int PointArray::count() const
|
||||
ssize_t PointArray::count() const
|
||||
{
|
||||
return static_cast<int>(_controlPoints->size());
|
||||
return _controlPoints->size();
|
||||
}
|
||||
|
||||
PointArray* PointArray::reverse() const
|
||||
|
@ -177,11 +177,11 @@ PointArray* PointArray::reverse() const
|
|||
|
||||
void PointArray::reverseInline()
|
||||
{
|
||||
auto l = _controlPoints->size();
|
||||
size_t l = _controlPoints->size();
|
||||
Point *p1 = nullptr;
|
||||
Point *p2 = nullptr;
|
||||
int x, y;
|
||||
for (int i = 0; i < l/2; ++i)
|
||||
float x, y;
|
||||
for (size_t i = 0; i < l/2; ++i)
|
||||
{
|
||||
p1 = _controlPoints->at(i);
|
||||
p2 = _controlPoints->at(l-i-1);
|
||||
|
@ -291,7 +291,7 @@ CardinalSplineTo* CardinalSplineTo::clone() const
|
|||
|
||||
void CardinalSplineTo::update(float time)
|
||||
{
|
||||
int p;
|
||||
ssize_t p;
|
||||
float lt;
|
||||
|
||||
// eg.
|
||||
|
@ -383,7 +383,7 @@ CardinalSplineBy* CardinalSplineBy::reverse() const
|
|||
// convert "absolutes" to "diffs"
|
||||
//
|
||||
Point p = copyConfig->getControlPointAtIndex(0);
|
||||
for (unsigned int i = 1; i < copyConfig->count(); ++i)
|
||||
for (ssize_t i = 1; i < copyConfig->count(); ++i)
|
||||
{
|
||||
Point current = copyConfig->getControlPointAtIndex(i);
|
||||
Point diff = current - p;
|
||||
|
@ -405,7 +405,7 @@ CardinalSplineBy* CardinalSplineBy::reverse() const
|
|||
p = -p;
|
||||
pReverse->insertControlPoint(p, 0);
|
||||
|
||||
for (unsigned int i = 1; i < pReverse->count(); ++i)
|
||||
for (ssize_t i = 1; i < pReverse->count(); ++i)
|
||||
{
|
||||
Point current = pReverse->getControlPointAtIndex(i);
|
||||
current = -current;
|
||||
|
@ -528,7 +528,7 @@ CatmullRomBy* CatmullRomBy::reverse() const
|
|||
// convert "absolutes" to "diffs"
|
||||
//
|
||||
Point p = copyConfig->getControlPointAtIndex(0);
|
||||
for (unsigned int i = 1; i < copyConfig->count(); ++i)
|
||||
for (ssize_t i = 1; i < copyConfig->count(); ++i)
|
||||
{
|
||||
Point current = copyConfig->getControlPointAtIndex(i);
|
||||
Point diff = current - p;
|
||||
|
@ -550,7 +550,7 @@ CatmullRomBy* CatmullRomBy::reverse() const
|
|||
p = -p;
|
||||
reverse->insertControlPoint(p, 0);
|
||||
|
||||
for (unsigned int i = 1; i < reverse->count(); ++i)
|
||||
for (ssize_t i = 1; i < reverse->count(); ++i)
|
||||
{
|
||||
Point current = reverse->getControlPointAtIndex(i);
|
||||
current = -current;
|
||||
|
|
|
@ -61,7 +61,7 @@ public:
|
|||
/** creates and initializes a Points array with capacity
|
||||
* @js NA
|
||||
*/
|
||||
static PointArray* create(int capacity);
|
||||
static PointArray* create(ssize_t capacity);
|
||||
|
||||
/**
|
||||
* @js NA
|
||||
|
@ -77,7 +77,7 @@ public:
|
|||
/** initializes a Catmull Rom config with a capacity hint
|
||||
* @js NA
|
||||
*/
|
||||
bool initWithCapacity(int capacity);
|
||||
bool initWithCapacity(ssize_t capacity);
|
||||
|
||||
/** appends a control point
|
||||
* @js NA
|
||||
|
@ -87,27 +87,27 @@ public:
|
|||
/** inserts a controlPoint at index
|
||||
* @js NA
|
||||
*/
|
||||
void insertControlPoint(Point &controlPoint, int index);
|
||||
void insertControlPoint(Point &controlPoint, ssize_t index);
|
||||
|
||||
/** replaces an existing controlPoint at index
|
||||
* @js NA
|
||||
*/
|
||||
void replaceControlPoint(Point &controlPoint, int index);
|
||||
void replaceControlPoint(Point &controlPoint, ssize_t index);
|
||||
|
||||
/** get the value of a controlPoint at a given index
|
||||
* @js NA
|
||||
*/
|
||||
Point getControlPointAtIndex(int index);
|
||||
Point getControlPointAtIndex(ssize_t index);
|
||||
|
||||
/** deletes a control point at a given index
|
||||
* @js NA
|
||||
*/
|
||||
void removeControlPointAtIndex(int index);
|
||||
void removeControlPointAtIndex(ssize_t index);
|
||||
|
||||
/** returns the number of objects of the control point array
|
||||
* @js NA
|
||||
*/
|
||||
int count() const;
|
||||
ssize_t count() const;
|
||||
|
||||
/** returns a new copy of the array reversed. User is responsible for releasing this copy
|
||||
* @js NA
|
||||
|
|
|
@ -32,7 +32,7 @@ THE SOFTWARE.
|
|||
#include "CCProtocols.h"
|
||||
#include "CCSpriteFrame.h"
|
||||
#include "CCAnimation.h"
|
||||
#include <CCVector.h>
|
||||
#include "CCVector.h"
|
||||
#include <vector>
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
|
|
@ -102,7 +102,8 @@ void AnimationCache::parseVersion1(const ValueMap& animations)
|
|||
continue;
|
||||
}
|
||||
|
||||
Vector<AnimationFrame*> frames(static_cast<int>(frameNames.size()));
|
||||
ssize_t frameNameSize = frameNames.size();
|
||||
Vector<AnimationFrame*> frames(frameNameSize);
|
||||
|
||||
for (auto& frameName : frameNames)
|
||||
{
|
||||
|
@ -118,12 +119,12 @@ void AnimationCache::parseVersion1(const ValueMap& animations)
|
|||
frames.pushBack(animFrame);
|
||||
}
|
||||
|
||||
if ( frames.size() == 0 )
|
||||
if ( frames.empty() )
|
||||
{
|
||||
CCLOG("cocos2d: AnimationCache: None of the frames for animation '%s' were found in the SpriteFrameCache. Animation is not being added to the Animation Cache.", iter->first.c_str());
|
||||
continue;
|
||||
}
|
||||
else if ( frames.size() != frameNames.size() )
|
||||
else if ( frames.size() != frameNameSize )
|
||||
{
|
||||
CCLOG("cocos2d: AnimationCache: An animation in your dictionary refers to a frame which is not in the SpriteFrameCache. Some or all of the frames for the animation '%s' may be missing.", iter->first.c_str());
|
||||
}
|
||||
|
|
|
@ -34,7 +34,7 @@ THE SOFTWARE.
|
|||
#include "CCDirector.h"
|
||||
#include "TransformUtils.h"
|
||||
#include "CCRenderer.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
|
||||
// external
|
||||
#include "kazmath/GL/matrix.h"
|
||||
|
@ -151,8 +151,7 @@ void AtlasNode::draw(void)
|
|||
|
||||
auto shader = ShaderCache::getInstance()->getProgram(GLProgram::SHADER_NAME_POSITION_TEXTURE_COLOR_NO_MVP);
|
||||
|
||||
QuadCommand* cmd = QuadCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0,
|
||||
_quadCommand.init(0,
|
||||
_vertexZ,
|
||||
_textureAtlas->getTexture()->getName(),
|
||||
shader,
|
||||
|
@ -161,7 +160,7 @@ void AtlasNode::draw(void)
|
|||
_textureAtlas->getTotalQuads(),
|
||||
_modelViewTransform);
|
||||
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_quadCommand);
|
||||
|
||||
}
|
||||
|
||||
|
@ -263,12 +262,12 @@ TextureAtlas * AtlasNode::getTextureAtlas() const
|
|||
return _textureAtlas;
|
||||
}
|
||||
|
||||
int AtlasNode::getQuadsToDraw() const
|
||||
ssize_t AtlasNode::getQuadsToDraw() const
|
||||
{
|
||||
return _quadsToDraw;
|
||||
}
|
||||
|
||||
void AtlasNode::setQuadsToDraw(int quadsToDraw)
|
||||
void AtlasNode::setQuadsToDraw(ssize_t quadsToDraw)
|
||||
{
|
||||
_quadsToDraw = quadsToDraw;
|
||||
}
|
||||
|
|
|
@ -30,6 +30,7 @@ THE SOFTWARE.
|
|||
#include "CCNode.h"
|
||||
#include "CCProtocols.h"
|
||||
#include "ccTypes.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -62,8 +63,8 @@ public:
|
|||
void setTextureAtlas(TextureAtlas* textureAtlas);
|
||||
TextureAtlas* getTextureAtlas() const;
|
||||
|
||||
void setQuadsToDraw(int quadsToDraw);
|
||||
int getQuadsToDraw() const;
|
||||
void setQuadsToDraw(ssize_t quadsToDraw);
|
||||
ssize_t getQuadsToDraw() const;
|
||||
|
||||
|
||||
// Overrides
|
||||
|
@ -125,11 +126,13 @@ protected:
|
|||
BlendFunc _blendFunc;
|
||||
|
||||
// quads to draw
|
||||
int _quadsToDraw;
|
||||
ssize_t _quadsToDraw;
|
||||
// color uniform
|
||||
GLint _uniformColor;
|
||||
// This varible is only used for LabelAtlas FPS display. So plz don't modify its value.
|
||||
bool _ignoreContentScaleFactor;
|
||||
// quad command
|
||||
QuadCommand _quadCommand;
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(AtlasNode);
|
||||
|
|
|
@ -209,23 +209,20 @@ void ClippingNode::visit()
|
|||
|
||||
Renderer* renderer = Director::getInstance()->getRenderer();
|
||||
|
||||
GroupCommand* groupCommand = GroupCommand::getCommandPool().generateCommand();
|
||||
groupCommand->init(0,_vertexZ);
|
||||
renderer->addCommand(groupCommand);
|
||||
_groupCommand.init(0,_vertexZ);
|
||||
renderer->addCommand(&_groupCommand);
|
||||
|
||||
renderer->pushGroup(groupCommand->getRenderQueueID());
|
||||
renderer->pushGroup(_groupCommand.getRenderQueueID());
|
||||
|
||||
CustomCommand* beforeVisitCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
beforeVisitCmd->init(0,_vertexZ);
|
||||
beforeVisitCmd->func = CC_CALLBACK_0(ClippingNode::onBeforeVisit, this);
|
||||
renderer->addCommand(beforeVisitCmd);
|
||||
_beforeVisitCmd.init(0,_vertexZ);
|
||||
_beforeVisitCmd.func = CC_CALLBACK_0(ClippingNode::onBeforeVisit, this);
|
||||
renderer->addCommand(&_beforeVisitCmd);
|
||||
|
||||
_stencil->visit();
|
||||
|
||||
CustomCommand* afterDrawStencilCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
afterDrawStencilCmd->init(0,_vertexZ);
|
||||
afterDrawStencilCmd->func = CC_CALLBACK_0(ClippingNode::onAfterDrawStencil, this);
|
||||
renderer->addCommand(afterDrawStencilCmd);
|
||||
_afterDrawStencilCmd.init(0,_vertexZ);
|
||||
_afterDrawStencilCmd.func = CC_CALLBACK_0(ClippingNode::onAfterDrawStencil, this);
|
||||
renderer->addCommand(&_afterDrawStencilCmd);
|
||||
|
||||
int i = 0;
|
||||
|
||||
|
@ -253,10 +250,9 @@ void ClippingNode::visit()
|
|||
this->draw();
|
||||
}
|
||||
|
||||
CustomCommand* afterVisitCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
afterVisitCmd->init(0,_vertexZ);
|
||||
afterVisitCmd->func = CC_CALLBACK_0(ClippingNode::onAfterVisit, this);
|
||||
renderer->addCommand(afterVisitCmd);
|
||||
_afterVisitCmd.init(0,_vertexZ);
|
||||
_afterVisitCmd.func = CC_CALLBACK_0(ClippingNode::onAfterVisit, this);
|
||||
renderer->addCommand(&_afterVisitCmd);
|
||||
|
||||
renderer->popGroup();
|
||||
|
||||
|
|
|
@ -30,6 +30,8 @@
|
|||
|
||||
#include "CCNode.h"
|
||||
#include "CCGL.h"
|
||||
#include "renderer/CCGroupCommand.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -142,6 +144,11 @@ protected:
|
|||
|
||||
GLint _mask_layer_le;
|
||||
|
||||
GroupCommand _groupCommand;
|
||||
CustomCommand _beforeVisitCmd;
|
||||
CustomCommand _afterDrawStencilCmd;
|
||||
CustomCommand _afterVisitCmd;
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(ClippingNode);
|
||||
};
|
||||
|
|
|
@ -847,13 +847,10 @@ void Director::resume()
|
|||
|
||||
setAnimationInterval(_oldAnimationInterval);
|
||||
|
||||
if (gettimeofday(_lastUpdate, nullptr) != 0)
|
||||
{
|
||||
CCLOG("cocos2d: Director: Error in gettimeofday");
|
||||
}
|
||||
|
||||
_paused = false;
|
||||
_deltaTime = 0;
|
||||
// fix issue #3509, skip one fps to avoid incorrect time calculation.
|
||||
setNextDeltaTimeZero(true);
|
||||
}
|
||||
|
||||
// display the FPS using a LabelAtlas
|
||||
|
|
|
@ -241,10 +241,9 @@ void DrawNode::render()
|
|||
|
||||
void DrawNode::draw()
|
||||
{
|
||||
CustomCommand* cmd = CustomCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0, _vertexZ);
|
||||
cmd->func = CC_CALLBACK_0(DrawNode::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
_customCommand.init(0, _vertexZ);
|
||||
_customCommand.func = CC_CALLBACK_0(DrawNode::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_customCommand);
|
||||
}
|
||||
|
||||
void DrawNode::onDraw()
|
||||
|
|
|
@ -32,6 +32,7 @@
|
|||
|
||||
#include "CCNode.h"
|
||||
#include "ccTypes.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -105,6 +106,7 @@ protected:
|
|||
V2F_C4B_T2F *_buffer;
|
||||
|
||||
BlendFunc _blendFunc;
|
||||
CustomCommand _customCommand;
|
||||
|
||||
bool _dirty;
|
||||
|
||||
|
|
|
@ -475,7 +475,7 @@ void drawCardinalSpline( PointArray *config, float tension, unsigned int segmen
|
|||
|
||||
Vertex2F* vertices = new Vertex2F[segments + 1];
|
||||
|
||||
unsigned int p;
|
||||
ssize_t p;
|
||||
float lt;
|
||||
float deltaT = 1.0f / config->count();
|
||||
|
||||
|
|
|
@ -97,10 +97,10 @@ static EventListener::ListenerID __getListenerID(Event* event)
|
|||
return ret;
|
||||
}
|
||||
|
||||
EventDispatcher::EventListenerVector::EventListenerVector()
|
||||
: _sceneGraphListeners(nullptr)
|
||||
, _fixedListeners(nullptr)
|
||||
, _gt0Index(0)
|
||||
EventDispatcher::EventListenerVector::EventListenerVector() :
|
||||
_fixedListeners(nullptr),
|
||||
_sceneGraphListeners(nullptr),
|
||||
_gt0Index(0)
|
||||
{
|
||||
}
|
||||
|
||||
|
@ -501,11 +501,12 @@ void EventDispatcher::dispatchEventToListeners(EventListenerVector* listeners, s
|
|||
auto fixedPriorityListeners = listeners->getFixedPriorityListeners();
|
||||
auto sceneGraphPriorityListeners = listeners->getSceneGraphPriorityListeners();
|
||||
|
||||
int i = 0;
|
||||
ssize_t i = 0;
|
||||
// priority < 0
|
||||
if (fixedPriorityListeners)
|
||||
{
|
||||
for (; !fixedPriorityListeners->empty() && i < listeners->getGt0Index(); ++i)
|
||||
bool isEmpty = fixedPriorityListeners->empty();
|
||||
for (; !isEmpty && i < listeners->getGt0Index(); ++i)
|
||||
{
|
||||
auto l = fixedPriorityListeners->at(i);
|
||||
if (!l->isPaused() && l->isRegistered() && onEvent(l))
|
||||
|
@ -537,7 +538,8 @@ void EventDispatcher::dispatchEventToListeners(EventListenerVector* listeners, s
|
|||
if (!shouldStopPropagation)
|
||||
{
|
||||
// priority > 0
|
||||
for (; i < fixedPriorityListeners->size(); ++i)
|
||||
ssize_t size = fixedPriorityListeners->size();
|
||||
for (; i < size; ++i)
|
||||
{
|
||||
auto l = fixedPriorityListeners->at(i);
|
||||
|
||||
|
|
|
@ -67,8 +67,8 @@ EventListenerMouse* EventListenerMouse::clone()
|
|||
}
|
||||
|
||||
EventListenerMouse::EventListenerMouse()
|
||||
: onMouseUp(nullptr)
|
||||
, onMouseDown(nullptr)
|
||||
: onMouseDown(nullptr)
|
||||
, onMouseUp(nullptr)
|
||||
, onMouseMove(nullptr)
|
||||
, onMouseScroll(nullptr)
|
||||
{
|
||||
|
|
|
@ -102,16 +102,20 @@ Label* Label::createWithAtlas(FontAtlas *atlas, TextHAlignment alignment, int li
|
|||
|
||||
Label::Label(FontAtlas *atlas, TextHAlignment alignment, bool useDistanceField,bool useA8Shader)
|
||||
: _reusedLetter(nullptr)
|
||||
, _lineBreakWithoutSpaces(false)
|
||||
, _multilineEnable(true)
|
||||
, _commonLineHeight(0.0f)
|
||||
, _lineBreakWithoutSpaces(false)
|
||||
, _width(0.0f)
|
||||
, _alignment(alignment)
|
||||
, _currentUTF16String(0)
|
||||
, _originalUTF16String(0)
|
||||
, _advances(0)
|
||||
, _advances(nullptr)
|
||||
, _fontAtlas(atlas)
|
||||
, _isOpacityModifyRGB(true)
|
||||
, _useDistanceField(useDistanceField)
|
||||
, _useA8Shader(useA8Shader)
|
||||
, _fontSize(0)
|
||||
, _uniformEffectColor(0)
|
||||
{
|
||||
}
|
||||
|
||||
|
|
|
@ -113,7 +113,7 @@ bool LabelAtlas::initWithString(const std::string& theString, const std::string&
|
|||
//CCLabelAtlas - Atlas generation
|
||||
void LabelAtlas::updateAtlasValues()
|
||||
{
|
||||
auto n = _string.length();
|
||||
ssize_t n = _string.length();
|
||||
|
||||
const unsigned char *s = (unsigned char*)_string.c_str();
|
||||
|
||||
|
@ -130,7 +130,7 @@ void LabelAtlas::updateAtlasValues()
|
|||
|
||||
CCASSERT(n <= _textureAtlas->getCapacity(), "updateAtlasValues: Invalid String length");
|
||||
V3F_C4B_T2F_Quad* quads = _textureAtlas->getQuads();
|
||||
for(int i = 0; i < n; i++) {
|
||||
for(ssize_t i = 0; i < n; i++) {
|
||||
|
||||
unsigned char a = s[i] - _mapStartChar;
|
||||
float row = (float) (a % _itemsPerRow);
|
||||
|
@ -178,7 +178,7 @@ void LabelAtlas::updateAtlasValues()
|
|||
}
|
||||
if (n > 0 ){
|
||||
_textureAtlas->setDirty(true);
|
||||
auto totalQuads = _textureAtlas->getTotalQuads();
|
||||
ssize_t totalQuads = _textureAtlas->getTotalQuads();
|
||||
if (n > totalQuads) {
|
||||
_textureAtlas->increaseTotalQuadsWith(static_cast<int>(n - totalQuads));
|
||||
}
|
||||
|
@ -188,10 +188,10 @@ void LabelAtlas::updateAtlasValues()
|
|||
//CCLabelAtlas - LabelProtocol
|
||||
void LabelAtlas::setString(const std::string &label)
|
||||
{
|
||||
auto len = label.size();
|
||||
ssize_t len = label.size();
|
||||
if (len > _textureAtlas->getTotalQuads())
|
||||
{
|
||||
_textureAtlas->resizeCapacity(static_cast<int>(len));
|
||||
_textureAtlas->resizeCapacity(len);
|
||||
}
|
||||
_string.clear();
|
||||
_string = label;
|
||||
|
@ -201,7 +201,7 @@ void LabelAtlas::setString(const std::string &label)
|
|||
|
||||
this->setContentSize(s);
|
||||
|
||||
_quadsToDraw = static_cast<int>(len);
|
||||
_quadsToDraw = len;
|
||||
}
|
||||
|
||||
const std::string& LabelAtlas::getString(void) const
|
||||
|
|
|
@ -184,9 +184,15 @@ std::set<unsigned int>* CCBMFontConfiguration::parseConfigFile(const std::string
|
|||
{
|
||||
std::string fullpath = FileUtils::getInstance()->fullPathForFilename(controlFile);
|
||||
|
||||
std::string contents = FileUtils::getInstance()->getStringFromFile(fullpath);
|
||||
Data data = FileUtils::getInstance()->getDataFromFile(fullpath);
|
||||
CCASSERT((!data.isNull() && data.getSize() > 0), "CCBMFontConfiguration::parseConfigFile | Open file error.");
|
||||
|
||||
CCASSERT(!contents.empty(), "CCBMFontConfiguration::parseConfigFile | Open file error.");
|
||||
if (memcmp("BMF", data.getBytes(), 3) == 0) {
|
||||
std::set<unsigned int>* ret = parseBinaryConfigFile(data.getBytes(), data.getSize(), controlFile);
|
||||
return ret;
|
||||
}
|
||||
|
||||
std::string contents((const char*)data.getBytes(), data.getSize());
|
||||
|
||||
std::set<unsigned int> *validCharsString = new std::set<unsigned int>();
|
||||
|
||||
|
@ -260,6 +266,167 @@ std::set<unsigned int>* CCBMFontConfiguration::parseConfigFile(const std::string
|
|||
return validCharsString;
|
||||
}
|
||||
|
||||
std::set<unsigned int>* CCBMFontConfiguration::parseBinaryConfigFile(unsigned char* pData, unsigned long size, const std::string& controlFile)
|
||||
{
|
||||
/* based on http://www.angelcode.com/products/bmfont/doc/file_format.html file format */
|
||||
|
||||
set<unsigned int> *validCharsString = new set<unsigned int>();
|
||||
|
||||
unsigned long remains = size;
|
||||
|
||||
unsigned char version = pData[3];
|
||||
CCASSERT(version == 3, "Only version 3 is supported");
|
||||
|
||||
pData += 4; remains -= 4;
|
||||
|
||||
while (remains > 0)
|
||||
{
|
||||
unsigned char blockId = pData[0]; pData += 1; remains -= 1;
|
||||
uint32_t blockSize = 0; memcpy(&blockSize, pData, 4);
|
||||
|
||||
pData += 4; remains -= 4;
|
||||
|
||||
if (blockId == 1)
|
||||
{
|
||||
/*
|
||||
fontSize 2 int 0
|
||||
bitField 1 bits 2 bit 0: smooth, bit 1: unicode, bit 2: italic, bit 3: bold, bit 4: fixedHeigth, bits 5-7: reserved
|
||||
charSet 1 uint 3
|
||||
stretchH 2 uint 4
|
||||
aa 1 uint 6
|
||||
paddingUp 1 uint 7
|
||||
paddingRight 1 uint 8
|
||||
paddingDown 1 uint 9
|
||||
paddingLeft 1 uint 10
|
||||
spacingHoriz 1 uint 11
|
||||
spacingVert 1 uint 12
|
||||
outline 1 uint 13 added with version 2
|
||||
fontName n+1 string 14 null terminated string with length n
|
||||
*/
|
||||
|
||||
_padding.top = (unsigned char)pData[7];
|
||||
_padding.right = (unsigned char)pData[8];
|
||||
_padding.bottom = (unsigned char)pData[9];
|
||||
_padding.left = (unsigned char)pData[10];
|
||||
}
|
||||
else if (blockId == 2)
|
||||
{
|
||||
/*
|
||||
lineHeight 2 uint 0
|
||||
base 2 uint 2
|
||||
scaleW 2 uint 4
|
||||
scaleH 2 uint 6
|
||||
pages 2 uint 8
|
||||
bitField 1 bits 10 bits 0-6: reserved, bit 7: packed
|
||||
alphaChnl 1 uint 11
|
||||
redChnl 1 uint 12
|
||||
greenChnl 1 uint 13
|
||||
blueChnl 1 uint 14
|
||||
*/
|
||||
|
||||
uint16_t lineHeight = 0; memcpy(&lineHeight, pData, 2);
|
||||
_commonHeight = lineHeight;
|
||||
|
||||
uint16_t scaleW = 0; memcpy(&scaleW, pData + 4, 2);
|
||||
uint16_t scaleH = 0; memcpy(&scaleH, pData + 6, 2);
|
||||
|
||||
CCASSERT(scaleW <= Configuration::getInstance()->getMaxTextureSize() && scaleH <= Configuration::getInstance()->getMaxTextureSize(), "CCLabelBMFont: page can't be larger than supported");
|
||||
|
||||
uint16_t pages = 0; memcpy(&pages, pData + 8, 2);
|
||||
CCASSERT(pages == 1, "CCBitfontAtlas: only supports 1 page");
|
||||
}
|
||||
else if (blockId == 3)
|
||||
{
|
||||
/*
|
||||
pageNames p*(n+1) strings 0 p null terminated strings, each with length n
|
||||
*/
|
||||
|
||||
const char *value = (const char *)pData;
|
||||
size_t len = strlen(value);
|
||||
CCASSERT(len < blockSize, "Block size should be less then string");
|
||||
|
||||
_atlasName = FileUtils::getInstance()->fullPathFromRelativeFile(value, controlFile);
|
||||
}
|
||||
else if (blockId == 4)
|
||||
{
|
||||
/*
|
||||
id 4 uint 0+c*20 These fields are repeated until all characters have been described
|
||||
x 2 uint 4+c*20
|
||||
y 2 uint 6+c*20
|
||||
width 2 uint 8+c*20
|
||||
height 2 uint 10+c*20
|
||||
xoffset 2 int 12+c*20
|
||||
yoffset 2 int 14+c*20
|
||||
xadvance 2 int 16+c*20
|
||||
page 1 uint 18+c*20
|
||||
chnl 1 uint 19+c*20
|
||||
*/
|
||||
|
||||
unsigned long count = blockSize / 20;
|
||||
|
||||
for (unsigned long i = 0; i < count; i++)
|
||||
{
|
||||
tFontDefHashElement* element = (tFontDefHashElement*)malloc( sizeof(*element) );
|
||||
|
||||
uint32_t charId = 0; memcpy(&charId, pData + (i * 20), 4);
|
||||
element->fontDef.charID = charId;
|
||||
|
||||
uint16_t charX = 0; memcpy(&charX, pData + (i * 20) + 4, 2);
|
||||
element->fontDef.rect.origin.x = charX;
|
||||
|
||||
uint16_t charY = 0; memcpy(&charY, pData + (i * 20) + 6, 2);
|
||||
element->fontDef.rect.origin.y = charY;
|
||||
|
||||
uint16_t charWidth = 0; memcpy(&charWidth, pData + (i * 20) + 8, 2);
|
||||
element->fontDef.rect.size.width = charWidth;
|
||||
|
||||
uint16_t charHeight = 0; memcpy(&charHeight, pData + (i * 20) + 10, 2);
|
||||
element->fontDef.rect.size.height = charHeight;
|
||||
|
||||
int16_t xoffset = 0; memcpy(&xoffset, pData + (i * 20) + 12, 2);
|
||||
element->fontDef.xOffset = xoffset;
|
||||
|
||||
int16_t yoffset = 0; memcpy(&yoffset, pData + (i * 20) + 14, 2);
|
||||
element->fontDef.yOffset = yoffset;
|
||||
|
||||
int16_t xadvance = 0; memcpy(&xadvance, pData + (i * 20) + 16, 2);
|
||||
element->fontDef.xAdvance = xadvance;
|
||||
|
||||
element->key = element->fontDef.charID;
|
||||
HASH_ADD_INT(_fontDefDictionary, key, element);
|
||||
|
||||
validCharsString->insert(element->fontDef.charID);
|
||||
}
|
||||
}
|
||||
else if (blockId == 5) {
|
||||
/*
|
||||
first 4 uint 0+c*10 These fields are repeated until all kerning pairs have been described
|
||||
second 4 uint 4+c*10
|
||||
amount 2 int 8+c*10
|
||||
*/
|
||||
|
||||
unsigned long count = blockSize / 20;
|
||||
|
||||
for (unsigned long i = 0; i < count; i++)
|
||||
{
|
||||
|
||||
uint32_t first = 0; memcpy(&first, pData + (i * 10), 4);
|
||||
uint32_t second = 0; memcpy(&second, pData + (i * 10) + 4, 4);
|
||||
int16_t amount = 0; memcpy(&amount, pData + (i * 10) + 8, 2);
|
||||
|
||||
tKerningHashElement *element = (tKerningHashElement *)calloc( sizeof( *element ), 1 );
|
||||
element->amount = amount;
|
||||
element->key = (first<<16) | (second&0xffff);
|
||||
HASH_ADD_INT(_kerningDictionary,key, element);
|
||||
}
|
||||
}
|
||||
|
||||
pData += blockSize; remains -= blockSize;
|
||||
}
|
||||
|
||||
return validCharsString;
|
||||
}
|
||||
|
||||
void CCBMFontConfiguration::parseImageFileName(std::string line, const std::string& fntFile)
|
||||
{
|
||||
//////////////////////////////////////////////////////////////////////////
|
||||
|
@ -947,7 +1114,7 @@ void LabelBMFont::updateLabel()
|
|||
size_t size = multiline_string.size();
|
||||
unsigned short* str_new = new unsigned short[size + 1];
|
||||
|
||||
for (int j = 0; j < size; ++j)
|
||||
for (size_t j = 0; j < size; ++j)
|
||||
{
|
||||
str_new[j] = multiline_string[j];
|
||||
}
|
||||
|
|
|
@ -151,6 +151,7 @@ public:
|
|||
std::set<unsigned int>* getCharacterSet() const;
|
||||
private:
|
||||
std::set<unsigned int>* parseConfigFile(const std::string& controlFile);
|
||||
std::set<unsigned int>* parseBinaryConfigFile(unsigned char* pData, unsigned long size, const std::string& controlFile);
|
||||
void parseCharacterDefinition(std::string line, ccBMFontDef *characterDefinition);
|
||||
void parseInfoArguments(std::string line);
|
||||
void parseCommonArguments(std::string line);
|
||||
|
|
|
@ -200,7 +200,7 @@ bool LabelTextFormatter::multilineText(LabelTextFormatProtocol *theLabel)
|
|||
size_t size = multiline_string.size();
|
||||
unsigned short* strNew = new unsigned short[size + 1];
|
||||
|
||||
for (int j = 0; j < size; ++j)
|
||||
for (size_t j = 0; j < size; ++j)
|
||||
{
|
||||
strNew[j] = multiline_string[j];
|
||||
}
|
||||
|
|
|
@ -53,11 +53,11 @@ Layer::Layer()
|
|||
: _touchEnabled(false)
|
||||
, _accelerometerEnabled(false)
|
||||
, _keyboardEnabled(false)
|
||||
, _touchMode(Touch::DispatchMode::ALL_AT_ONCE)
|
||||
, _swallowsTouches(true)
|
||||
, _touchListener(nullptr)
|
||||
, _keyboardListener(nullptr)
|
||||
, _accelerationListener(nullptr)
|
||||
, _touchMode(Touch::DispatchMode::ALL_AT_ONCE)
|
||||
, _swallowsTouches(true)
|
||||
{
|
||||
_ignoreAnchorPointForPosition = true;
|
||||
setAnchorPoint(Point(0.5f, 0.5f));
|
||||
|
@ -564,10 +564,9 @@ void LayerColor::updateColor()
|
|||
|
||||
void LayerColor::draw()
|
||||
{
|
||||
CustomCommand* cmd = CustomCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0, _vertexZ);
|
||||
cmd->func = CC_CALLBACK_0(LayerColor::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
_customCommand.init(0, _vertexZ);
|
||||
_customCommand.func = CC_CALLBACK_0(LayerColor::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_customCommand);
|
||||
}
|
||||
|
||||
void LayerColor::onDraw()
|
||||
|
|
|
@ -35,6 +35,7 @@ THE SOFTWARE.
|
|||
#endif // EMSCRIPTEN
|
||||
|
||||
#include "CCEventKeyboard.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -296,6 +297,7 @@ protected:
|
|||
BlendFunc _blendFunc;
|
||||
Vertex2F _squareVertices[4];
|
||||
Color4F _squareColors[4];
|
||||
CustomCommand _customCommand;
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(LayerColor);
|
||||
|
|
|
@ -346,7 +346,7 @@ void Menu::alignItemsInColumns(int columns, va_list args)
|
|||
void Menu::alignItemsInColumnsWithArray(const ValueVector& rows)
|
||||
{
|
||||
int height = -5;
|
||||
int row = 0;
|
||||
size_t row = 0;
|
||||
int rowHeight = 0;
|
||||
int columnsOccupied = 0;
|
||||
int rowColumns = 0;
|
||||
|
@ -441,7 +441,7 @@ void Menu::alignItemsInRowsWithArray(const ValueVector& columns)
|
|||
|
||||
int width = -10;
|
||||
int columnHeight = -5;
|
||||
int column = 0;
|
||||
size_t column = 0;
|
||||
int columnWidth = 0;
|
||||
int rowsOccupied = 0;
|
||||
int columnRows;
|
||||
|
|
|
@ -358,10 +358,9 @@ void MotionStreak::draw()
|
|||
if(_nuPoints <= 1)
|
||||
return;
|
||||
kmGLGetMatrix(KM_GL_MODELVIEW,&_cachedMV);
|
||||
CustomCommand* cmd = CustomCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0,_vertexZ);
|
||||
cmd->func = CC_CALLBACK_0(MotionStreak::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
_customCommand.init(0,_vertexZ);
|
||||
_customCommand.func = CC_CALLBACK_0(MotionStreak::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_customCommand);
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -29,6 +29,7 @@ THE SOFTWARE.
|
|||
#include "CCTexture2D.h"
|
||||
#include "ccTypes.h"
|
||||
#include "CCNode.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
#ifdef EMSCRIPTEN
|
||||
#include "CCGLBufferedNode.h"
|
||||
#endif // EMSCRIPTEN
|
||||
|
@ -145,6 +146,8 @@ protected:
|
|||
GLubyte* _colorPointer;
|
||||
Tex2F* _texCoords;
|
||||
|
||||
CustomCommand _customCommand;
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(MotionStreak);
|
||||
};
|
||||
|
|
|
@ -44,7 +44,7 @@ THE SOFTWARE.
|
|||
#include "CCEventTouch.h"
|
||||
#include "CCScene.h"
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
#include "CCPhysicsBody.h"
|
||||
#endif
|
||||
|
||||
|
@ -123,7 +123,7 @@ Node::Node(void)
|
|||
, _isTransitionFinished(false)
|
||||
, _updateScriptHandler(0)
|
||||
, _componentContainer(nullptr)
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
, _physicsBody(nullptr)
|
||||
#endif
|
||||
, _displayedOpacity(255)
|
||||
|
@ -178,7 +178,7 @@ Node::~Node()
|
|||
|
||||
CC_SAFE_DELETE(_componentContainer);
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
CC_SAFE_RELEASE(_physicsBody);
|
||||
#endif
|
||||
}
|
||||
|
@ -264,7 +264,7 @@ void Node::setRotation(float newRotation)
|
|||
_rotationX = _rotationY = newRotation;
|
||||
_transformDirty = _inverseDirty = true;
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
if (_physicsBody)
|
||||
{
|
||||
_physicsBody->setRotation(newRotation);
|
||||
|
@ -354,7 +354,7 @@ void Node::setPosition(const Point& newPosition)
|
|||
_position = newPosition;
|
||||
_transformDirty = _inverseDirty = true;
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
if (_physicsBody)
|
||||
{
|
||||
_physicsBody->setPosition(newPosition);
|
||||
|
@ -604,7 +604,7 @@ void Node::addChild(Node *child, int zOrder, int tag)
|
|||
|
||||
this->insertChild(child, zOrder);
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
for (Node* node = this->getParent(); node != nullptr; node = node->getParent())
|
||||
{
|
||||
if (dynamic_cast<Scene*>(node) != nullptr)
|
||||
|
@ -739,7 +739,7 @@ void Node::detachChild(Node *child, ssize_t childIndex, bool doCleanup)
|
|||
child->onExit();
|
||||
}
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
if (child->_physicsBody != nullptr)
|
||||
{
|
||||
child->_physicsBody->removeFromWorld();
|
||||
|
@ -848,7 +848,7 @@ void Node::transformAncestors()
|
|||
|
||||
void Node::transform()
|
||||
{
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
updatePhysicsTransform();
|
||||
#endif
|
||||
|
||||
|
@ -867,13 +867,6 @@ void Node::onEnter()
|
|||
{
|
||||
_isTransitionFinished = false;
|
||||
|
||||
for( const auto &child: _children)
|
||||
child->onEnter();
|
||||
|
||||
this->resume();
|
||||
|
||||
_running = true;
|
||||
|
||||
if (_scriptType != kScriptTypeNone)
|
||||
{
|
||||
int action = kNodeOnEnter;
|
||||
|
@ -881,15 +874,19 @@ void Node::onEnter()
|
|||
ScriptEvent scriptEvent(kNodeEvent,(void*)&data);
|
||||
ScriptEngineManager::getInstance()->getScriptEngine()->sendEvent(&scriptEvent);
|
||||
}
|
||||
|
||||
for( const auto &child: _children)
|
||||
child->onEnter();
|
||||
|
||||
this->resume();
|
||||
|
||||
_running = true;
|
||||
}
|
||||
|
||||
void Node::onEnterTransitionDidFinish()
|
||||
{
|
||||
_isTransitionFinished = true;
|
||||
|
||||
for( const auto &child: _children)
|
||||
child->onEnterTransitionDidFinish();
|
||||
|
||||
if (_scriptType != kScriptTypeNone)
|
||||
{
|
||||
int action = kNodeOnEnterTransitionDidFinish;
|
||||
|
@ -897,6 +894,9 @@ void Node::onEnterTransitionDidFinish()
|
|||
ScriptEvent scriptEvent(kNodeEvent,(void*)&data);
|
||||
ScriptEngineManager::getInstance()->getScriptEngine()->sendEvent(&scriptEvent);
|
||||
}
|
||||
|
||||
for( const auto &child: _children)
|
||||
child->onEnterTransitionDidFinish();
|
||||
}
|
||||
|
||||
void Node::onExitTransitionDidStart()
|
||||
|
@ -918,6 +918,10 @@ void Node::onExit()
|
|||
this->pause();
|
||||
|
||||
_running = false;
|
||||
|
||||
for( const auto &child: _children)
|
||||
child->onExit();
|
||||
|
||||
if (_scriptType != kScriptTypeNone)
|
||||
{
|
||||
int action = kNodeOnExit;
|
||||
|
@ -925,9 +929,6 @@ void Node::onExit()
|
|||
ScriptEvent scriptEvent(kNodeEvent,(void*)&data);
|
||||
ScriptEngineManager::getInstance()->getScriptEngine()->sendEvent(&scriptEvent);
|
||||
}
|
||||
|
||||
for( const auto &child: _children)
|
||||
child->onExit();
|
||||
}
|
||||
|
||||
void Node::setEventDispatcher(EventDispatcher* dispatcher)
|
||||
|
@ -1170,8 +1171,8 @@ const kmMat4& Node::getNodeToParentTransform() const
|
|||
// If skew is needed, apply skew and then anchor point
|
||||
if (needsSkewMatrix)
|
||||
{
|
||||
kmMat4 skewMatrix = { 1, tanf(CC_DEGREES_TO_RADIANS(_skewY)), 0, 0,
|
||||
tanf(CC_DEGREES_TO_RADIANS(_skewX)), 1, 0, 0,
|
||||
kmMat4 skewMatrix = { 1, (float)tanf(CC_DEGREES_TO_RADIANS(_skewY)), 0, 0,
|
||||
(float)tanf(CC_DEGREES_TO_RADIANS(_skewX)), 1, 0, 0,
|
||||
0, 0, 1, 0,
|
||||
0, 0, 0, 1};
|
||||
|
||||
|
@ -1324,7 +1325,7 @@ Point Node::convertTouchToNodeSpaceAR(Touch *touch) const
|
|||
return this->convertToNodeSpaceAR(point);
|
||||
}
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
bool Node::updatePhysicsTransform()
|
||||
{
|
||||
if (_physicsBody != nullptr && _physicsBody->getWorld() != nullptr && !_physicsBody->isResting())
|
||||
|
@ -1374,7 +1375,7 @@ void Node::removeAllComponents()
|
|||
_componentContainer->removeAll();
|
||||
}
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
void Node::setPhysicsBody(PhysicsBody* body)
|
||||
{
|
||||
if (_physicsBody != nullptr)
|
||||
|
|
|
@ -54,7 +54,7 @@ class Component;
|
|||
class ComponentContainer;
|
||||
class EventDispatcher;
|
||||
class Scene;
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
class PhysicsBody;
|
||||
#endif
|
||||
|
||||
|
@ -590,7 +590,7 @@ public:
|
|||
*
|
||||
* @return a Node object whose tag equals to the input parameter
|
||||
*/
|
||||
Node * getChildByTag(int tag);
|
||||
virtual Node * getChildByTag(int tag);
|
||||
/**
|
||||
* Return an array of children
|
||||
*
|
||||
|
@ -615,7 +615,7 @@ public:
|
|||
*
|
||||
* @return The amount of children.
|
||||
*/
|
||||
ssize_t getChildrenCount() const;
|
||||
virtual ssize_t getChildrenCount() const;
|
||||
|
||||
/**
|
||||
* Sets the parent node
|
||||
|
@ -1341,7 +1341,7 @@ public:
|
|||
/// @} end of component functions
|
||||
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
/**
|
||||
* set the PhysicsBody that let the sprite effect with physics
|
||||
*/
|
||||
|
@ -1465,7 +1465,7 @@ protected:
|
|||
|
||||
ComponentContainer *_componentContainer; ///< Dictionary of components
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
PhysicsBody* _physicsBody; ///< the physicsBody the node have
|
||||
#endif
|
||||
|
||||
|
|
|
@ -47,8 +47,8 @@ NodeGrid* NodeGrid::create()
|
|||
}
|
||||
|
||||
NodeGrid::NodeGrid()
|
||||
: _nodeGrid(nullptr)
|
||||
, _gridTarget(nullptr)
|
||||
: _gridTarget(nullptr)
|
||||
, _nodeGrid(nullptr)
|
||||
{
|
||||
|
||||
}
|
||||
|
@ -92,10 +92,9 @@ void NodeGrid::visit()
|
|||
|
||||
Renderer* renderer = Director::getInstance()->getRenderer();
|
||||
|
||||
GroupCommand* groupCommand = GroupCommand::getCommandPool().generateCommand();
|
||||
groupCommand->init(0,_vertexZ);
|
||||
renderer->addCommand(groupCommand);
|
||||
renderer->pushGroup(groupCommand->getRenderQueueID());
|
||||
_groupCommand.init(0,_vertexZ);
|
||||
renderer->addCommand(&_groupCommand);
|
||||
renderer->pushGroup(_groupCommand.getRenderQueueID());
|
||||
|
||||
kmGLPushMatrix();
|
||||
Director::Projection beforeProjectionType;
|
||||
|
@ -105,10 +104,9 @@ void NodeGrid::visit()
|
|||
_nodeGrid->set2DProjection();
|
||||
}
|
||||
|
||||
CustomCommand* gridBeginCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
gridBeginCmd->init(0,_vertexZ);
|
||||
gridBeginCmd->func = CC_CALLBACK_0(NodeGrid::onGridBeginDraw, this);
|
||||
renderer->addCommand(gridBeginCmd);
|
||||
_gridBeginCommand.init(0,_vertexZ);
|
||||
_gridBeginCommand.func = CC_CALLBACK_0(NodeGrid::onGridBeginDraw, this);
|
||||
renderer->addCommand(&_gridBeginCommand);
|
||||
|
||||
this->transform();
|
||||
|
||||
|
@ -154,10 +152,9 @@ void NodeGrid::visit()
|
|||
director->setProjection(beforeProjectionType);
|
||||
}
|
||||
|
||||
CustomCommand* gridEndCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
gridEndCmd->init(0,_vertexZ);
|
||||
gridEndCmd->func = CC_CALLBACK_0(NodeGrid::onGridEndDraw, this);
|
||||
renderer->addCommand(gridEndCmd);
|
||||
_gridEndCommand.init(0,_vertexZ);
|
||||
_gridEndCommand.func = CC_CALLBACK_0(NodeGrid::onGridEndDraw, this);
|
||||
renderer->addCommand(&_gridEndCommand);
|
||||
|
||||
renderer->popGroup();
|
||||
|
||||
|
|
|
@ -27,6 +27,8 @@
|
|||
|
||||
#include "CCNode.h"
|
||||
#include "kazmath/GL/matrix.h"
|
||||
#include "renderer/CCGroupCommand.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -64,6 +66,9 @@ protected:
|
|||
|
||||
Node* _gridTarget;
|
||||
GridBase* _nodeGrid;
|
||||
GroupCommand _groupCommand;
|
||||
CustomCommand _gridBeginCommand;
|
||||
CustomCommand _gridEndCommand;
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(NodeGrid);
|
||||
|
|
|
@ -190,13 +190,7 @@ void NotificationCenter::postNotification(const std::string& name, Object *sende
|
|||
|
||||
if (observer->getName() == name && (observer->getSender() == sender || observer->getSender() == nullptr || sender == nullptr))
|
||||
{
|
||||
if (0 != observer->getHandler())
|
||||
{
|
||||
BasicScriptData data(this, (void*)name.c_str());
|
||||
ScriptEvent scriptEvent(kNotificationEvent,(void*)&data);
|
||||
ScriptEngineManager::getInstance()->getScriptEngine()->sendEvent(&scriptEvent);
|
||||
}
|
||||
else
|
||||
if (0 == observer->getHandler())
|
||||
{
|
||||
observer->performSelector(sender);
|
||||
}
|
||||
|
|
|
@ -42,7 +42,7 @@
|
|||
#include "platform/CCFileUtils.h"
|
||||
#include "kazmath/GL/matrix.h"
|
||||
#include "CCProfiling.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "CCRenderer.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
@ -392,8 +392,7 @@ void ParticleBatchNode::draw(void)
|
|||
kmMat4 mv;
|
||||
kmGLGetMatrix(KM_GL_MODELVIEW, &mv);
|
||||
|
||||
QuadCommand* cmd = QuadCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0,
|
||||
_quadCommand.init(0,
|
||||
_vertexZ,
|
||||
_textureAtlas->getTexture()->getName(),
|
||||
shader,
|
||||
|
@ -401,7 +400,7 @@ void ParticleBatchNode::draw(void)
|
|||
_textureAtlas->getQuads(),
|
||||
_textureAtlas->getTotalQuads(),
|
||||
mv);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_quadCommand);
|
||||
CC_PROFILER_STOP("CCParticleBatchNode - draw");
|
||||
}
|
||||
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
|
||||
#include "CCNode.h"
|
||||
#include "CCProtocols.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -140,6 +141,8 @@ private:
|
|||
private:
|
||||
/** the blend function used for drawing the quads */
|
||||
BlendFunc _blendFunc;
|
||||
// quad command
|
||||
QuadCommand _quadCommand;
|
||||
};
|
||||
|
||||
// end of particle_nodes group
|
||||
|
|
|
@ -39,7 +39,7 @@ THE SOFTWARE.
|
|||
#include "CCEventType.h"
|
||||
#include "CCConfiguration.h"
|
||||
#include "CCRenderer.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "CCCustomCommand.h"
|
||||
|
||||
// extern
|
||||
|
@ -443,9 +443,8 @@ void ParticleSystemQuad::draw()
|
|||
|
||||
auto shader = ShaderCache::getInstance()->getProgram(GLProgram::SHADER_NAME_POSITION_TEXTURE_COLOR_NO_MVP);
|
||||
|
||||
QuadCommand* cmd = QuadCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0, _vertexZ, _texture->getName(), shader, _blendFunc, _quads, _particleIdx, _modelViewTransform);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
_quadCommand.init(0, _vertexZ, _texture->getName(), shader, _blendFunc, _quads, _particleIdx, _modelViewTransform);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_quadCommand);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -28,6 +28,7 @@ THE SOFTWARE.
|
|||
#define __CC_PARTICLE_SYSTEM_QUAD_H__
|
||||
|
||||
#include "CCParticleSystem.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -151,6 +152,8 @@ protected:
|
|||
GLuint _buffersVBO[2]; //0: vertex 1: indices
|
||||
|
||||
kmMat4 _transformMatrix;
|
||||
|
||||
QuadCommand _quadCommand; // quad command
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(ParticleSystemQuad);
|
||||
};
|
||||
|
|
|
@ -532,10 +532,9 @@ void ProgressTimer::draw()
|
|||
if( ! _vertexData || ! _sprite)
|
||||
return;
|
||||
|
||||
CustomCommand* cmd = CustomCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0, _vertexZ);
|
||||
cmd->func = CC_CALLBACK_0(ProgressTimer::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
_customCommand.init(0, _vertexZ);
|
||||
_customCommand.func = CC_CALLBACK_0(ProgressTimer::onDraw, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_customCommand);
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -26,6 +26,7 @@ THE SOFTWARE.
|
|||
#define __MISC_NODE_CCPROGRESS_TIMER_H__
|
||||
|
||||
#include "CCSprite.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
#ifdef EMSCRIPTEN
|
||||
#include "CCGLBufferedNode.h"
|
||||
#endif // EMSCRIPTEN
|
||||
|
@ -144,6 +145,8 @@ protected:
|
|||
int _vertexDataCount;
|
||||
V2F_C4B_T2F *_vertexData;
|
||||
|
||||
CustomCommand _customCommand;
|
||||
|
||||
bool _reverseDirection;
|
||||
|
||||
private:
|
||||
|
|
|
@ -329,10 +329,9 @@ void RenderTexture::beginWithClear(float r, float g, float b, float a, float dep
|
|||
this->begin();
|
||||
|
||||
//clear screen
|
||||
CustomCommand* clearCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
clearCmd->init(0, _vertexZ);
|
||||
clearCmd->func = CC_CALLBACK_0(RenderTexture::onClear, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(clearCmd);
|
||||
_beginWithClearCommand.init(0, _vertexZ);
|
||||
_beginWithClearCommand.func = CC_CALLBACK_0(RenderTexture::onClear, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_beginWithClearCommand);
|
||||
}
|
||||
|
||||
//TODO find a better way to clear the screen, there is no need to rebind render buffer there.
|
||||
|
@ -348,11 +347,10 @@ void RenderTexture::clearDepth(float depthValue)
|
|||
|
||||
this->begin();
|
||||
|
||||
CustomCommand* cmd = CustomCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0, _vertexZ);
|
||||
cmd->func = CC_CALLBACK_0(RenderTexture::onClearDepth, this);
|
||||
_clearDepthCommand.init(0, _vertexZ);
|
||||
_clearDepthCommand.func = CC_CALLBACK_0(RenderTexture::onClearDepth, this);
|
||||
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_clearDepthCommand);
|
||||
|
||||
this->end();
|
||||
}
|
||||
|
@ -614,10 +612,9 @@ void RenderTexture::draw()
|
|||
begin();
|
||||
|
||||
//clear screen
|
||||
CustomCommand* clearCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
clearCmd->init(0, _vertexZ);
|
||||
clearCmd->func = CC_CALLBACK_0(RenderTexture::onClear, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(clearCmd);
|
||||
_clearCommand.init(0, _vertexZ);
|
||||
_clearCommand.func = CC_CALLBACK_0(RenderTexture::onClear, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_clearCommand);
|
||||
|
||||
//! make sure all children are drawn
|
||||
sortAllChildren();
|
||||
|
@ -643,28 +640,25 @@ void RenderTexture::begin()
|
|||
kmGLPushMatrix();
|
||||
kmGLGetMatrix(KM_GL_MODELVIEW, &_transformMatrix);
|
||||
|
||||
GroupCommand* groupCommand = GroupCommand::getCommandPool().generateCommand();
|
||||
groupCommand->init(0, _vertexZ);
|
||||
_groupCommand.init(0, _vertexZ);
|
||||
|
||||
Renderer *renderer = Director::getInstance()->getRenderer();
|
||||
renderer->addCommand(groupCommand);
|
||||
renderer->pushGroup(groupCommand->getRenderQueueID());
|
||||
renderer->addCommand(&_groupCommand);
|
||||
renderer->pushGroup(_groupCommand.getRenderQueueID());
|
||||
|
||||
CustomCommand* beginCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
beginCmd->init(0, _vertexZ);
|
||||
beginCmd->func = CC_CALLBACK_0(RenderTexture::onBegin, this);
|
||||
_beginCommand.init(0, _vertexZ);
|
||||
_beginCommand.func = CC_CALLBACK_0(RenderTexture::onBegin, this);
|
||||
|
||||
Director::getInstance()->getRenderer()->addCommand(beginCmd);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_beginCommand);
|
||||
}
|
||||
|
||||
void RenderTexture::end()
|
||||
{
|
||||
CustomCommand* endCmd = CustomCommand::getCommandPool().generateCommand();
|
||||
endCmd->init(0, _vertexZ);
|
||||
endCmd->func = CC_CALLBACK_0(RenderTexture::onEnd, this);
|
||||
_endCommand.init(0, _vertexZ);
|
||||
_endCommand.func = CC_CALLBACK_0(RenderTexture::onEnd, this);
|
||||
|
||||
Renderer *renderer = Director::getInstance()->getRenderer();
|
||||
renderer->addCommand(endCmd);
|
||||
renderer->addCommand(&_endCommand);
|
||||
renderer->popGroup();
|
||||
}
|
||||
|
||||
|
|
|
@ -29,6 +29,8 @@ THE SOFTWARE.
|
|||
#include "CCSprite.h"
|
||||
#include "kazmath/mat4.h"
|
||||
#include "platform/CCImage.h"
|
||||
#include "renderer/CCGroupCommand.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -187,6 +189,13 @@ protected:
|
|||
- [[renderTexture sprite] setBlendFunc:(BlendFunc){GL_ONE, GL_ONE_MINUS_SRC_ALPHA}];
|
||||
*/
|
||||
Sprite* _sprite;
|
||||
|
||||
GroupCommand _groupCommand;
|
||||
CustomCommand _beginWithClearCommand;
|
||||
CustomCommand _clearDepthCommand;
|
||||
CustomCommand _clearCommand;
|
||||
CustomCommand _beginCommand;
|
||||
CustomCommand _endCommand;
|
||||
protected:
|
||||
//renderer caches and callbacks
|
||||
void onBegin();
|
||||
|
|
|
@ -34,7 +34,7 @@ THE SOFTWARE.
|
|||
NS_CC_BEGIN
|
||||
|
||||
Scene::Scene()
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
: _physicsWorld(nullptr)
|
||||
#endif
|
||||
{
|
||||
|
@ -44,7 +44,7 @@ Scene::Scene()
|
|||
|
||||
Scene::~Scene()
|
||||
{
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
CC_SAFE_DELETE(_physicsWorld);
|
||||
#endif
|
||||
}
|
||||
|
@ -88,7 +88,22 @@ Scene* Scene::getScene()
|
|||
return this;
|
||||
}
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
void Scene::addChild(Node* child, int zOrder, int tag)
|
||||
{
|
||||
Node::addChild(child, zOrder, tag);
|
||||
addChildToPhysicsWorld(child);
|
||||
}
|
||||
|
||||
void Scene::update(float delta)
|
||||
{
|
||||
Node::update(delta);
|
||||
if (nullptr != _physicsWorld)
|
||||
{
|
||||
_physicsWorld->update(delta);
|
||||
}
|
||||
}
|
||||
|
||||
Scene *Scene::createWithPhysics()
|
||||
{
|
||||
Scene *ret = new Scene();
|
||||
|
@ -121,13 +136,6 @@ bool Scene::initWithPhysics()
|
|||
return ret;
|
||||
}
|
||||
|
||||
void Scene::addChild(Node* child, int zOrder, int tag)
|
||||
{
|
||||
Node::addChild(child, zOrder, tag);
|
||||
|
||||
addChildToPhysicsWorld(child);
|
||||
}
|
||||
|
||||
void Scene::addChildToPhysicsWorld(Node* child)
|
||||
{
|
||||
if (_physicsWorld)
|
||||
|
@ -149,18 +157,6 @@ void Scene::addChildToPhysicsWorld(Node* child)
|
|||
addToPhysicsWorldFunc(child);
|
||||
}
|
||||
}
|
||||
|
||||
void Scene::update(float delta)
|
||||
{
|
||||
Node::update(delta);
|
||||
|
||||
if (nullptr != _physicsWorld)
|
||||
{
|
||||
_physicsWorld->update(delta);
|
||||
}
|
||||
|
||||
}
|
||||
#endif
|
||||
|
||||
|
||||
NS_CC_END
|
||||
|
|
|
@ -52,32 +52,13 @@ class CC_DLL Scene : public Node
|
|||
public:
|
||||
/** creates a new Scene object */
|
||||
static Scene *create();
|
||||
#ifdef CC_USE_PHYSICS
|
||||
static Scene *createWithPhysics();
|
||||
#endif
|
||||
|
||||
// Overrides
|
||||
virtual Scene *getScene() override;
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
public:
|
||||
|
||||
inline PhysicsWorld* getPhysicsWorld() { return _physicsWorld; }
|
||||
|
||||
using Node::addChild;
|
||||
virtual void addChild(Node* child, int zOrder, int tag) override;
|
||||
virtual void update(float delta) override;
|
||||
virtual std::string getDescription() const override;
|
||||
|
||||
protected:
|
||||
bool initWithPhysics();
|
||||
void addChildToPhysicsWorld(Node* child);
|
||||
|
||||
PhysicsWorld* _physicsWorld;
|
||||
#endif // CC_USE_PHYSICS
|
||||
|
||||
|
||||
|
||||
protected:
|
||||
Scene();
|
||||
virtual ~Scene();
|
||||
|
@ -88,6 +69,19 @@ protected:
|
|||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(Scene);
|
||||
|
||||
#if CC_USE_PHYSICS
|
||||
public:
|
||||
virtual void addChild(Node* child, int zOrder, int tag) override;
|
||||
virtual void update(float delta) override;
|
||||
inline PhysicsWorld* getPhysicsWorld() { return _physicsWorld; }
|
||||
static Scene *createWithPhysics();
|
||||
protected:
|
||||
bool initWithPhysics();
|
||||
void addChildToPhysicsWorld(Node* child);
|
||||
|
||||
PhysicsWorld* _physicsWorld;
|
||||
#endif // CC_USE_PHYSICS
|
||||
};
|
||||
|
||||
// end of scene group
|
||||
|
|
|
@ -201,7 +201,6 @@ enum ScriptEventType
|
|||
{
|
||||
kNodeEvent = 0,
|
||||
kMenuClickedEvent,
|
||||
kNotificationEvent,
|
||||
kCallFuncEvent,
|
||||
kScheduleEvent,
|
||||
kTouchEvent,
|
||||
|
@ -210,16 +209,6 @@ enum ScriptEventType
|
|||
kAccelerometerEvent,
|
||||
kControlEvent,
|
||||
kCommonEvent,
|
||||
kTableViewEvent,//Now it's only used in LuaBinding
|
||||
kAssetsManagerEvent,//Now it's only used in Lua Binding
|
||||
kCocoStudioEventListener,//Now it's only used in Lua Binding
|
||||
kArmatureWrapper,//Now it's only used in Lua Binding
|
||||
kEventListenerAcc,//Now it's only used in Lua Binding
|
||||
kEventListenerKeyboard,//Now it's only used in Lua Binding
|
||||
kEventListenerTouch,//Now it's only used in Lua Binding
|
||||
kEventListenerTouches,//Now it's only used in Lua Binding
|
||||
kEventListenerMouse,//Now it's only used in Lua Binding
|
||||
kEventListenerCustom,////Now it's only used in Lua Binding
|
||||
};
|
||||
|
||||
struct BasicScriptData
|
||||
|
|
|
@ -45,7 +45,7 @@ THE SOFTWARE.
|
|||
#include "TransformUtils.h"
|
||||
#include "CCProfiling.h"
|
||||
#include "CCRenderer.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "CCFrustum.h"
|
||||
|
||||
// external
|
||||
|
@ -502,7 +502,7 @@ void Sprite::updateTransform(void)
|
|||
{
|
||||
CCASSERT(_batchNode, "updateTransform is only valid when Sprite is being rendered using an SpriteBatchNode");
|
||||
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
if (updatePhysicsTransform())
|
||||
{
|
||||
setDirty(true);
|
||||
|
@ -671,16 +671,11 @@ void Sprite::updateTransform(void)
|
|||
void Sprite::draw(void)
|
||||
{
|
||||
//TODO implement z order
|
||||
QuadCommand* renderCommand = QuadCommand::getCommandPool().generateCommand();
|
||||
renderCommand->init(0, _vertexZ, _texture->getName(), _shaderProgram, _blendFunc, &_quad, 1, _modelViewTransform);
|
||||
_quadCommand.init(0, _vertexZ, _texture->getName(), _shaderProgram, _blendFunc, &_quad, 1, _modelViewTransform);
|
||||
|
||||
// if(!culling())
|
||||
// {
|
||||
// renderCommand->releaseToCommandPool();
|
||||
// }
|
||||
// else
|
||||
// if(culling())
|
||||
{
|
||||
Director::getInstance()->getRenderer()->addCommand(renderCommand);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_quadCommand);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -711,7 +706,7 @@ bool Sprite::culling() const
|
|||
|
||||
void Sprite::updateQuadVertices()
|
||||
{
|
||||
#ifdef CC_USE_PHYSICS
|
||||
#if CC_USE_PHYSICS
|
||||
updatePhysicsTransform();
|
||||
setDirty(true);
|
||||
#endif
|
||||
|
|
|
@ -37,6 +37,7 @@ THE SOFTWARE.
|
|||
#include "CCGLBufferedNode.h"
|
||||
#endif // EMSCRIPTEN
|
||||
#include "CCPhysicsBody.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "kazmath/kazmath.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
@ -545,6 +546,7 @@ protected:
|
|||
//
|
||||
BlendFunc _blendFunc; /// It's required for TextureProtocol inheritance
|
||||
Texture2D* _texture; /// Texture2D object that is used to render the sprite
|
||||
QuadCommand _quadCommand; /// quad command
|
||||
|
||||
//
|
||||
// Shared data
|
||||
|
|
|
@ -43,7 +43,7 @@ THE SOFTWARE.
|
|||
#include "CCLayer.h"
|
||||
#include "CCScene.h"
|
||||
#include "CCRenderer.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
// external
|
||||
#include "kazmath/GL/matrix.h"
|
||||
|
||||
|
@ -360,8 +360,7 @@ void SpriteBatchNode::draw()
|
|||
kmMat4 mv;
|
||||
kmGLGetMatrix(KM_GL_MODELVIEW, &mv);
|
||||
|
||||
QuadCommand* cmd = QuadCommand::getCommandPool().generateCommand();
|
||||
cmd->init(0,
|
||||
_quadCommand.init(0,
|
||||
_vertexZ,
|
||||
_textureAtlas->getTexture()->getName(),
|
||||
shader,
|
||||
|
@ -369,7 +368,7 @@ void SpriteBatchNode::draw()
|
|||
_textureAtlas->getQuads(),
|
||||
_textureAtlas->getTotalQuads(),
|
||||
mv);
|
||||
Director::getInstance()->getRenderer()->addCommand(cmd);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_quadCommand);
|
||||
}
|
||||
|
||||
void SpriteBatchNode::increaseAtlasCapacity(void)
|
||||
|
|
|
@ -34,6 +34,7 @@ THE SOFTWARE.
|
|||
#include "CCProtocols.h"
|
||||
#include "CCTextureAtlas.h"
|
||||
#include "ccMacros.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -187,6 +188,7 @@ protected:
|
|||
|
||||
TextureAtlas *_textureAtlas;
|
||||
BlendFunc _blendFunc;
|
||||
QuadCommand _quadCommand; // quad command
|
||||
|
||||
// all descendants: children, grand children, etc...
|
||||
// There is not need to retain/release these objects, since they are already retained by _children
|
||||
|
|
|
@ -209,7 +209,7 @@ void TextFieldTTF::deleteBackward()
|
|||
}
|
||||
|
||||
// get the delete byte number
|
||||
int deleteLen = 1; // default, erase 1 byte
|
||||
size_t deleteLen = 1; // default, erase 1 byte
|
||||
|
||||
while(0x80 == (0xC0 & _inputText.at(len - deleteLen)))
|
||||
{
|
||||
|
|
|
@ -51,7 +51,7 @@ TextPageDef::~TextPageDef()
|
|||
{
|
||||
size_t numLines = _lines.size();
|
||||
|
||||
for( int c = 0; c<numLines; ++c )
|
||||
for( size_t c = 0; c<numLines; ++c )
|
||||
{
|
||||
delete _lines[c];
|
||||
}
|
||||
|
|
|
@ -89,7 +89,7 @@ void TextureCache::purgeSharedTextureCache()
|
|||
|
||||
std::string TextureCache::getDescription() const
|
||||
{
|
||||
return StringUtils::format("<TextureCache | Number of textures = %lu>", _textures.size());
|
||||
return StringUtils::format("<TextureCache | Number of textures = %zd>", _textures.size());
|
||||
}
|
||||
|
||||
void TextureCache::addImageAsync(const std::string &path, Object *target, SEL_CallFuncO selector)
|
||||
|
|
|
@ -30,6 +30,7 @@ THE SOFTWARE.
|
|||
#include "CCActionGrid.h"
|
||||
#include "CCActionPageTurn3D.h"
|
||||
#include "CCNodeGrid.h"
|
||||
#include "renderer/CCRenderer.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -78,24 +79,43 @@ void TransitionPageTurn::sceneOrder()
|
|||
_isInSceneOnTop = _back;
|
||||
}
|
||||
|
||||
void TransitionPageTurn::onEnablePolygonOffset()
|
||||
{
|
||||
glEnable(GL_POLYGON_OFFSET_FILL);
|
||||
glPolygonOffset(POLYGON_OFFSET_FACTOR, POLYGON_OFFSET_UNITS);
|
||||
}
|
||||
|
||||
void TransitionPageTurn::onDisablePolygonOffset()
|
||||
{
|
||||
glDisable(GL_POLYGON_OFFSET_FILL);
|
||||
glPolygonOffset(0, 0);
|
||||
}
|
||||
|
||||
void TransitionPageTurn::draw()
|
||||
{
|
||||
Scene::draw();
|
||||
|
||||
if( _isInSceneOnTop ) {
|
||||
_outSceneProxy->visit();
|
||||
glEnable(GL_POLYGON_OFFSET_FILL);
|
||||
glPolygonOffset(POLYGON_OFFSET_FACTOR, POLYGON_OFFSET_UNITS);
|
||||
_enableOffsetCmd.init(0, _vertexZ);
|
||||
_enableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onEnablePolygonOffset, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_enableOffsetCmd);
|
||||
_inSceneProxy->visit();
|
||||
glDisable(GL_POLYGON_OFFSET_FILL);
|
||||
glPolygonOffset(0, 0);
|
||||
_disableOffsetCmd.init(0, _vertexZ);
|
||||
_disableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onDisablePolygonOffset, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_disableOffsetCmd);
|
||||
} else {
|
||||
_inSceneProxy->visit();
|
||||
glEnable(GL_POLYGON_OFFSET_FILL);
|
||||
glPolygonOffset(POLYGON_OFFSET_FACTOR, POLYGON_OFFSET_UNITS);
|
||||
|
||||
_enableOffsetCmd.init(0, _vertexZ);
|
||||
_enableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onEnablePolygonOffset, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_enableOffsetCmd);
|
||||
|
||||
_outSceneProxy->visit();
|
||||
glDisable(GL_POLYGON_OFFSET_FILL);
|
||||
glPolygonOffset(0, 0);
|
||||
|
||||
_disableOffsetCmd.init(0, _vertexZ);
|
||||
_disableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onDisablePolygonOffset, this);
|
||||
Director::getInstance()->getRenderer()->addCommand(&_disableOffsetCmd);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -27,6 +27,7 @@ THE SOFTWARE.
|
|||
#define __CCPAGE_TURN_TRANSITION_H__
|
||||
|
||||
#include "CCTransition.h"
|
||||
#include "renderer/CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
@ -96,6 +97,12 @@ protected:
|
|||
bool _back;
|
||||
static float POLYGON_OFFSET_FACTOR;
|
||||
static float POLYGON_OFFSET_UNITS;
|
||||
|
||||
protected:
|
||||
CustomCommand _enableOffsetCmd;
|
||||
CustomCommand _disableOffsetCmd;
|
||||
void onEnablePolygonOffset();
|
||||
void onDisablePolygonOffset();
|
||||
};
|
||||
|
||||
// end of transition group
|
||||
|
|
|
@ -268,7 +268,7 @@ To enable set it to a value different than 0. Disabled by default.
|
|||
|
||||
/** Use physics integration API */
|
||||
#ifndef CC_USE_PHYSICS
|
||||
#define CC_USE_PHYSICS
|
||||
#define CC_USE_PHYSICS 1
|
||||
#endif
|
||||
|
||||
#endif // __CCCONFIG_H__
|
||||
|
|
|
@ -1200,7 +1200,8 @@ bool Image::initWithPVRv2Data(const unsigned char * data, ssize_t dataLen)
|
|||
}
|
||||
|
||||
if (! configuration->supportsNPOT() &&
|
||||
(header->width != ccNextPOT(header->width) || header->height != ccNextPOT(header->height)))
|
||||
(static_cast<int>(header->width) != ccNextPOT(header->width)
|
||||
|| static_cast<int>(header->height) != ccNextPOT(header->height)))
|
||||
{
|
||||
CCLOG("cocos2d: ERROR: Loading an NPOT texture (%dx%d) but is not supported on this device", header->width, header->height);
|
||||
return false;
|
||||
|
|
|
@ -33,6 +33,7 @@
|
|||
|
||||
#define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, "cocos2dx/nativeactivity.cpp", __VA_ARGS__))
|
||||
#define LOGW(...) ((void)__android_log_print(ANDROID_LOG_WARN, "cocos2dx/nativeactivity.cpp", __VA_ARGS__))
|
||||
#define LOGE(...) ((void)__android_log_print(ANDROID_LOG_ERROR, "cocos2dx/nativeactivity.cpp", __VA_ARGS__))
|
||||
|
||||
#define LOG_RENDER_DEBUG(...)
|
||||
// #define LOG_RENDER_DEBUG(...) ((void)__android_log_print(ANDROID_LOG_INFO, "cocos2dx/nativeactivity.cpp", __VA_ARGS__))
|
||||
|
@ -40,6 +41,13 @@
|
|||
#define LOG_EVENTS_DEBUG(...)
|
||||
// #define LOG_EVENTS_DEBUG(...) ((void)__android_log_print(ANDROID_LOG_INFO, "cocos2dx/nativeactivity.cpp", __VA_ARGS__))
|
||||
|
||||
/* For debug builds, always enable the debug traces in this library */
|
||||
#ifndef NDEBUG
|
||||
# define LOGV(...) ((void)__android_log_print(ANDROID_LOG_VERBOSE, "cocos2dx/nativeactivity.cpp", __VA_ARGS__))
|
||||
#else
|
||||
# define LOGV(...) ((void)0)
|
||||
#endif
|
||||
|
||||
void cocos_android_app_init(struct android_app* app);
|
||||
|
||||
/**
|
||||
|
@ -454,6 +462,7 @@ static int32_t engine_handle_input(struct android_app* app, AInputEvent* event)
|
|||
LOG_EVENTS_DEBUG("engine_handle_input(%X, %X), pthread_self() = %X", app, event, thisthread);
|
||||
|
||||
struct engine* engine = (struct engine*)app->userData;
|
||||
|
||||
if (AInputEvent_getType(event) == AINPUT_EVENT_TYPE_MOTION) {
|
||||
engine->animating = 1;
|
||||
engine->state.x = AMotionEvent_getX(event, 0);
|
||||
|
@ -563,6 +572,23 @@ static void onContentRectChanged(ANativeActivity* activity, const ARect* rect) {
|
|||
isContentRectChanged = true;
|
||||
}
|
||||
|
||||
static void process_input(struct android_app* app, struct android_poll_source* source) {
|
||||
AInputEvent* event = NULL;
|
||||
int processed = 0;
|
||||
while (AInputQueue_hasEvents( app->inputQueue ) && AInputQueue_getEvent(app->inputQueue, &event) >= 0) {
|
||||
LOGV("New input event: type=%d\n", AInputEvent_getType(event));
|
||||
if (AInputQueue_preDispatchEvent(app->inputQueue, event)) {
|
||||
continue;
|
||||
}
|
||||
int32_t handled = 0;
|
||||
if (app->onInputEvent != NULL) handled = app->onInputEvent(app, event);
|
||||
AInputQueue_finishEvent(app->inputQueue, event, handled);
|
||||
processed = 1;
|
||||
}
|
||||
if (processed == 0) {
|
||||
LOGE("Failure reading next input event: %s\n", strerror(errno));
|
||||
}
|
||||
}
|
||||
/**
|
||||
* This is the main entry point of a native application that is using
|
||||
* android_native_app_glue. It runs in its own thread, with its own
|
||||
|
@ -577,6 +603,7 @@ void android_main(struct android_app* state) {
|
|||
state->userData = &engine;
|
||||
state->onAppCmd = engine_handle_cmd;
|
||||
state->onInputEvent = engine_handle_input;
|
||||
state->inputPollSource.process = process_input;
|
||||
engine.app = state;
|
||||
|
||||
// Prepare to monitor accelerometer
|
||||
|
|
|
@ -150,7 +150,7 @@ static Data getData(const std::string& filename, bool forString)
|
|||
}
|
||||
DWORD sizeRead = 0;
|
||||
BOOL successed = FALSE;
|
||||
successed = ::ReadFile(fileHandle, buffer, *size, &sizeRead, NULL);
|
||||
successed = ::ReadFile(fileHandle, buffer, size, &sizeRead, NULL);
|
||||
::CloseHandle(fileHandle);
|
||||
|
||||
if (!successed)
|
||||
|
@ -180,22 +180,21 @@ static Data getData(const std::string& filename, bool forString)
|
|||
return ret;
|
||||
}
|
||||
|
||||
std::string FileUtilsAndroid::getStringFromFile(const std::string& filename)
|
||||
std::string FileUtilsWin32::getStringFromFile(const std::string& filename)
|
||||
{
|
||||
Data data = getData(filename, true);
|
||||
std::string ret((const char*)data.getBytes());
|
||||
return ret;
|
||||
}
|
||||
|
||||
Data FileUtilsAndroid::getDataFromFile(const std::string& filename)
|
||||
Data FileUtilsWin32::getDataFromFile(const std::string& filename)
|
||||
{
|
||||
return getData(filename, false);
|
||||
}
|
||||
|
||||
unsigned char* FileUtilsWin32::getFileData(const char* filename, const char* mode, ssize_t* size)
|
||||
unsigned char* FileUtilsWin32::getFileData(const std::string& filename, const char* mode, ssize_t* size)
|
||||
{
|
||||
unsigned char * pBuffer = NULL;
|
||||
CCASSERT(filename != NULL && size != NULL && mode != NULL, "Invalid parameters.");
|
||||
*size = 0;
|
||||
do
|
||||
{
|
||||
|
|
|
@ -58,7 +58,7 @@ protected:
|
|||
* @return Upon success, a pointer to the data is returned, otherwise NULL.
|
||||
* @warning Recall: you are responsible for calling delete[] on any Non-NULL pointer returned.
|
||||
*/
|
||||
CC_DEPRECATED_ATTRIBUTE virtual unsigned char* getFileData(const char* filename, const char* mode, ssize_t * size) override;
|
||||
CC_DEPRECATED_ATTRIBUTE virtual unsigned char* getFileData(const std::string& filename, const char* mode, ssize_t * size) override;
|
||||
|
||||
/**
|
||||
* Gets string from a file.
|
||||
|
|
|
@ -25,13 +25,12 @@
|
|||
#include "CCCustomCommand.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
RenderCommandPool<CustomCommand> CustomCommand::_commandPool;
|
||||
|
||||
CustomCommand::CustomCommand()
|
||||
:RenderCommand()
|
||||
, func(nullptr)
|
||||
, _viewport(0)
|
||||
, _depth(0)
|
||||
, func(nullptr)
|
||||
{
|
||||
_type = RenderCommand::Type::CUSTOM_COMMAND;
|
||||
}
|
||||
|
@ -66,9 +65,4 @@ void CustomCommand::execute()
|
|||
}
|
||||
}
|
||||
|
||||
void CustomCommand::releaseToCommandPool()
|
||||
{
|
||||
getCommandPool().pushBackCommand(this);
|
||||
}
|
||||
|
||||
NS_CC_END
|
|
@ -34,7 +34,10 @@ NS_CC_BEGIN
|
|||
class CustomCommand : public RenderCommand
|
||||
{
|
||||
public:
|
||||
static RenderCommandPool<CustomCommand>& getCommandPool() { return _commandPool; }
|
||||
CustomCommand();
|
||||
~CustomCommand();
|
||||
|
||||
public:
|
||||
|
||||
void init(int viewport, int32_t depth);
|
||||
|
||||
|
@ -48,18 +51,11 @@ public:
|
|||
void execute();
|
||||
|
||||
inline bool isTranslucent() { return true; }
|
||||
virtual void releaseToCommandPool() override;
|
||||
std::function<void()> func;
|
||||
|
||||
protected:
|
||||
CustomCommand();
|
||||
~CustomCommand();
|
||||
|
||||
int _viewport;
|
||||
int32_t _depth;
|
||||
static RenderCommandPool<CustomCommand> _commandPool;
|
||||
|
||||
friend class RenderCommandPool<CustomCommand>;
|
||||
};
|
||||
|
||||
NS_CC_END
|
||||
|
|
|
@ -28,7 +28,6 @@
|
|||
#include "CCDirector.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
RenderCommandPool<GroupCommand> GroupCommand::_commandPool;
|
||||
|
||||
static GroupCommandManager* s_instance;
|
||||
GroupCommandManager *GroupCommandManager::getInstance()
|
||||
|
@ -119,10 +118,4 @@ int64_t GroupCommand::generateID()
|
|||
return _id;
|
||||
}
|
||||
|
||||
void GroupCommand::releaseToCommandPool()
|
||||
{
|
||||
getCommandPool().pushBackCommand(this);
|
||||
}
|
||||
|
||||
|
||||
NS_CC_END
|
||||
|
|
|
@ -53,7 +53,10 @@ protected:
|
|||
class GroupCommand : public RenderCommand
|
||||
{
|
||||
public:
|
||||
static RenderCommandPool<GroupCommand>& getCommandPool() { return _commandPool; }
|
||||
GroupCommand();
|
||||
~GroupCommand();
|
||||
|
||||
public:
|
||||
|
||||
void init(int viewport, int32_t depth);
|
||||
|
||||
|
@ -66,18 +69,11 @@ public:
|
|||
|
||||
inline bool isTranslucent() {return true;}
|
||||
inline int getRenderQueueID() {return _renderQueueID;}
|
||||
virtual void releaseToCommandPool() override;
|
||||
|
||||
protected:
|
||||
GroupCommand();
|
||||
~GroupCommand();
|
||||
|
||||
int _viewport;
|
||||
int32_t _depth;
|
||||
int _renderQueueID;
|
||||
static RenderCommandPool<GroupCommand> _commandPool;
|
||||
|
||||
friend class RenderCommandPool<GroupCommand>;
|
||||
};
|
||||
|
||||
NS_CC_END
|
||||
|
|
|
@ -23,11 +23,10 @@
|
|||
****************************************************************************/
|
||||
|
||||
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "ccGLStateCache.h"
|
||||
|
||||
NS_CC_BEGIN
|
||||
RenderCommandPool<QuadCommand> QuadCommand::_commandPool;
|
||||
|
||||
QuadCommand::QuadCommand()
|
||||
:RenderCommand()
|
||||
|
@ -172,9 +171,4 @@ void QuadCommand::useMaterial()
|
|||
GL::blendFunc(_blendType.src, _blendType.dst);
|
||||
}
|
||||
|
||||
void QuadCommand::releaseToCommandPool()
|
||||
{
|
||||
getCommandPool().pushBackCommand(this);
|
||||
}
|
||||
|
||||
NS_CC_END
|
|
@ -37,7 +37,6 @@ NS_CC_BEGIN
|
|||
class QuadCommand : public RenderCommand
|
||||
{
|
||||
public:
|
||||
static RenderCommandPool<QuadCommand>& getCommandPool() { return _commandPool; }
|
||||
|
||||
QuadCommand();
|
||||
~QuadCommand();
|
||||
|
@ -69,8 +68,6 @@ public:
|
|||
|
||||
inline BlendFunc getBlendType() const { return _blendType; }
|
||||
|
||||
virtual void releaseToCommandPool() override;
|
||||
|
||||
protected:
|
||||
int32_t _materialID;
|
||||
|
||||
|
@ -91,12 +88,7 @@ protected:
|
|||
V3F_C4B_T2F_Quad* _quad;
|
||||
ssize_t _quadCount;
|
||||
ssize_t _capacity;
|
||||
|
||||
friend class RenderCommandPool<QuadCommand>;
|
||||
|
||||
static RenderCommandPool<QuadCommand> _commandPool;
|
||||
};
|
||||
|
||||
NS_CC_END
|
||||
|
||||
#endif //_CC_QUADCOMMAND_H_
|
||||
|
|
|
@ -37,11 +37,11 @@ RenderCommand::~RenderCommand()
|
|||
{
|
||||
}
|
||||
|
||||
void printBits(size_t const size, void const * const ptr)
|
||||
void printBits(ssize_t const size, void const * const ptr)
|
||||
{
|
||||
unsigned char *b = (unsigned char*) ptr;
|
||||
unsigned char byte;
|
||||
int i, j;
|
||||
ssize_t i, j;
|
||||
|
||||
for (i=size-1;i>=0;i--)
|
||||
{
|
||||
|
|
|
@ -52,7 +52,6 @@ public:
|
|||
virtual inline int64_t getID() { return _id; }
|
||||
|
||||
virtual inline Type getType() { return _type; }
|
||||
virtual void releaseToCommandPool() =0;
|
||||
|
||||
protected:
|
||||
RenderCommand();
|
||||
|
|
|
@ -26,7 +26,7 @@
|
|||
#include "CCShaderCache.h"
|
||||
#include "ccGLStateCache.h"
|
||||
#include "CCCustomCommand.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "CCGroupCommand.h"
|
||||
#include "CCConfiguration.h"
|
||||
#include "CCNotificationCenter.h"
|
||||
|
@ -41,9 +41,9 @@ using namespace std;
|
|||
|
||||
Renderer::Renderer()
|
||||
:_lastMaterialID(0)
|
||||
,_numQuads(0)
|
||||
,_firstCommand(0)
|
||||
,_lastCommand(0)
|
||||
,_numQuads(0)
|
||||
,_glViewAssigned(false)
|
||||
{
|
||||
_commandGroupStack.push(DEFAULT_RENDER_QUEUE);
|
||||
|
@ -296,13 +296,13 @@ void Renderer::render()
|
|||
}
|
||||
}
|
||||
|
||||
//TODO give command back to command pool
|
||||
for (size_t j = 0 ; j < _renderGroups.size(); j++)
|
||||
{
|
||||
for (const auto &cmd : _renderGroups[j])
|
||||
{
|
||||
cmd->releaseToCommandPool();
|
||||
}
|
||||
//commands are owned by nodes
|
||||
// for (const auto &cmd : _renderGroups[j])
|
||||
// {
|
||||
// cmd->releaseToCommandPool();
|
||||
// }
|
||||
_renderGroups[j].clear();
|
||||
}
|
||||
|
||||
|
|
|
@ -39,13 +39,17 @@ _size(0)
|
|||
CCLOGINFO("In the empty constructor of Data.");
|
||||
}
|
||||
|
||||
Data::Data(Data&& other)
|
||||
Data::Data(Data&& other) :
|
||||
_bytes(nullptr),
|
||||
_size(0)
|
||||
{
|
||||
CCLOGINFO("In the move constructor of Data.");
|
||||
move(other);
|
||||
}
|
||||
|
||||
Data::Data(const Data& other)
|
||||
Data::Data(const Data& other) :
|
||||
_bytes(nullptr),
|
||||
_size(0)
|
||||
{
|
||||
CCLOGINFO("In the copy constructor of Data.");
|
||||
copy(other._bytes, other._size);
|
||||
|
|
|
@ -28,6 +28,7 @@
|
|||
#include "CCPlatformMacros.h"
|
||||
#include <stdint.h> // for ssize_t on android
|
||||
#include <string> // for ssize_t on linux
|
||||
#include "CCStdC.h" // for ssize_t on window
|
||||
|
||||
NS_CC_BEGIN
|
||||
|
||||
|
|
|
@ -107,10 +107,22 @@ public:
|
|||
_data.reserve(capacity);
|
||||
}
|
||||
|
||||
/** Returns capacity of the map */
|
||||
ssize_t capacity() const
|
||||
/** Returns the number of buckets in the Map container. */
|
||||
ssize_t bucketCount() const
|
||||
{
|
||||
return _data.capacity();
|
||||
return _data.bucket_count();
|
||||
}
|
||||
|
||||
/** Returns the number of elements in bucket n. */
|
||||
ssize_t bucketSize(ssize_t n) const
|
||||
{
|
||||
return _data.bucket_size(n);
|
||||
}
|
||||
|
||||
/** Returns the bucket number where the element with key k is located. */
|
||||
ssize_t bucket(const K& k) const
|
||||
{
|
||||
return _data.bucket(k);
|
||||
}
|
||||
|
||||
/** The number of elements in the map. */
|
||||
|
|
|
@ -34,18 +34,19 @@ NS_CC_BEGIN
|
|||
typedef std::vector<std::string> strArray;
|
||||
|
||||
// string toolkit
|
||||
static inline void split(std::string src, const char* token, strArray& vect)
|
||||
static inline void split(const std::string& src, const std::string& token, strArray& vect)
|
||||
{
|
||||
size_t nend = 0;
|
||||
size_t nbegin = 0;
|
||||
while(nend != -1)
|
||||
size_t tokenSize = token.size();
|
||||
while(nend != std::string::npos)
|
||||
{
|
||||
nend = src.find(token, nbegin);
|
||||
if(nend == -1)
|
||||
if(nend == std::string::npos)
|
||||
vect.push_back(src.substr(nbegin, src.length()-nbegin));
|
||||
else
|
||||
vect.push_back(src.substr(nbegin, nend-nbegin));
|
||||
nbegin = nend + strlen(token);
|
||||
nbegin = nend + tokenSize;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -69,7 +70,7 @@ static bool splitWithForm(const std::string& str, strArray& strs)
|
|||
size_t nPosRight = content.find('}');
|
||||
|
||||
// don't have '{' and '}'
|
||||
CC_BREAK_IF(nPosLeft == (int)std::string::npos || nPosRight == (int)std::string::npos);
|
||||
CC_BREAK_IF(nPosLeft == std::string::npos || nPosRight == std::string::npos);
|
||||
// '}' is before '{'
|
||||
CC_BREAK_IF(nPosLeft > nPosRight);
|
||||
|
||||
|
@ -80,7 +81,7 @@ static bool splitWithForm(const std::string& str, strArray& strs)
|
|||
size_t nPos1 = pointStr.find('{');
|
||||
size_t nPos2 = pointStr.find('}');
|
||||
// contain '{' or '}'
|
||||
CC_BREAK_IF(nPos1 != (int)std::string::npos || nPos2 != (int)std::string::npos);
|
||||
CC_BREAK_IF(nPos1 != std::string::npos || nPos2 != std::string::npos);
|
||||
|
||||
split(pointStr, ",", strs);
|
||||
if (strs.size() != 2 || strs[0].length() == 0 || strs[1].length() == 0)
|
||||
|
@ -111,19 +112,19 @@ Rect RectFromString(const std::string& str)
|
|||
size_t nPosRight = content.find('}');
|
||||
for (int i = 1; i < 3; ++i)
|
||||
{
|
||||
if (nPosRight == (int)std::string::npos)
|
||||
if (nPosRight == std::string::npos)
|
||||
{
|
||||
break;
|
||||
}
|
||||
nPosRight = content.find('}', nPosRight + 1);
|
||||
}
|
||||
CC_BREAK_IF(nPosLeft == (int)std::string::npos || nPosRight == (int)std::string::npos);
|
||||
CC_BREAK_IF(nPosLeft == std::string::npos || nPosRight == std::string::npos);
|
||||
|
||||
content = content.substr(nPosLeft + 1, nPosRight - nPosLeft - 1);
|
||||
size_t nPointEnd = content.find('}');
|
||||
CC_BREAK_IF(nPointEnd == (int)std::string::npos);
|
||||
CC_BREAK_IF(nPointEnd == std::string::npos);
|
||||
nPointEnd = content.find(',', nPointEnd);
|
||||
CC_BREAK_IF(nPointEnd == (int)std::string::npos);
|
||||
CC_BREAK_IF(nPointEnd == std::string::npos);
|
||||
|
||||
// get the point string and size string
|
||||
std::string pointStr = content.substr(0, nPointEnd);
|
||||
|
|
|
@ -6,6 +6,7 @@ LOCAL_MODULE := cocostudio_static
|
|||
LOCAL_MODULE_FILENAME := libcocostudio
|
||||
|
||||
LOCAL_SRC_FILES := CCActionFrame.cpp \
|
||||
CCActionEaseEx.cpp \
|
||||
CCActionFrameEasing.cpp \
|
||||
CCActionManagerEx.cpp \
|
||||
CCActionNode.cpp \
|
||||
|
@ -34,13 +35,13 @@ CCComAudio.cpp \
|
|||
CCComController.cpp \
|
||||
CCComRender.cpp \
|
||||
CCInputDelegate.cpp \
|
||||
CSContentJsonDictionary.cpp \
|
||||
DictionaryHelper.cpp \
|
||||
CCSGUIReader.cpp \
|
||||
CCSSceneReader.cpp \
|
||||
../../../external/json/json_reader.cpp \
|
||||
../../../external/json/json_value.cpp \
|
||||
../../../external/json/json_writer.cpp
|
||||
ObjectFactory.cpp \
|
||||
TriggerBase.cpp \
|
||||
TriggerMng.cpp \
|
||||
TriggerObj.cpp
|
||||
|
||||
LOCAL_EXPORT_C_INCLUDES := $(LOCAL_PATH)/.. \
|
||||
$(LOCAL_PATH)/../../../external
|
||||
|
|
|
@ -0,0 +1,748 @@
|
|||
/****************************************************************************
|
||||
Copyright (c) 2013 cocos2d-x.org
|
||||
|
||||
http://www.cocos2d-x.org
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#include "CCActionEaseEx.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
static inline float bezieratFunction( float a, float b, float c, float d, float t )
|
||||
{
|
||||
return (powf(1-t,3) * a + 3*t*(powf(1-t,2))*b + 3*powf(t,2)*(1-t)*c + powf(t,3)*d );
|
||||
}
|
||||
|
||||
EaseBezierAction* EaseBezierAction::create(cocos2d::ActionInterval* action)
|
||||
{
|
||||
EaseBezierAction *ret = new EaseBezierAction();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
void EaseBezierAction::setBezierParamer( float p0, float p1, float p2, float p3)
|
||||
{
|
||||
_p0 = p0;
|
||||
_p1 = p1;
|
||||
_p2 = p2;
|
||||
_p3 = p3;
|
||||
}
|
||||
|
||||
EaseBezierAction* EaseBezierAction::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseBezierAction();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->setBezierParamer(_p0,_p1,_p2,_p3);
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseBezierAction::update(float time)
|
||||
{
|
||||
_inner->update(bezieratFunction(_p0,_p1,_p2,_p3,time));
|
||||
}
|
||||
|
||||
EaseBezierAction* EaseBezierAction::reverse() const
|
||||
{
|
||||
EaseBezierAction* reverseAction = EaseBezierAction::create(_inner->reverse());
|
||||
reverseAction->setBezierParamer(_p3,_p2,_p1,_p0);
|
||||
return reverseAction;
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuadraticActionIn
|
||||
//
|
||||
|
||||
EaseQuadraticActionIn* EaseQuadraticActionIn::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuadraticActionIn *ret = new EaseQuadraticActionIn();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuadraticActionIn* EaseQuadraticActionIn::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuadraticActionIn();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
void EaseQuadraticActionIn::update(float time)
|
||||
{
|
||||
_inner->update(powf(time,2));
|
||||
}
|
||||
|
||||
EaseQuadraticActionIn* EaseQuadraticActionIn::reverse() const
|
||||
{
|
||||
return EaseQuadraticActionIn::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuadraticActionOut
|
||||
//
|
||||
|
||||
EaseQuadraticActionOut* EaseQuadraticActionOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuadraticActionOut *ret = new EaseQuadraticActionOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuadraticActionOut* EaseQuadraticActionOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuadraticActionOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuadraticActionOut::update(float time)
|
||||
{
|
||||
_inner->update(-time*(time-2));
|
||||
}
|
||||
|
||||
EaseQuadraticActionOut* EaseQuadraticActionOut::reverse() const
|
||||
{
|
||||
return EaseQuadraticActionOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuadraticActionInOut
|
||||
//
|
||||
|
||||
EaseQuadraticActionInOut* EaseQuadraticActionInOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuadraticActionInOut *ret = new EaseQuadraticActionInOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuadraticActionInOut* EaseQuadraticActionInOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuadraticActionInOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuadraticActionInOut::update(float time)
|
||||
{
|
||||
float resultTime = time;
|
||||
time = time*0.5f;
|
||||
if (time < 1)
|
||||
{
|
||||
resultTime = time * time * 0.5f;
|
||||
}
|
||||
else
|
||||
{
|
||||
--time;
|
||||
resultTime = -0.5f * (time * (time - 2) - 1);
|
||||
}
|
||||
|
||||
_inner->update(resultTime);
|
||||
}
|
||||
|
||||
EaseQuadraticActionInOut* EaseQuadraticActionInOut::reverse() const
|
||||
{
|
||||
return EaseQuadraticActionInOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuarticActionIn
|
||||
//
|
||||
|
||||
EaseQuarticActionIn* EaseQuarticActionIn::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuarticActionIn *ret = new EaseQuarticActionIn();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuarticActionIn* EaseQuarticActionIn::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuarticActionIn();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuarticActionIn::update(float time)
|
||||
{
|
||||
_inner->update(powf(time,4.0f));
|
||||
}
|
||||
|
||||
EaseQuarticActionIn* EaseQuarticActionIn::reverse() const
|
||||
{
|
||||
return EaseQuarticActionIn::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuarticActionOut
|
||||
//
|
||||
|
||||
EaseQuarticActionOut* EaseQuarticActionOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuarticActionOut *ret = new EaseQuarticActionOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuarticActionOut* EaseQuarticActionOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuarticActionOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuarticActionOut::update(float time)
|
||||
{
|
||||
float tempTime = time -1;
|
||||
_inner->update(1- powf(tempTime,4.0f));
|
||||
}
|
||||
|
||||
EaseQuarticActionOut* EaseQuarticActionOut::reverse() const
|
||||
{
|
||||
return EaseQuarticActionOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuarticActionInOut
|
||||
//
|
||||
|
||||
EaseQuarticActionInOut* EaseQuarticActionInOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuarticActionInOut *ret = new EaseQuarticActionInOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuarticActionInOut* EaseQuarticActionInOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuarticActionInOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuarticActionInOut::update(float time)
|
||||
{
|
||||
float tempTime = time * 0.5f;
|
||||
if (tempTime < 1)
|
||||
tempTime = powf(tempTime,4.0f) * 0.5f;
|
||||
else
|
||||
{
|
||||
tempTime -= 2;
|
||||
tempTime = 1 - powf(tempTime,4.0f)* 0.5f;
|
||||
}
|
||||
|
||||
_inner->update(tempTime);
|
||||
}
|
||||
|
||||
EaseQuarticActionInOut* EaseQuarticActionInOut::reverse() const
|
||||
{
|
||||
return EaseQuarticActionInOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuinticActionIn
|
||||
//
|
||||
|
||||
EaseQuinticActionIn* EaseQuinticActionIn::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuinticActionIn *ret = new EaseQuinticActionIn();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuinticActionIn* EaseQuinticActionIn::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuinticActionIn();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuinticActionIn::update(float time)
|
||||
{
|
||||
_inner->update(powf(time,5.0f));
|
||||
}
|
||||
|
||||
EaseQuinticActionIn* EaseQuinticActionIn::reverse() const
|
||||
{
|
||||
return EaseQuinticActionIn::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuinticActionOut
|
||||
//
|
||||
|
||||
EaseQuinticActionOut* EaseQuinticActionOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuinticActionOut *ret = new EaseQuinticActionOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuinticActionOut* EaseQuinticActionOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuinticActionOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuinticActionOut::update(float time)
|
||||
{
|
||||
float tempTime = time -1;
|
||||
_inner->update(1 + powf(tempTime,5.0f));
|
||||
}
|
||||
|
||||
EaseQuinticActionOut* EaseQuinticActionOut::reverse() const
|
||||
{
|
||||
return EaseQuinticActionOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseQuinticActionInOut
|
||||
//
|
||||
|
||||
EaseQuinticActionInOut* EaseQuinticActionInOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseQuinticActionInOut *ret = new EaseQuinticActionInOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseQuinticActionInOut* EaseQuinticActionInOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseQuinticActionInOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseQuinticActionInOut::update(float time)
|
||||
{
|
||||
float tempTime = time * 0.5f;
|
||||
if (tempTime < 1)
|
||||
tempTime = powf(tempTime,5.0f) * 0.5f;
|
||||
else
|
||||
{
|
||||
tempTime -= 2;
|
||||
tempTime = 1 + powf(tempTime,5.0f)* 0.5f;
|
||||
}
|
||||
|
||||
_inner->update(tempTime);
|
||||
}
|
||||
|
||||
EaseQuinticActionInOut* EaseQuinticActionInOut::reverse() const
|
||||
{
|
||||
return EaseQuinticActionInOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseCircleActionIn
|
||||
//
|
||||
|
||||
EaseCircleActionIn* EaseCircleActionIn::create(ActionInterval* action)
|
||||
{
|
||||
EaseCircleActionIn *ret = new EaseCircleActionIn();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseCircleActionIn* EaseCircleActionIn::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseCircleActionIn();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseCircleActionIn::update(float time)
|
||||
{
|
||||
_inner->update(1-sqrt(1-powf(time,2.0f)));
|
||||
}
|
||||
|
||||
EaseCircleActionIn* EaseCircleActionIn::reverse() const
|
||||
{
|
||||
return EaseCircleActionIn::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseCircleActionOut
|
||||
//
|
||||
|
||||
EaseCircleActionOut* EaseCircleActionOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseCircleActionOut *ret = new EaseCircleActionOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseCircleActionOut* EaseCircleActionOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseCircleActionOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseCircleActionOut::update(float time)
|
||||
{
|
||||
float tempTime = time - 1;
|
||||
_inner->update(sqrt(1-powf(tempTime,2.0f)));
|
||||
}
|
||||
|
||||
EaseCircleActionOut* EaseCircleActionOut::reverse() const
|
||||
{
|
||||
return EaseCircleActionOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseCircleActionInOut
|
||||
//
|
||||
|
||||
EaseCircleActionInOut* EaseCircleActionInOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseCircleActionInOut *ret = new EaseCircleActionInOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseCircleActionInOut* EaseCircleActionInOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseCircleActionInOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseCircleActionInOut::update(float time)
|
||||
{
|
||||
float tempTime = time * 0.5f;
|
||||
if (tempTime < 1)
|
||||
tempTime = (1- sqrt(1 - powf(tempTime,2.0f))) * 0.5f;
|
||||
else
|
||||
{
|
||||
tempTime -= 2;
|
||||
tempTime = (1+ sqrt(1 - powf(tempTime,2.0f)));
|
||||
}
|
||||
|
||||
_inner->update(time);
|
||||
}
|
||||
|
||||
EaseCircleActionInOut* EaseCircleActionInOut::reverse() const
|
||||
{
|
||||
return EaseCircleActionInOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseCubicActionIn
|
||||
//
|
||||
|
||||
EaseCubicActionIn* EaseCubicActionIn::create(ActionInterval* action)
|
||||
{
|
||||
EaseCubicActionIn *ret = new EaseCubicActionIn();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseCubicActionIn* EaseCubicActionIn::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseCubicActionIn();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseCubicActionIn::update(float time)
|
||||
{
|
||||
_inner->update(powf(time,3.0f));
|
||||
}
|
||||
|
||||
EaseCubicActionIn* EaseCubicActionIn::reverse() const
|
||||
{
|
||||
return EaseCubicActionIn::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseCubicActionOut
|
||||
//
|
||||
|
||||
EaseCubicActionOut* EaseCubicActionOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseCubicActionOut *ret = new EaseCubicActionOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseCubicActionOut* EaseCubicActionOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseCubicActionOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseCubicActionOut::update(float time)
|
||||
{
|
||||
_inner->update(1+powf(time,3.0f));
|
||||
}
|
||||
|
||||
EaseCubicActionOut* EaseCubicActionOut::reverse() const
|
||||
{
|
||||
return EaseCubicActionOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
//
|
||||
// EaseCubicActionInOut
|
||||
//
|
||||
|
||||
EaseCubicActionInOut* EaseCubicActionInOut::create(ActionInterval* action)
|
||||
{
|
||||
EaseCubicActionInOut *ret = new EaseCubicActionInOut();
|
||||
if (ret)
|
||||
{
|
||||
if (ret->initWithAction(action))
|
||||
{
|
||||
ret->autorelease();
|
||||
}
|
||||
else
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(ret);
|
||||
}
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
EaseCubicActionInOut* EaseCubicActionInOut::clone() const
|
||||
{
|
||||
// no copy constructor
|
||||
auto a = new EaseCubicActionInOut();
|
||||
a->initWithAction(_inner->clone());
|
||||
a->autorelease();
|
||||
return a;
|
||||
}
|
||||
|
||||
void EaseCubicActionInOut::update(float time)
|
||||
{
|
||||
float tempTime = time * 0.5f;
|
||||
if (tempTime < 1)
|
||||
tempTime = powf(tempTime,3.0f) * 0.5f;
|
||||
else
|
||||
{
|
||||
tempTime -= 2;
|
||||
tempTime = 1 + powf(tempTime,3.0f)* 0.5f;
|
||||
}
|
||||
_inner->update(time);
|
||||
}
|
||||
|
||||
EaseCubicActionInOut* EaseCubicActionInOut::reverse() const
|
||||
{
|
||||
return EaseCubicActionInOut::create(_inner->reverse());
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,397 @@
|
|||
/****************************************************************************
|
||||
Copyright (c) 2013 cocos2d-x.org
|
||||
|
||||
http://www.cocos2d-x.org
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in
|
||||
all copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||
THE SOFTWARE.
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef __ActionEaseEx_H__
|
||||
#define __ActionEaseEx_H__
|
||||
|
||||
#include "cocos2d.h"
|
||||
#include "cocostudio/CocoStudio.h"
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
/**
|
||||
@brief Ease Bezier
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseBezierAction : public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseBezierAction* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseBezierAction* clone() const override;
|
||||
virtual EaseBezierAction* reverse() const override;
|
||||
|
||||
virtual void setBezierParamer( float p0, float p1, float p2, float p3);
|
||||
|
||||
protected:
|
||||
EaseBezierAction() {}
|
||||
virtual ~EaseBezierAction() {}
|
||||
|
||||
float _p0;
|
||||
float _p1;
|
||||
float _p2;
|
||||
float _p3;
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseBezierAction);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quadratic In
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuadraticActionIn:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuadraticActionIn* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuadraticActionIn* clone() const override;
|
||||
virtual EaseQuadraticActionIn* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuadraticActionIn() {}
|
||||
virtual ~EaseQuadraticActionIn() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuadraticActionIn);
|
||||
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quadratic Out
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuadraticActionOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuadraticActionOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuadraticActionOut* clone() const override;
|
||||
virtual EaseQuadraticActionOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuadraticActionOut() {}
|
||||
virtual ~EaseQuadraticActionOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuadraticActionOut);
|
||||
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quadratic InOut
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuadraticActionInOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuadraticActionInOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuadraticActionInOut* clone() const override;
|
||||
virtual EaseQuadraticActionInOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuadraticActionInOut() {}
|
||||
virtual ~EaseQuadraticActionInOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuadraticActionInOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quartic In
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuarticActionIn:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuarticActionIn* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuarticActionIn* clone() const override;
|
||||
virtual EaseQuarticActionIn* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuarticActionIn() {}
|
||||
virtual ~EaseQuarticActionIn() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuarticActionIn);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quartic Out
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuarticActionOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuarticActionOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuarticActionOut* clone() const override;
|
||||
virtual EaseQuarticActionOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuarticActionOut() {}
|
||||
virtual ~EaseQuarticActionOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuarticActionOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quartic InOut
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuarticActionInOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuarticActionInOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuarticActionInOut* clone() const override;
|
||||
virtual EaseQuarticActionInOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuarticActionInOut() {}
|
||||
virtual ~EaseQuarticActionInOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuarticActionInOut);
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
@brief Ease Quintic In
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuinticActionIn:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuinticActionIn* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuinticActionIn* clone() const override;
|
||||
virtual EaseQuinticActionIn* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuinticActionIn() {}
|
||||
virtual ~EaseQuinticActionIn() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuinticActionIn);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quintic Out
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuinticActionOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuinticActionOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuinticActionOut* clone() const override;
|
||||
virtual EaseQuinticActionOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuinticActionOut() {}
|
||||
virtual ~EaseQuinticActionOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuinticActionOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Quintic InOut
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseQuinticActionInOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseQuinticActionInOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseQuinticActionInOut* clone() const override;
|
||||
virtual EaseQuinticActionInOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseQuinticActionInOut() {}
|
||||
virtual ~EaseQuinticActionInOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseQuinticActionInOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Circle In
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseCircleActionIn:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseCircleActionIn* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseCircleActionIn* clone() const override;
|
||||
virtual EaseCircleActionIn* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseCircleActionIn() {}
|
||||
virtual ~EaseCircleActionIn() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseCircleActionIn);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Circle Out
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseCircleActionOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseCircleActionOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseCircleActionOut* clone() const override;
|
||||
virtual EaseCircleActionOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseCircleActionOut() {}
|
||||
virtual ~EaseCircleActionOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseCircleActionOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Circle InOut
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseCircleActionInOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseCircleActionInOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseCircleActionInOut* clone() const override;
|
||||
virtual EaseCircleActionInOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseCircleActionInOut() {}
|
||||
virtual ~EaseCircleActionInOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseCircleActionInOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Cubic In
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseCubicActionIn:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseCubicActionIn* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseCubicActionIn* clone() const override;
|
||||
virtual EaseCubicActionIn* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseCubicActionIn() {}
|
||||
virtual ~EaseCubicActionIn() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseCubicActionIn);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Cubic Out
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseCubicActionOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseCubicActionOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseCubicActionOut* clone() const override;
|
||||
virtual EaseCubicActionOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseCubicActionOut() {}
|
||||
virtual ~EaseCubicActionOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseCubicActionOut);
|
||||
};
|
||||
|
||||
/**
|
||||
@brief Ease Cubic InOut
|
||||
@ingroup Actions
|
||||
*/
|
||||
class EaseCubicActionInOut:public cocos2d::ActionEase
|
||||
{
|
||||
public:
|
||||
/** creates the action */
|
||||
static EaseCubicActionInOut* create(cocos2d::ActionInterval* action);
|
||||
|
||||
virtual void update(float time) override;
|
||||
virtual EaseCubicActionInOut* clone() const override;
|
||||
virtual EaseCubicActionInOut* reverse() const override;
|
||||
|
||||
protected:
|
||||
EaseCubicActionInOut() {}
|
||||
virtual ~EaseCubicActionInOut() {}
|
||||
|
||||
private:
|
||||
CC_DISALLOW_COPY_AND_ASSIGN(EaseCubicActionInOut);
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
#endif
|
|
@ -23,6 +23,7 @@
|
|||
****************************************************************************/
|
||||
|
||||
#include "CCActionFrame.h"
|
||||
#include "CCActionEaseEx.h"
|
||||
|
||||
using namespace cocos2d;
|
||||
|
||||
|
@ -30,9 +31,9 @@ namespace cocostudio {
|
|||
|
||||
ActionFrame::ActionFrame()
|
||||
: _frameType(0)
|
||||
, _easingType(0)
|
||||
, _frameIndex(0)
|
||||
, _fTime(0.0f)
|
||||
, _easingType(FrameEaseType::LINERAR)
|
||||
{
|
||||
|
||||
}
|
||||
|
@ -70,17 +71,158 @@ int ActionFrame::getFrameType()
|
|||
|
||||
void ActionFrame::setEasingType(int easingType)
|
||||
{
|
||||
_easingType = easingType;
|
||||
_easingType = (FrameEaseType)easingType;
|
||||
}
|
||||
int ActionFrame::getEasingType()
|
||||
{
|
||||
return _easingType;
|
||||
return (int)_easingType;
|
||||
}
|
||||
|
||||
Action* ActionFrame::getAction(float fDuration)
|
||||
ActionInterval* ActionFrame::getAction(float fDuration)
|
||||
{
|
||||
log("Need a definition of <getAction> for ActionFrame");
|
||||
return NULL;
|
||||
return nullptr;
|
||||
}
|
||||
ActionInterval* ActionFrame::getAction(float fDuration,ActionFrame* srcFrame)
|
||||
{
|
||||
return this->getAction(fDuration);
|
||||
}
|
||||
|
||||
void ActionFrame::setEasingParameter(std::vector<float>& parameter)
|
||||
{
|
||||
_Parameter.clear();
|
||||
|
||||
for (size_t i = 0; i<parameter.size(); i++)
|
||||
{
|
||||
_Parameter.push_back(parameter[i]);
|
||||
}
|
||||
}
|
||||
|
||||
ActionInterval* ActionFrame::getEasingAction(ActionInterval* action)
|
||||
{
|
||||
if (action == nullptr)
|
||||
{
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
switch (_easingType)
|
||||
{
|
||||
case FrameEaseType::Custom:
|
||||
{
|
||||
EaseBezierAction* cAction = EaseBezierAction::create(action);
|
||||
cAction->setBezierParamer(_Parameter[0],_Parameter[1],_Parameter[2],_Parameter[3]);
|
||||
return cAction;
|
||||
}
|
||||
break;
|
||||
case FrameEaseType::LINERAR:
|
||||
return action;
|
||||
break;
|
||||
case FrameEaseType::SINE_EASEIN:
|
||||
return EaseSineIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::SINE_EASEOUT:
|
||||
return EaseSineOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::SINE_EASEINOUT:
|
||||
return EaseSineInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUAD_EASEIN:
|
||||
return EaseQuadraticActionIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUAD_EASEOUT:
|
||||
return EaseQuadraticActionOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUAD_EASEINOUT:
|
||||
return EaseQuadraticActionInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::CUBIC_EASEIN:
|
||||
return EaseCubicActionIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::CUBIC_EASEOUT:
|
||||
return EaseCubicActionOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::CUBIC_EASEINOUT:
|
||||
return EaseCubicActionInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUART_EASEIN:
|
||||
return EaseQuarticActionIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUART_EASEOUT:
|
||||
return EaseQuadraticActionOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUART_EASEINOUT:
|
||||
return EaseQuarticActionInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUINT_EASEIN:
|
||||
return EaseQuinticActionIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUINT_EASEOUT:
|
||||
return EaseQuinticActionOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::QUINT_EASEINOUT:
|
||||
return EaseQuinticActionInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::EXPO_EASEIN:
|
||||
return EaseExponentialIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::EXPO_EASEOUT:
|
||||
return EaseExponentialOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::EXPO_EASEINOUT:
|
||||
return EaseExponentialInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::CIRC_EASEIN:
|
||||
return EaseCircleActionIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::CIRC_EASEOUT:
|
||||
return EaseCircleActionOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::CIRC_EASEINOUT:
|
||||
return EaseCircleActionInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::ELASTIC_EASEIN:
|
||||
{
|
||||
EaseElasticIn* cAction = EaseElasticIn::create(action);
|
||||
cAction->setPeriod(_Parameter[0]);
|
||||
return cAction;
|
||||
}
|
||||
break;
|
||||
case FrameEaseType::ELASTIC_EASEOUT:
|
||||
{
|
||||
EaseElasticOut* cAction = EaseElasticOut::create(action);
|
||||
cAction->setPeriod(_Parameter[0]);
|
||||
return cAction;
|
||||
}
|
||||
break;
|
||||
case FrameEaseType::ELASTIC_EASEINOUT:
|
||||
{
|
||||
EaseElasticInOut* cAction = EaseElasticInOut::create(action);
|
||||
cAction->setPeriod(_Parameter[0]);
|
||||
return cAction;
|
||||
}
|
||||
break;
|
||||
case FrameEaseType::BACK_EASEIN:
|
||||
return EaseBackIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::BACK_EASEOUT:
|
||||
return EaseBackOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::BACK_EASEINOUT:
|
||||
return EaseBackInOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::BOUNCE_EASEIN:
|
||||
return EaseBounceIn::create(action);
|
||||
break;
|
||||
case FrameEaseType::BOUNCE_EASEOUT:
|
||||
return EaseBounceOut::create(action);
|
||||
break;
|
||||
case FrameEaseType::BOUNCE_EASEINOUT:
|
||||
return EaseBounceInOut::create(action);
|
||||
break;
|
||||
default:
|
||||
return action;
|
||||
break;
|
||||
}
|
||||
}
|
||||
//////////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
@ -101,9 +243,9 @@ Point ActionMoveFrame::getPosition()
|
|||
{
|
||||
return _position;
|
||||
}
|
||||
Action* ActionMoveFrame::getAction(float fDuration)
|
||||
ActionInterval* ActionMoveFrame::getAction(float fDuration)
|
||||
{
|
||||
return MoveTo::create(fDuration,_position);
|
||||
return this->getEasingAction(CCMoveTo::create(fDuration,_position));
|
||||
}
|
||||
//////////////////////////////////////////////////////////////////////////
|
||||
|
||||
|
@ -139,9 +281,9 @@ float ActionScaleFrame::getScaleY()
|
|||
return _scaleY;
|
||||
}
|
||||
|
||||
Action* ActionScaleFrame::getAction(float fDuration)
|
||||
ActionInterval* ActionScaleFrame::getAction(float fDuration)
|
||||
{
|
||||
return ScaleTo::create(fDuration,_scaleX,_scaleY);
|
||||
return this->getEasingAction(CCScaleTo::create(fDuration,_scaleX,_scaleY));
|
||||
}
|
||||
|
||||
ActionRotationFrame::ActionRotationFrame()
|
||||
|
@ -165,9 +307,22 @@ float ActionRotationFrame::getRotation()
|
|||
return _rotation;
|
||||
}
|
||||
|
||||
Action* ActionRotationFrame::getAction(float fDuration)
|
||||
ActionInterval* ActionRotationFrame::getAction(float fDuration)
|
||||
{
|
||||
return RotateTo::create(fDuration,_rotation);
|
||||
return this->getEasingAction(CCRotateTo::create(fDuration,_rotation));
|
||||
}
|
||||
ActionInterval* ActionRotationFrame::getAction(float fDuration,ActionFrame* srcFrame)
|
||||
{
|
||||
ActionRotationFrame* srcRotationFrame = static_cast<ActionRotationFrame*>(srcFrame);
|
||||
if (srcRotationFrame == nullptr)
|
||||
{
|
||||
return this->getAction(fDuration);
|
||||
}
|
||||
else
|
||||
{
|
||||
float diffRotation = _rotation - srcRotationFrame->_rotation;
|
||||
return this->getEasingAction(CCRotateBy::create(fDuration,diffRotation));
|
||||
}
|
||||
}
|
||||
|
||||
ActionFadeFrame::ActionFadeFrame()
|
||||
|
@ -191,9 +346,9 @@ int ActionFadeFrame::getOpacity()
|
|||
return _opacity;
|
||||
}
|
||||
|
||||
Action* ActionFadeFrame::getAction(float fDuration)
|
||||
ActionInterval* ActionFadeFrame::getAction(float fDuration)
|
||||
{
|
||||
return FadeTo::create(fDuration,_opacity);
|
||||
return this->getEasingAction(CCFadeTo::create(fDuration,_opacity));
|
||||
}
|
||||
|
||||
|
||||
|
@ -218,9 +373,9 @@ Color3B ActionTintFrame::getColor()
|
|||
return _color;
|
||||
}
|
||||
|
||||
Action* ActionTintFrame::getAction(float fDuration)
|
||||
ActionInterval* ActionTintFrame::getAction(float fDuration)
|
||||
{
|
||||
return TintTo::create(fDuration,_color.r,_color.g,_color.b);
|
||||
return this->getEasingAction(CCTintTo::create(fDuration,_color.r,_color.g,_color.b));
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -39,6 +39,54 @@ enum FrameType
|
|||
kKeyframeMax
|
||||
};
|
||||
|
||||
enum class FrameEaseType
|
||||
{
|
||||
Custom = -1,
|
||||
|
||||
LINERAR = 0,
|
||||
|
||||
SINE_EASEIN,
|
||||
SINE_EASEOUT,
|
||||
SINE_EASEINOUT,
|
||||
|
||||
QUAD_EASEIN,
|
||||
QUAD_EASEOUT,
|
||||
QUAD_EASEINOUT,
|
||||
|
||||
CUBIC_EASEIN,
|
||||
CUBIC_EASEOUT,
|
||||
CUBIC_EASEINOUT,
|
||||
|
||||
QUART_EASEIN,
|
||||
QUART_EASEOUT,
|
||||
QUART_EASEINOUT,
|
||||
|
||||
QUINT_EASEIN,
|
||||
QUINT_EASEOUT,
|
||||
QUINT_EASEINOUT,
|
||||
|
||||
EXPO_EASEIN,
|
||||
EXPO_EASEOUT,
|
||||
EXPO_EASEINOUT,
|
||||
|
||||
CIRC_EASEIN,
|
||||
CIRC_EASEOUT,
|
||||
CIRC_EASEINOUT,
|
||||
|
||||
ELASTIC_EASEIN,
|
||||
ELASTIC_EASEOUT,
|
||||
ELASTIC_EASEINOUT,
|
||||
|
||||
BACK_EASEIN,
|
||||
BACK_EASEOUT,
|
||||
BACK_EASEINOUT,
|
||||
|
||||
BOUNCE_EASEIN,
|
||||
BOUNCE_EASEOUT,
|
||||
BOUNCE_EASEINOUT,
|
||||
|
||||
TWEEN_EASING_MAX = 10000
|
||||
};
|
||||
/**
|
||||
* @js NA
|
||||
* @lua NA
|
||||
|
@ -115,18 +163,46 @@ public:
|
|||
int getEasingType();
|
||||
|
||||
/**
|
||||
* Gets the CCAction of ActionFrame.
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame fDuration the duration time of ActionFrame
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @return CCAction
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::Action* getAction(float fDuration);
|
||||
virtual cocos2d::ActionInterval* getAction(float duration);
|
||||
/**
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @parame duration the source ActionFrame
|
||||
*
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::ActionInterval* getAction(float duration,ActionFrame* srcFrame);
|
||||
|
||||
/**
|
||||
*Set the ActionInterval easing parameter.
|
||||
*
|
||||
*@parame parameter the parameter for frame ease
|
||||
*
|
||||
*/
|
||||
virtual void setEasingParameter(std::vector<float>& parameter);
|
||||
protected:
|
||||
/**
|
||||
* Gets the Easing Action of ActionFrame.
|
||||
*
|
||||
* @parame action the duration time of ActionFrame
|
||||
*
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::ActionInterval* getEasingAction(cocos2d::ActionInterval* action);
|
||||
protected:
|
||||
int _frameType;
|
||||
int _easingType;
|
||||
int _frameIndex;
|
||||
float _fTime;
|
||||
FrameEaseType _easingType;
|
||||
std::vector<float> _Parameter;
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -162,13 +238,13 @@ public:
|
|||
cocos2d::Point getPosition();
|
||||
|
||||
/**
|
||||
* Gets the CCAction of ActionFrame.
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame fDuration the duration time of ActionFrame
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @return CCAction
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::Action* getAction(float fDuration);
|
||||
virtual cocos2d::ActionInterval* getAction(float duration);
|
||||
protected:
|
||||
cocos2d::Point _position;
|
||||
};
|
||||
|
@ -220,13 +296,13 @@ public:
|
|||
float getScaleY();
|
||||
|
||||
/**
|
||||
* Gets the CCAction of ActionFrame.
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame fDuration the duration time of ActionFrame
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @return CCAction
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::Action* getAction(float fDuration);
|
||||
virtual cocos2d::ActionInterval* getAction(float duration);
|
||||
protected:
|
||||
float _scaleX;
|
||||
float _scaleY;
|
||||
|
@ -264,14 +340,24 @@ public:
|
|||
float getRotation();
|
||||
|
||||
/**
|
||||
* Gets the CCAction of ActionFrame.
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame fDuration the duration time of ActionFrame
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @return CCAction
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::Action* getAction(float fDuration);
|
||||
protected:
|
||||
virtual cocos2d::ActionInterval* getAction(float duration);
|
||||
/**
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @parame duration the source ActionFrame
|
||||
*
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::ActionInterval* getAction(float duration,ActionFrame* srcFrame);
|
||||
public:
|
||||
float _rotation;
|
||||
};
|
||||
/**
|
||||
|
@ -307,13 +393,13 @@ public:
|
|||
int getOpacity();
|
||||
|
||||
/**
|
||||
* Gets the CCAction of ActionFrame.
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame fDuration the duration time of ActionFrame
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @return CCAction
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::Action* getAction(float fDuration);
|
||||
virtual cocos2d::ActionInterval* getAction(float duration);
|
||||
protected:
|
||||
float _opacity;
|
||||
};
|
||||
|
@ -351,13 +437,13 @@ public:
|
|||
cocos2d::Color3B getColor();
|
||||
|
||||
/**
|
||||
* Gets the CCAction of ActionFrame.
|
||||
* Gets the ActionInterval of ActionFrame.
|
||||
*
|
||||
* @parame fDuration the duration time of ActionFrame
|
||||
* @parame duration the duration time of ActionFrame
|
||||
*
|
||||
* @return CCAction
|
||||
* @return ActionInterval
|
||||
*/
|
||||
virtual cocos2d::Action* getAction(float fDuration);
|
||||
virtual cocos2d::ActionInterval* getAction(float duration);
|
||||
protected:
|
||||
cocos2d::Color3B _color;
|
||||
};
|
||||
|
|
|
@ -26,7 +26,6 @@
|
|||
#define __ActionFrameEasing_H__
|
||||
|
||||
#include "cocos2d.h"
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
|
|
|
@ -29,9 +29,9 @@
|
|||
|
||||
namespace cocostudio {
|
||||
|
||||
static ActionManagerEx* sharedActionManager = NULL;
|
||||
static ActionManagerEx* sharedActionManager = nullptr;
|
||||
|
||||
ActionManagerEx* ActionManagerEx::shareManager()
|
||||
ActionManagerEx* ActionManagerEx::getInstance()
|
||||
{
|
||||
if (!sharedActionManager) {
|
||||
sharedActionManager = new ActionManagerEx();
|
||||
|
@ -39,60 +39,56 @@ ActionManagerEx* ActionManagerEx::shareManager()
|
|||
return sharedActionManager;
|
||||
}
|
||||
|
||||
void ActionManagerEx::purgeActionManager()
|
||||
void ActionManagerEx::destroyInstance()
|
||||
{
|
||||
CC_SAFE_DELETE(sharedActionManager);
|
||||
}
|
||||
|
||||
ActionManagerEx::ActionManagerEx()
|
||||
: _pActionDic(NULL)
|
||||
{
|
||||
_pActionDic = Dictionary::create();
|
||||
_pActionDic->retain();
|
||||
}
|
||||
|
||||
ActionManagerEx::~ActionManagerEx()
|
||||
{
|
||||
_pActionDic->removeAllObjects();
|
||||
_pActionDic->release();
|
||||
_actionDic.clear();
|
||||
}
|
||||
|
||||
void ActionManagerEx::initWithDictionary(const char* jsonName,JsonDictionary *dic,Object* root)
|
||||
void ActionManagerEx::initWithDictionary(const char* jsonName,const rapidjson::Value &dic,Object* root)
|
||||
{
|
||||
std::string path = jsonName;
|
||||
int pos = path.find_last_of("/");
|
||||
ssize_t pos = path.find_last_of("/");
|
||||
std::string fileName = path.substr(pos+1,path.length());
|
||||
CCLOG("filename == %s",fileName.c_str());
|
||||
Array* actionList = Array::create();
|
||||
cocos2d::Vector<ActionObject*> actionList;
|
||||
int actionCount = DICTOOL->getArrayCount_json(dic, "actionlist");
|
||||
for (int i=0; i<actionCount; i++) {
|
||||
ActionObject* action = new ActionObject();
|
||||
action->autorelease();
|
||||
JsonDictionary* actionDic = DICTOOL->getDictionaryFromArray_json(dic, "actionlist", i);
|
||||
const rapidjson::Value &actionDic = DICTOOL->getDictionaryFromArray_json(dic, "actionlist", i);
|
||||
action->initWithDictionary(actionDic,root);
|
||||
actionList->addObject(action);
|
||||
CC_SAFE_DELETE(actionDic);
|
||||
actionList.pushBack(action);
|
||||
}
|
||||
_pActionDic->setObject(actionList, fileName);
|
||||
_actionDic.insert(std::pair<std::string, cocos2d::Vector<ActionObject*>>(fileName, actionList));
|
||||
}
|
||||
|
||||
|
||||
ActionObject* ActionManagerEx::getActionByName(const char* jsonName,const char* actionName)
|
||||
{
|
||||
Array* actionList = (Array*)(_pActionDic->objectForKey(jsonName));
|
||||
if (!actionList)
|
||||
auto iterator = _actionDic.find(jsonName);
|
||||
if (iterator == _actionDic.end())
|
||||
{
|
||||
return NULL;
|
||||
return nullptr;
|
||||
}
|
||||
for (int i = 0; i < actionList->count(); i++)
|
||||
auto actionList = iterator->second;
|
||||
for (int i = 0; i < actionList.size(); i++)
|
||||
{
|
||||
ActionObject* action = dynamic_cast<ActionObject*>(actionList->getObjectAtIndex(i));
|
||||
ActionObject* action = actionList.at(i);
|
||||
if (strcmp(actionName, action->getName()) == 0)
|
||||
{
|
||||
return action;
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
ActionObject* ActionManagerEx::playActionByName(const char* jsonName,const char* actionName)
|
||||
|
@ -105,10 +101,19 @@ ActionObject* ActionManagerEx::playActionByName(const char* jsonName,const char*
|
|||
return action;
|
||||
}
|
||||
|
||||
ActionObject* ActionManagerEx::playActionByName(const char* jsonName,const char* actionName, CallFunc* func)
|
||||
{
|
||||
ActionObject* action = getActionByName(jsonName,actionName);
|
||||
if (action)
|
||||
{
|
||||
action->play(func);
|
||||
}
|
||||
return action;
|
||||
}
|
||||
|
||||
void ActionManagerEx::releaseActions()
|
||||
{
|
||||
_pActionDic->removeAllObjects();
|
||||
|
||||
_actionDic.clear();
|
||||
}
|
||||
|
||||
}
|
|
@ -27,7 +27,7 @@
|
|||
|
||||
#include "cocos2d.h"
|
||||
#include "cocostudio/CCActionObject.h"
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
#include "cocostudio/DictionaryHelper.h"
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
|
@ -53,14 +53,14 @@ public:
|
|||
* @js getInstance
|
||||
* @lua getInstance
|
||||
*/
|
||||
static ActionManagerEx* shareManager();
|
||||
static ActionManagerEx* getInstance();
|
||||
|
||||
/**
|
||||
* Purges ActionManager point.
|
||||
* @js purge
|
||||
* @lua destroyActionManager
|
||||
*/
|
||||
static void purgeActionManager();
|
||||
static void destroyInstance();
|
||||
|
||||
/**
|
||||
* Gets an ActionObject with a name.
|
||||
|
@ -84,9 +84,19 @@ public:
|
|||
*/
|
||||
ActionObject* playActionByName(const char* jsonName,const char* actionName);
|
||||
|
||||
/*init properties with json dictionay*/
|
||||
void initWithDictionary(const char* jsonName,JsonDictionary* dic,cocos2d::Object* root);
|
||||
/**
|
||||
* Play an Action with a name.
|
||||
*
|
||||
* @param jsonName UI file name
|
||||
*
|
||||
* @param actionName action name in teh UIfile.
|
||||
*
|
||||
* @param func ui action call back
|
||||
*/
|
||||
ActionObject* playActionByName(const char* jsonName,const char* actionName, cocos2d::CallFunc* func);
|
||||
|
||||
/*init properties with json dictionay*/
|
||||
void initWithDictionary(const char* jsonName,const rapidjson::Value &dic, Object* root);
|
||||
/**
|
||||
* Release all actions.
|
||||
*
|
||||
|
@ -94,7 +104,7 @@ public:
|
|||
void releaseActions();
|
||||
|
||||
protected:
|
||||
cocos2d::Dictionary* _pActionDic;
|
||||
std::unordered_map<std::string, cocos2d::Vector<ActionObject*>> _actionDic;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -38,26 +38,21 @@ ActionNode::ActionNode()
|
|||
, _destFrameIndex(0)
|
||||
, _fUnitTime(0.1f)
|
||||
, _actionTag(0)
|
||||
, _actionSpawn(NULL)
|
||||
, _action(NULL)
|
||||
, _object(NULL)
|
||||
, _frameArray(NULL)
|
||||
, _actionSpawn(nullptr)
|
||||
, _action(nullptr)
|
||||
, _object(nullptr)
|
||||
, _frameArrayNum(0)
|
||||
{
|
||||
_frameArray = Array::create();
|
||||
_frameArray->retain();
|
||||
|
||||
_frameArrayNum = (int)kKeyframeMax;
|
||||
for(int i = 0; i < _frameArrayNum; i++)
|
||||
{
|
||||
Array* cArray = Array::create();
|
||||
_frameArray->addObject(cArray);
|
||||
_frameArray.push_back( new cocos2d::Vector<ActionFrame*>());
|
||||
}
|
||||
}
|
||||
|
||||
ActionNode::~ActionNode()
|
||||
{
|
||||
if (_action == NULL)
|
||||
if (_action == nullptr)
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(_actionSpawn);
|
||||
}
|
||||
|
@ -66,20 +61,20 @@ ActionNode::~ActionNode()
|
|||
CC_SAFE_RELEASE_NULL(_action);
|
||||
}
|
||||
|
||||
if (_frameArray != NULL)
|
||||
for (auto object : _frameArray)
|
||||
{
|
||||
_frameArray->removeAllObjects();
|
||||
CC_SAFE_RELEASE_NULL(_frameArray);
|
||||
object->clear();
|
||||
}
|
||||
_frameArray.clear();
|
||||
}
|
||||
|
||||
void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
||||
void ActionNode::initWithDictionary(const rapidjson::Value& dic,Object* root)
|
||||
{
|
||||
setActionTag(DICTOOL->getIntValue_json(dic, "ActionTag"));
|
||||
int actionFrameCount = DICTOOL->getArrayCount_json(dic, "actionframelist");
|
||||
for (int i=0; i<actionFrameCount; i++) {
|
||||
|
||||
JsonDictionary* actionFrameDic = DICTOOL->getDictionaryFromArray_json(dic, "actionframelist", i);
|
||||
const rapidjson::Value& actionFrameDic = DICTOOL->getDictionaryFromArray_json(dic, "actionframelist", i);
|
||||
int frameInex = DICTOOL->getIntValue_json(actionFrameDic,"frameid");
|
||||
|
||||
bool existPosition = DICTOOL->checkObjectExist_json(actionFrameDic,"positionx");
|
||||
|
@ -88,10 +83,11 @@ void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
|||
float positionX = DICTOOL->getFloatValue_json(actionFrameDic, "positionx");
|
||||
float positionY = DICTOOL->getFloatValue_json(actionFrameDic, "positiony");
|
||||
ActionMoveFrame* actionFrame = new ActionMoveFrame();
|
||||
actionFrame->autorelease();
|
||||
actionFrame->setFrameIndex(frameInex);
|
||||
actionFrame->setPosition(Point(positionX, positionY));
|
||||
Array* cActionArray = (Array*)_frameArray->getObjectAtIndex((int)kKeyframeMove);
|
||||
cActionArray->addObject(actionFrame);
|
||||
auto cActionArray = _frameArray.at((int)kKeyframeMove);
|
||||
cActionArray->pushBack(actionFrame);
|
||||
}
|
||||
|
||||
bool existScale = DICTOOL->checkObjectExist_json(actionFrameDic,"scalex");
|
||||
|
@ -100,11 +96,12 @@ void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
|||
float scaleX = DICTOOL->getFloatValue_json(actionFrameDic, "scalex");
|
||||
float scaleY = DICTOOL->getFloatValue_json(actionFrameDic, "scaley");
|
||||
ActionScaleFrame* actionFrame = new ActionScaleFrame();
|
||||
actionFrame->autorelease();
|
||||
actionFrame->setFrameIndex(frameInex);
|
||||
actionFrame->setScaleX(scaleX);
|
||||
actionFrame->setScaleY(scaleY);
|
||||
Array* cActionArray = (Array*)_frameArray->getObjectAtIndex((int)kKeyframeScale);
|
||||
cActionArray->addObject(actionFrame);
|
||||
auto cActionArray = _frameArray.at((int)kKeyframeMove);
|
||||
cActionArray->pushBack(actionFrame);
|
||||
}
|
||||
|
||||
bool existRotation = DICTOOL->checkObjectExist_json(actionFrameDic,"rotation");
|
||||
|
@ -112,10 +109,11 @@ void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
|||
{
|
||||
float rotation = DICTOOL->getFloatValue_json(actionFrameDic, "rotation");
|
||||
ActionRotationFrame* actionFrame = new ActionRotationFrame();
|
||||
actionFrame->autorelease();
|
||||
actionFrame->setFrameIndex(frameInex);
|
||||
actionFrame->setRotation(rotation);
|
||||
Array* cActionArray = (Array*)_frameArray->getObjectAtIndex((int)kKeyframeRotate);
|
||||
cActionArray->addObject(actionFrame);
|
||||
auto cActionArray = _frameArray.at((int)kKeyframeMove);
|
||||
cActionArray->pushBack(actionFrame);
|
||||
}
|
||||
|
||||
bool existOpacity = DICTOOL->checkObjectExist_json(actionFrameDic,"opacity");
|
||||
|
@ -123,10 +121,11 @@ void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
|||
{
|
||||
int opacity = DICTOOL->getIntValue_json(actionFrameDic, "opacity");
|
||||
ActionFadeFrame* actionFrame = new ActionFadeFrame();
|
||||
actionFrame->autorelease();
|
||||
actionFrame->setFrameIndex(frameInex);
|
||||
actionFrame->setOpacity(opacity);
|
||||
Array* cActionArray = (Array*)_frameArray->getObjectAtIndex((int)kKeyframeFade);
|
||||
cActionArray->addObject(actionFrame);
|
||||
auto cActionArray = _frameArray.at((int)kKeyframeMove);
|
||||
cActionArray->pushBack(actionFrame);
|
||||
}
|
||||
|
||||
bool existColor = DICTOOL->checkObjectExist_json(actionFrameDic,"colorr");
|
||||
|
@ -136,13 +135,12 @@ void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
|||
int colorG = DICTOOL->getIntValue_json(actionFrameDic, "colorg");
|
||||
int colorB = DICTOOL->getIntValue_json(actionFrameDic, "colorb");
|
||||
ActionTintFrame* actionFrame = new ActionTintFrame();
|
||||
actionFrame->autorelease();
|
||||
actionFrame->setFrameIndex(frameInex);
|
||||
actionFrame->setColor(Color3B(colorR,colorG,colorB));
|
||||
Array* cActionArray = (Array*)_frameArray->getObjectAtIndex((int)kKeyframeTint);
|
||||
cActionArray->addObject(actionFrame);
|
||||
auto cActionArray = _frameArray.at((int)kKeyframeMove);
|
||||
cActionArray->pushBack(actionFrame);
|
||||
}
|
||||
|
||||
CC_SAFE_DELETE(actionFrameDic);
|
||||
}
|
||||
initActionNodeFromRoot(root);
|
||||
}
|
||||
|
@ -150,13 +148,13 @@ void ActionNode::initWithDictionary(JsonDictionary *dic,Object* root)
|
|||
void ActionNode::initActionNodeFromRoot(Object* root)
|
||||
{
|
||||
Node* rootNode = dynamic_cast<Node*>(root);
|
||||
if (rootNode != NULL)
|
||||
if (rootNode != nullptr)
|
||||
{
|
||||
Widget* rootWidget = dynamic_cast<Widget*>(root);
|
||||
if (rootWidget != NULL)
|
||||
if (rootWidget != nullptr)
|
||||
{
|
||||
Widget* widget = UIHelper::seekActionWidgetByActionTag(rootWidget, getActionTag());
|
||||
if (widget != NULL)
|
||||
if (widget != nullptr)
|
||||
{
|
||||
setObject(widget);
|
||||
}
|
||||
|
@ -198,114 +196,113 @@ Object* ActionNode::getObject()
|
|||
Node* ActionNode::getActionNode()
|
||||
{
|
||||
Node* cNode = dynamic_cast<Node*>(_object);
|
||||
if (cNode != NULL)
|
||||
if (cNode != nullptr)
|
||||
{
|
||||
return cNode;
|
||||
}
|
||||
else
|
||||
{
|
||||
Widget* rootWidget = dynamic_cast<Widget*>(_object);
|
||||
if (rootWidget != NULL)
|
||||
if (rootWidget != nullptr)
|
||||
{
|
||||
return rootWidget;
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
void ActionNode::insertFrame(int index, ActionFrame* frame)
|
||||
{
|
||||
if (frame == NULL)
|
||||
if (frame == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
int frameType = frame->getFrameType();
|
||||
Array* cArray = (Array*)_frameArray->getObjectAtIndex(frameType);
|
||||
if (cArray == NULL)
|
||||
if(frameType < _frameArray.size())
|
||||
{
|
||||
return;
|
||||
auto cArray = _frameArray.at(frameType);
|
||||
cArray->insert(index, frame);
|
||||
}
|
||||
cArray->insertObject(frame,index);
|
||||
}
|
||||
|
||||
void ActionNode::addFrame(ActionFrame* frame)
|
||||
{
|
||||
if (frame == NULL)
|
||||
if (frame == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
int frameType = frame->getFrameType();
|
||||
Array* cArray = (Array*)_frameArray->getObjectAtIndex(frameType);
|
||||
if (cArray == NULL)
|
||||
|
||||
if(frameType < _frameArray.size())
|
||||
{
|
||||
return;
|
||||
auto cArray = _frameArray.at(frameType);
|
||||
cArray->pushBack(frame);
|
||||
}
|
||||
cArray->addObject(frame);
|
||||
}
|
||||
|
||||
void ActionNode::deleteFrame(ActionFrame* frame)
|
||||
{
|
||||
if (frame == NULL)
|
||||
if (frame == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
int frameType = frame->getFrameType();
|
||||
Array* cArray = (Array*)_frameArray->getObjectAtIndex(frameType);
|
||||
if (cArray == NULL)
|
||||
if(frameType < _frameArray.size())
|
||||
{
|
||||
return;
|
||||
auto cArray = _frameArray.at(frameType);
|
||||
cArray->eraseObject(frame);
|
||||
}
|
||||
cArray->removeObject(frame);
|
||||
}
|
||||
|
||||
void ActionNode::clearAllFrame()
|
||||
{
|
||||
for (int i = 0; i < _frameArrayNum; i++)
|
||||
for(auto array : _frameArray)
|
||||
{
|
||||
_frameArray[i].removeAllObjects();
|
||||
array->clear();
|
||||
}
|
||||
}
|
||||
|
||||
Spawn * ActionNode::refreshActionProperty()
|
||||
{
|
||||
if ( _object == NULL )
|
||||
if ( _object == nullptr )
|
||||
{
|
||||
return NULL;
|
||||
return nullptr;
|
||||
}
|
||||
Vector<FiniteTimeAction*> cSpawnArray;
|
||||
|
||||
for (int n = 0; n < _frameArrayNum; n++)
|
||||
{
|
||||
Array* cArray = (Array*)(_frameArray->getObjectAtIndex(n));
|
||||
if (cArray == NULL || cArray->count() <= 0)
|
||||
auto cArray = _frameArray.at(n);
|
||||
if (cArray->size() <= 0)
|
||||
{
|
||||
continue;
|
||||
}
|
||||
|
||||
Vector<FiniteTimeAction*> cSequenceArray;
|
||||
auto frameCount = cArray->count();
|
||||
auto frameCount = cArray->size();
|
||||
for (int i = 0; i < frameCount; i++)
|
||||
{
|
||||
ActionFrame* frame = (ActionFrame*)(cArray->getObjectAtIndex(i));
|
||||
auto frame = cArray->at(i);
|
||||
if (i == 0)
|
||||
{
|
||||
}
|
||||
else
|
||||
{
|
||||
ActionFrame* srcFrame = (ActionFrame*)(cArray->getObjectAtIndex(i-1));
|
||||
auto srcFrame = cArray->at(i-1);
|
||||
float duration = (frame->getFrameIndex() - srcFrame->getFrameIndex()) * getUnitTime();
|
||||
Action* cAction = frame->getAction(duration);
|
||||
if(cAction != nullptr)
|
||||
cSequenceArray.pushBack(static_cast<FiniteTimeAction*>(cAction));
|
||||
}
|
||||
}
|
||||
Sequence* cSequence = Sequence::create(cSequenceArray);
|
||||
if (cSequence != NULL)
|
||||
if (cSequence != nullptr)
|
||||
{
|
||||
cSpawnArray.pushBack(cSequence);
|
||||
}
|
||||
}
|
||||
|
||||
if (_action == NULL)
|
||||
if (_action == nullptr)
|
||||
{
|
||||
CC_SAFE_RELEASE_NULL(_actionSpawn);
|
||||
}
|
||||
|
@ -321,17 +318,17 @@ Spawn * ActionNode::refreshActionProperty()
|
|||
|
||||
void ActionNode::playAction()
|
||||
{
|
||||
if ( _object == NULL || _actionSpawn == NULL)
|
||||
if ( _object == nullptr || _actionSpawn == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if (_action!=NULL)
|
||||
if (_action!=nullptr)
|
||||
{
|
||||
_action->release();
|
||||
}
|
||||
|
||||
_action = Sequence::create(_actionSpawn, NULL);
|
||||
_action = Sequence::create(_actionSpawn, nullptr);
|
||||
_action->retain();
|
||||
|
||||
this->runAction();
|
||||
|
@ -341,7 +338,7 @@ void ActionNode::playAction()
|
|||
void ActionNode::runAction()
|
||||
{
|
||||
Node* cNode = this->getActionNode();
|
||||
if (cNode != NULL && _action != NULL)
|
||||
if (cNode != nullptr && _action != nullptr)
|
||||
{
|
||||
cNode->runAction(_action);
|
||||
}
|
||||
|
@ -350,7 +347,7 @@ void ActionNode::runAction()
|
|||
void ActionNode::stopAction()
|
||||
{
|
||||
Node* cNode = this->getActionNode();
|
||||
if (cNode != NULL && _action != NULL)
|
||||
if (cNode != nullptr && _action != nullptr)
|
||||
{
|
||||
cNode->stopAction(_action);
|
||||
}
|
||||
|
@ -362,13 +359,13 @@ int ActionNode::getFirstFrameIndex()
|
|||
bool bFindFrame = false;
|
||||
for (int n = 0; n < _frameArrayNum; n++)
|
||||
{
|
||||
Array* cArray = (Array*)(_frameArray->getObjectAtIndex(n));
|
||||
if (cArray == NULL || cArray->count() <= 0)
|
||||
auto cArray = _frameArray.at(n);
|
||||
if (cArray->empty())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
bFindFrame = true;
|
||||
ActionFrame* frame = (ActionFrame*)(cArray->getObjectAtIndex(0));
|
||||
auto frame = cArray->at(0);
|
||||
int iFrameIndex = frame->getFrameIndex();
|
||||
|
||||
if (frameindex > iFrameIndex)
|
||||
|
@ -389,14 +386,14 @@ int ActionNode::getLastFrameIndex()
|
|||
bool bFindFrame = false;
|
||||
for (int n = 0; n < _frameArrayNum; n++)
|
||||
{
|
||||
Array* cArray = (Array*)(_frameArray->getObjectAtIndex(n));
|
||||
if (cArray == NULL || cArray->count() <= 0)
|
||||
auto cArray = _frameArray.at(n);
|
||||
if (cArray->empty())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
bFindFrame = true;
|
||||
ssize_t lastInex = cArray->count() - 1;
|
||||
ActionFrame* frame = (ActionFrame*)(cArray->getObjectAtIndex(lastInex));
|
||||
ssize_t lastInex = cArray->size() - 1;
|
||||
auto frame = cArray->at(lastInex);
|
||||
int iFrameIndex = frame->getFrameIndex();
|
||||
|
||||
if (frameindex < iFrameIndex)
|
||||
|
@ -414,24 +411,24 @@ bool ActionNode::updateActionToTimeLine(float fTime)
|
|||
{
|
||||
bool bFindFrame = false;
|
||||
|
||||
ActionFrame* srcFrame = NULL;
|
||||
// ActionFrame* destFrame = NULL;
|
||||
ActionFrame* srcFrame = nullptr;
|
||||
// ActionFrame* destFrame = nullptr;
|
||||
|
||||
for (int n = 0; n < _frameArrayNum; n++)
|
||||
{
|
||||
Array* cArray = (Array*)(_frameArray->getObjectAtIndex(n));
|
||||
if (cArray == NULL)
|
||||
auto cArray = _frameArray.at(n);
|
||||
if (cArray->empty())
|
||||
{
|
||||
continue;
|
||||
}
|
||||
ssize_t frameCount = cArray->count();
|
||||
ssize_t frameCount = cArray->size();
|
||||
for (int i = 0; i < frameCount; i++)
|
||||
{
|
||||
ActionFrame* frame = (ActionFrame*)(cArray->getObjectAtIndex(i));
|
||||
auto frame = cArray->at(i);
|
||||
|
||||
if (frame->getFrameIndex()*getUnitTime() == fTime)
|
||||
{
|
||||
this->easingToFrame(1.0f,1.0f,frame);
|
||||
this->easingToFrame(1.0f,1.0f,nullptr,frame);
|
||||
bFindFrame = true;
|
||||
break;
|
||||
}
|
||||
|
@ -439,17 +436,17 @@ bool ActionNode::updateActionToTimeLine(float fTime)
|
|||
{
|
||||
if (i == 0)
|
||||
{
|
||||
this->easingToFrame(1.0f,1.0f,frame);
|
||||
this->easingToFrame(1.0f,1.0f,nullptr,frame);
|
||||
bFindFrame = false;
|
||||
}
|
||||
else
|
||||
{
|
||||
srcFrame = (ActionFrame*)(cArray->getObjectAtIndex(i-1));
|
||||
srcFrame = cArray->at(i-1);
|
||||
float duration = (frame->getFrameIndex() - srcFrame->getFrameIndex())*getUnitTime();
|
||||
float delaytime = fTime - srcFrame->getFrameIndex()*getUnitTime();
|
||||
this->easingToFrame(duration,1.0f,srcFrame);
|
||||
this->easingToFrame(duration,1.0f,nullptr,srcFrame);
|
||||
//float easingTime = ActionFrameEasing::bounceTime(delaytime);
|
||||
this->easingToFrame(duration,delaytime/duration,frame);
|
||||
this->easingToFrame(duration,delaytime/duration,srcFrame,frame);
|
||||
bFindFrame = true;
|
||||
}
|
||||
break;
|
||||
|
@ -459,11 +456,11 @@ bool ActionNode::updateActionToTimeLine(float fTime)
|
|||
return bFindFrame;
|
||||
}
|
||||
|
||||
void ActionNode::easingToFrame(float duration,float delayTime,ActionFrame* destFrame)
|
||||
void ActionNode::easingToFrame(float duration,float delayTime,ActionFrame* srcFrame,ActionFrame* destFrame)
|
||||
{
|
||||
Action* cAction = destFrame->getAction(duration);
|
||||
Action* cAction = destFrame->getAction(duration,srcFrame);
|
||||
Node* cNode = this->getActionNode();
|
||||
if (cAction == NULL || cNode == NULL)
|
||||
if (cAction == nullptr || cNode == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
|
|
@ -27,7 +27,7 @@
|
|||
|
||||
#include "cocos2d.h"
|
||||
#include "cocostudio/CCActionFrame.h"
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
#include "cocostudio/DictionaryHelper.h"
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
|
@ -149,7 +149,7 @@ public:
|
|||
virtual void stopAction();
|
||||
|
||||
/*init properties with a json dictionary*/
|
||||
virtual void initWithDictionary(JsonDictionary* dic,cocos2d::Object* root);
|
||||
virtual void initWithDictionary(const rapidjson::Value& dic,Object* root);
|
||||
|
||||
/**
|
||||
* Gets if the action is done once time.
|
||||
|
@ -168,7 +168,7 @@ protected:
|
|||
cocos2d::Action* _action;
|
||||
cocos2d::Object* _object;
|
||||
|
||||
cocos2d::Array* _frameArray;
|
||||
std::vector<cocos2d::Vector<ActionFrame*>*> _frameArray;
|
||||
int _frameArrayNum;
|
||||
|
||||
protected:
|
||||
|
@ -176,7 +176,7 @@ protected:
|
|||
virtual cocos2d::Spawn * refreshActionProperty();
|
||||
virtual void runAction();
|
||||
virtual void initActionNodeFromRoot(cocos2d::Object* root);
|
||||
virtual void easingToFrame(float duration,float delayTime,ActionFrame* destFrame);
|
||||
virtual void easingToFrame(float duration,float delayTime,ActionFrame* srcFrame,ActionFrame* destFrame);
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -30,25 +30,23 @@ using namespace cocos2d;
|
|||
namespace cocostudio {
|
||||
|
||||
ActionObject::ActionObject()
|
||||
: _actionNodeList(NULL)
|
||||
, _name("")
|
||||
: _name("")
|
||||
, _loop(false)
|
||||
, _bPause(false)
|
||||
, _bPlaying(false)
|
||||
, _fUnitTime(0.1f)
|
||||
, _currentTime(0.0f)
|
||||
, _pScheduler(NULL)
|
||||
, _pScheduler(nullptr)
|
||||
, _CallBack(nullptr)
|
||||
, _fTotalTime(0.0f)
|
||||
{
|
||||
_actionNodeList = Array::create();
|
||||
_actionNodeList->retain();
|
||||
_pScheduler = Director::getInstance()->getScheduler();
|
||||
CC_SAFE_RETAIN(_pScheduler);
|
||||
}
|
||||
|
||||
ActionObject::~ActionObject()
|
||||
{
|
||||
_actionNodeList->removeAllObjects();
|
||||
_actionNodeList->release();
|
||||
_actionNodeList.clear();
|
||||
CC_SAFE_RELEASE(_pScheduler);
|
||||
}
|
||||
|
||||
|
@ -73,11 +71,9 @@ bool ActionObject::getLoop()
|
|||
void ActionObject::setUnitTime(float fTime)
|
||||
{
|
||||
_fUnitTime = fTime;
|
||||
auto nodeNum = _actionNodeList->count();
|
||||
for ( int i = 0; i < nodeNum; i++ )
|
||||
for(const auto &e : _actionNodeList)
|
||||
{
|
||||
ActionNode* actionNode = (ActionNode*)_actionNodeList->getObjectAtIndex(i);
|
||||
actionNode->setUnitTime(_fUnitTime);
|
||||
e->setUnitTime(_fUnitTime);
|
||||
}
|
||||
}
|
||||
float ActionObject::getUnitTime()
|
||||
|
@ -95,62 +91,78 @@ void ActionObject::setCurrentTime(float fTime)
|
|||
_currentTime = fTime;
|
||||
}
|
||||
|
||||
float ActionObject::getTotalTime()
|
||||
{
|
||||
return _fTotalTime;
|
||||
}
|
||||
bool ActionObject::isPlaying()
|
||||
{
|
||||
return _bPlaying;
|
||||
}
|
||||
|
||||
void ActionObject::initWithDictionary(JsonDictionary *dic,Object* root)
|
||||
void ActionObject::initWithDictionary(const rapidjson::Value& dic, Object* root)
|
||||
{
|
||||
setName(DICTOOL->getStringValue_json(dic, "name"));
|
||||
setLoop(DICTOOL->getBooleanValue_json(dic, "loop"));
|
||||
setUnitTime(DICTOOL->getFloatValue_json(dic, "unittime"));
|
||||
int actionNodeCount = DICTOOL->getArrayCount_json(dic, "actionnodelist");
|
||||
int maxLength = 0;
|
||||
for (int i=0; i<actionNodeCount; i++) {
|
||||
ActionNode* actionNode = new ActionNode();
|
||||
actionNode->autorelease();
|
||||
JsonDictionary* actionNodeDic = DICTOOL->getDictionaryFromArray_json(dic, "actionnodelist", i);
|
||||
const rapidjson::Value& actionNodeDic = DICTOOL->getDictionaryFromArray_json(dic, "actionnodelist", i);
|
||||
actionNode->initWithDictionary(actionNodeDic,root);
|
||||
actionNode->setUnitTime(getUnitTime());
|
||||
_actionNodeList->addObject(actionNode);
|
||||
CC_SAFE_DELETE(actionNodeDic);
|
||||
_actionNodeList.pushBack(actionNode);
|
||||
|
||||
int length = actionNode->getLastFrameIndex() - actionNode->getFirstFrameIndex();
|
||||
if(length > maxLength)
|
||||
maxLength = length;
|
||||
}
|
||||
_fTotalTime = maxLength*_fTotalTime;
|
||||
}
|
||||
|
||||
void ActionObject::addActionNode(ActionNode* node)
|
||||
{
|
||||
if (node == NULL)
|
||||
if (node == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_actionNodeList->addObject(node);
|
||||
_actionNodeList.pushBack(node);
|
||||
node->setUnitTime(_fUnitTime);
|
||||
}
|
||||
void ActionObject::removeActionNode(ActionNode* node)
|
||||
{
|
||||
if (node == NULL)
|
||||
if (node == nullptr)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_actionNodeList->removeObject(node);
|
||||
_actionNodeList.eraseObject(node);
|
||||
}
|
||||
|
||||
void ActionObject::play()
|
||||
{
|
||||
stop();
|
||||
this->updateToFrameByTime(0.0f);
|
||||
auto frameNum = _actionNodeList->count();
|
||||
for ( int i = 0; i < frameNum; i++ )
|
||||
for(const auto &e : _actionNodeList)
|
||||
{
|
||||
ActionNode* actionNode = (ActionNode*)_actionNodeList->getObjectAtIndex(i);
|
||||
actionNode->playAction();
|
||||
e->playAction();
|
||||
}
|
||||
if (_loop)
|
||||
{
|
||||
_pScheduler->scheduleSelector(schedule_selector(ActionObject::simulationActionUpdate), this, 0.0f , kRepeatForever, 0.0f, false);
|
||||
}
|
||||
else
|
||||
{
|
||||
_pScheduler->scheduleSelector(schedule_selector(ActionObject::simulationActionUpdate), this, 0.0f, false);
|
||||
}
|
||||
}
|
||||
|
||||
void ActionObject::play(CallFunc* func)
|
||||
{
|
||||
this->play();
|
||||
this->_CallBack = func;
|
||||
}
|
||||
void ActionObject::pause()
|
||||
{
|
||||
_bPause = true;
|
||||
|
@ -158,14 +170,10 @@ void ActionObject::pause()
|
|||
|
||||
void ActionObject::stop()
|
||||
{
|
||||
auto frameNum = _actionNodeList->count();
|
||||
|
||||
for ( int i = 0; i < frameNum; i++ )
|
||||
for(const auto &e : _actionNodeList)
|
||||
{
|
||||
ActionNode* actionNode = (ActionNode*)_actionNodeList->getObjectAtIndex(i);
|
||||
actionNode->stopAction();
|
||||
e->stopAction();
|
||||
}
|
||||
|
||||
_pScheduler->unscheduleSelector(schedule_selector(ActionObject::simulationActionUpdate), this);
|
||||
_bPause = false;
|
||||
}
|
||||
|
@ -173,29 +181,19 @@ void ActionObject::stop()
|
|||
void ActionObject::updateToFrameByTime(float fTime)
|
||||
{
|
||||
_currentTime = fTime;
|
||||
|
||||
auto nodeNum = _actionNodeList->count();
|
||||
|
||||
for ( int i = 0; i < nodeNum; i++ )
|
||||
for(const auto &e : _actionNodeList)
|
||||
{
|
||||
ActionNode* actionNode = (ActionNode*)_actionNodeList->getObjectAtIndex(i);
|
||||
|
||||
actionNode->updateActionToTimeLine(fTime);
|
||||
e->updateActionToTimeLine(fTime);
|
||||
}
|
||||
}
|
||||
|
||||
void ActionObject::simulationActionUpdate(float dt)
|
||||
{
|
||||
if (_loop)
|
||||
{
|
||||
bool isEnd = true;
|
||||
auto nodeNum = _actionNodeList->count();
|
||||
|
||||
for ( int i = 0; i < nodeNum; i++ )
|
||||
for(const auto &e : _actionNodeList)
|
||||
{
|
||||
ActionNode* actionNode = static_cast<ActionNode*>(_actionNodeList->getObjectAtIndex(i));
|
||||
|
||||
if (actionNode->isActionDoneOnce() == false)
|
||||
if (!e->isActionDoneOnce())
|
||||
{
|
||||
isEnd = false;
|
||||
break;
|
||||
|
@ -203,11 +201,15 @@ void ActionObject::simulationActionUpdate(float dt)
|
|||
}
|
||||
|
||||
if (isEnd)
|
||||
{
|
||||
if (_CallBack != nullptr)
|
||||
{
|
||||
_CallBack->execute();
|
||||
}
|
||||
if (_loop)
|
||||
{
|
||||
this->play();
|
||||
}
|
||||
|
||||
//CCLOG("ActionObject Update");
|
||||
}
|
||||
}
|
||||
}
|
|
@ -27,7 +27,7 @@
|
|||
|
||||
#include "cocos2d.h"
|
||||
#include "CCActionNode.h"
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
#include "cocostudio/DictionaryHelper.h"
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
|
@ -105,6 +105,13 @@ public:
|
|||
*/
|
||||
float getCurrentTime();
|
||||
|
||||
/**
|
||||
* Gets the total time of frame.
|
||||
*
|
||||
* @return fTime the current time of frame
|
||||
*/
|
||||
float getTotalTime();
|
||||
|
||||
/**
|
||||
* Return if the action is playing.
|
||||
*
|
||||
|
@ -117,6 +124,13 @@ public:
|
|||
*/
|
||||
void play();
|
||||
|
||||
/**
|
||||
* Play the action.
|
||||
*
|
||||
* @ Action Call Back
|
||||
*/
|
||||
void play(cocos2d::CallFunc* func);
|
||||
|
||||
/**
|
||||
* Pause the action.
|
||||
*/
|
||||
|
@ -145,12 +159,12 @@ public:
|
|||
void updateToFrameByTime(float fTime);
|
||||
|
||||
/*init properties with a json dictionary*/
|
||||
void initWithDictionary(JsonDictionary* dic,cocos2d::Object* root);
|
||||
void initWithDictionary(const rapidjson::Value& dic,Object* root);
|
||||
|
||||
/*scheduler update function*/
|
||||
void simulationActionUpdate(float dt);
|
||||
protected:
|
||||
cocos2d::Array* _actionNodeList;/*actionnode*/
|
||||
cocos2d::Vector<ActionNode*> _actionNodeList;/*actionnode*/
|
||||
std::string _name;
|
||||
bool _loop;
|
||||
bool _bPause;
|
||||
|
@ -158,6 +172,8 @@ protected:
|
|||
float _fUnitTime;
|
||||
float _currentTime;
|
||||
cocos2d::Scheduler *_pScheduler;
|
||||
cocos2d::CallFunc *_CallBack;
|
||||
float _fTotalTime;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -28,7 +28,7 @@ THE SOFTWARE.
|
|||
#include "cocostudio/CCDataReaderHelper.h"
|
||||
#include "cocostudio/CCDatas.h"
|
||||
#include "cocostudio/CCSkin.h"
|
||||
#include "CCQuadCommand.h"
|
||||
#include "renderer/CCQuadCommand.h"
|
||||
#include "CCRenderer.h"
|
||||
#include "CCGroupCommand.h"
|
||||
|
||||
|
@ -181,9 +181,6 @@ bool Armature::init(const std::string& name)
|
|||
|
||||
setShaderProgram(ShaderCache::getInstance()->getProgram(GLProgram::SHADER_NAME_POSITION_TEXTURE_COLOR));
|
||||
|
||||
unscheduleUpdate();
|
||||
scheduleUpdate();
|
||||
|
||||
setCascadeOpacityEnabled(true);
|
||||
setCascadeColorEnabled(true);
|
||||
|
||||
|
@ -432,6 +429,18 @@ void Armature::draw()
|
|||
}
|
||||
}
|
||||
|
||||
void Armature::onEnter()
|
||||
{
|
||||
Node::onEnter();
|
||||
scheduleUpdate();
|
||||
}
|
||||
|
||||
void Armature::onExit()
|
||||
{
|
||||
Node::onExit();
|
||||
unscheduleUpdate();
|
||||
}
|
||||
|
||||
|
||||
void Armature::visit()
|
||||
{
|
||||
|
|
|
@ -161,6 +161,9 @@ public:
|
|||
virtual void update(float dt) override;
|
||||
virtual void draw() override;
|
||||
|
||||
virtual void onEnter() override;
|
||||
virtual void onExit() override;
|
||||
|
||||
virtual const kmMat4& getNodeToParentTransform() const override;
|
||||
/**
|
||||
* @js NA
|
||||
|
|
|
@ -246,8 +246,12 @@ void ArmatureAnimation::play(const std::string& animationName, int durationTo,
|
|||
_armature->update(0);
|
||||
}
|
||||
|
||||
|
||||
void ArmatureAnimation::playByIndex(int animationIndex, int durationTo, int loop)
|
||||
{
|
||||
playWithIndex(animationIndex, durationTo, loop);
|
||||
}
|
||||
|
||||
void ArmatureAnimation::playWithIndex(int animationIndex, int durationTo, int loop)
|
||||
{
|
||||
std::vector<std::string> &movName = _animationData->movementNames;
|
||||
CC_ASSERT((animationIndex > -1) && ((unsigned int)animationIndex < movName.size()));
|
||||
|
@ -257,7 +261,7 @@ void ArmatureAnimation::playByIndex(int animationIndex, int durationTo, int loop
|
|||
}
|
||||
|
||||
|
||||
void ArmatureAnimation::play(const std::vector<std::string>& movementNames, int durationTo, bool loop)
|
||||
void ArmatureAnimation::playWithNames(const std::vector<std::string>& movementNames, int durationTo, bool loop)
|
||||
{
|
||||
_movementList.clear();
|
||||
_movementListLoop = loop;
|
||||
|
@ -270,7 +274,7 @@ void ArmatureAnimation::play(const std::vector<std::string>& movementNames, int
|
|||
updateMovementList();
|
||||
}
|
||||
|
||||
void ArmatureAnimation::playByIndex(const std::vector<int>& movementIndexes, int durationTo, bool loop)
|
||||
void ArmatureAnimation::playWithIndexes(const std::vector<int>& movementIndexes, int durationTo, bool loop)
|
||||
{
|
||||
_movementList.clear();
|
||||
_movementListLoop = loop;
|
||||
|
|
|
@ -127,13 +127,14 @@ public:
|
|||
|
||||
/**
|
||||
* Play animation by index, the other param is the same to play.
|
||||
* @deprecated, please use playWithIndex
|
||||
* @param animationIndex the animation index you want to play
|
||||
*/
|
||||
virtual void playByIndex(int animationIndex, int durationTo = -1, int loop = -1);
|
||||
CC_DEPRECATED_ATTRIBUTE virtual void playByIndex(int animationIndex, int durationTo = -1, int loop = -1);
|
||||
virtual void playWithIndex(int animationIndex, int durationTo = -1, int loop = -1);
|
||||
|
||||
|
||||
virtual void play(const std::vector<std::string>& movementNames, int durationTo = -1, bool loop = true);
|
||||
virtual void playByIndex(const std::vector<int>& movementIndexes, int durationTo = -1, bool loop = true);
|
||||
virtual void playWithNames(const std::vector<std::string>& movementNames, int durationTo = -1, bool loop = true);
|
||||
virtual void playWithIndexes(const std::vector<int>& movementIndexes, int durationTo = -1, bool loop = true);
|
||||
|
||||
/**
|
||||
* Go to specified frame and play current movement.
|
||||
|
|
|
@ -47,7 +47,7 @@ ArmatureDataManager *ArmatureDataManager::getInstance()
|
|||
return s_sharedArmatureDataManager;
|
||||
}
|
||||
|
||||
void ArmatureDataManager::destoryInstance()
|
||||
void ArmatureDataManager::destroyInstance()
|
||||
{
|
||||
SpriteFrameCacheHelper::purge();
|
||||
DataReaderHelper::purge();
|
||||
|
|
|
@ -49,10 +49,10 @@ public:
|
|||
CC_DEPRECATED_ATTRIBUTE static ArmatureDataManager *sharedArmatureDataManager() { return ArmatureDataManager::getInstance(); }
|
||||
|
||||
/** @deprecated Use destoryInstance() instead */
|
||||
CC_DEPRECATED_ATTRIBUTE static void purge() { ArmatureDataManager::destoryInstance(); };
|
||||
CC_DEPRECATED_ATTRIBUTE static void purge() { ArmatureDataManager::destroyInstance(); };
|
||||
|
||||
static ArmatureDataManager *getInstance();
|
||||
static void destoryInstance();
|
||||
static void destroyInstance();
|
||||
|
||||
private:
|
||||
/**
|
||||
|
@ -199,7 +199,7 @@ private:
|
|||
|
||||
bool _autoLoadSpriteFile;
|
||||
|
||||
std::map<std::string, RelativeData> _relativeDatas;
|
||||
std::unordered_map<std::string, RelativeData> _relativeDatas;
|
||||
};
|
||||
|
||||
|
||||
|
|
|
@ -46,11 +46,13 @@ BatchNode *BatchNode::create()
|
|||
}
|
||||
|
||||
BatchNode::BatchNode()
|
||||
: _groupCommand(nullptr)
|
||||
{
|
||||
}
|
||||
|
||||
BatchNode::~BatchNode()
|
||||
{
|
||||
CC_SAFE_DELETE(_groupCommand);
|
||||
}
|
||||
|
||||
bool BatchNode::init()
|
||||
|
@ -78,6 +80,10 @@ void BatchNode::addChild(Node *child, int zOrder, int tag)
|
|||
if (armature != nullptr)
|
||||
{
|
||||
armature->setBatchNode(this);
|
||||
if (_groupCommand == nullptr)
|
||||
{
|
||||
_groupCommand = new GroupCommand();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -120,16 +126,16 @@ void BatchNode::draw()
|
|||
|
||||
CC_NODE_DRAW_SETUP();
|
||||
|
||||
generateGroupCommand();
|
||||
|
||||
bool pushed = false;
|
||||
for(auto object : _children)
|
||||
{
|
||||
Armature *armature = dynamic_cast<Armature *>(object);
|
||||
if (armature)
|
||||
{
|
||||
if (_popGroupCommand)
|
||||
if (!pushed)
|
||||
{
|
||||
generateGroupCommand();
|
||||
pushed = true;
|
||||
}
|
||||
|
||||
armature->visit();
|
||||
|
@ -137,7 +143,7 @@ void BatchNode::draw()
|
|||
else
|
||||
{
|
||||
Director::getInstance()->getRenderer()->popGroup();
|
||||
_popGroupCommand = true;
|
||||
pushed = false;
|
||||
|
||||
((Node *)object)->visit();
|
||||
}
|
||||
|
@ -147,13 +153,10 @@ void BatchNode::draw()
|
|||
void BatchNode::generateGroupCommand()
|
||||
{
|
||||
Renderer* renderer = Director::getInstance()->getRenderer();
|
||||
GroupCommand* groupCommand = GroupCommand::getCommandPool().generateCommand();
|
||||
groupCommand->init(0,_vertexZ);
|
||||
renderer->addCommand(groupCommand);
|
||||
_groupCommand->init(0,_vertexZ);
|
||||
renderer->addCommand(_groupCommand);
|
||||
|
||||
renderer->pushGroup(groupCommand->getRenderQueueID());
|
||||
|
||||
_popGroupCommand = false;
|
||||
renderer->pushGroup(_groupCommand->getRenderQueueID());
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -27,6 +27,10 @@ THE SOFTWARE.
|
|||
|
||||
#include "cocostudio/CCArmatureDefine.h"
|
||||
|
||||
namespace cocos2d {
|
||||
class GroupCommand;
|
||||
}
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
class BatchNode : public cocos2d::Node
|
||||
|
@ -61,11 +65,10 @@ public:
|
|||
*/
|
||||
void draw() override;
|
||||
|
||||
void setPopGroupCommand(bool pop) { _popGroupCommand = pop; }
|
||||
protected:
|
||||
void generateGroupCommand();
|
||||
|
||||
bool _popGroupCommand;
|
||||
cocos2d::GroupCommand* _groupCommand;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -28,22 +28,80 @@ using namespace cocos2d;
|
|||
namespace cocostudio {
|
||||
|
||||
ComAttribute::ComAttribute(void)
|
||||
: _jsonDict(nullptr)
|
||||
{
|
||||
_name = "ComAttribute";
|
||||
}
|
||||
|
||||
ComAttribute::~ComAttribute(void)
|
||||
{
|
||||
CC_SAFE_DELETE(_jsonDict);
|
||||
_dict.clear();
|
||||
}
|
||||
|
||||
bool ComAttribute::init()
|
||||
{
|
||||
_jsonDict = new JsonDictionary();
|
||||
return true;
|
||||
}
|
||||
|
||||
void ComAttribute::setInt(const std::string& key, int value)
|
||||
{
|
||||
_dict[key] = cocos2d::Value(value);
|
||||
}
|
||||
|
||||
void ComAttribute::setFloat(const std::string& key, float value)
|
||||
{
|
||||
_dict[key] = cocos2d::Value(value);
|
||||
}
|
||||
|
||||
void ComAttribute::setBool(const std::string& key, bool value)
|
||||
{
|
||||
_dict[key] = cocos2d::Value(value);
|
||||
}
|
||||
|
||||
void ComAttribute::setString(const std::string& key, const std::string& value)
|
||||
{
|
||||
_dict[key] = cocos2d::Value(value);
|
||||
}
|
||||
|
||||
int ComAttribute::getInt(const std::string& key, int def) const
|
||||
{
|
||||
if (_dict.find(key) == _dict.end())
|
||||
{
|
||||
return def;
|
||||
}
|
||||
const cocos2d::Value& v = _dict.at(key);
|
||||
return v.asInt();
|
||||
}
|
||||
|
||||
float ComAttribute::getFloat(const std::string& key, float def) const
|
||||
{
|
||||
if (_dict.find(key) == _dict.end())
|
||||
{
|
||||
return def;
|
||||
}
|
||||
const cocos2d::Value& v = _dict.at(key);
|
||||
return v.asFloat();
|
||||
}
|
||||
|
||||
bool ComAttribute::getBool(const std::string& key, bool def) const
|
||||
{
|
||||
if (_dict.find(key) == _dict.end())
|
||||
{
|
||||
return def;
|
||||
}
|
||||
const cocos2d::Value& v = _dict.at(key);
|
||||
return v.asBool();
|
||||
}
|
||||
|
||||
std::string ComAttribute::getString(const std::string& key, const std::string& def) const
|
||||
{
|
||||
if (_dict.find(key) == _dict.end())
|
||||
{
|
||||
return def;
|
||||
}
|
||||
const cocos2d::Value& v = _dict.at(key);
|
||||
return v.asString();
|
||||
}
|
||||
|
||||
ComAttribute* ComAttribute::create(void)
|
||||
{
|
||||
ComAttribute * pRet = new ComAttribute();
|
||||
|
@ -58,54 +116,5 @@ ComAttribute* ComAttribute::create(void)
|
|||
return pRet;
|
||||
}
|
||||
|
||||
void ComAttribute::setInt(const char *key, int value)
|
||||
{
|
||||
CCASSERT(key != NULL, "Argument must be non-nil");
|
||||
_jsonDict->insertItem(key, value);
|
||||
}
|
||||
|
||||
void ComAttribute::setFloat(const char *key, float value)
|
||||
{
|
||||
CCASSERT(key != NULL, "Argument must be non-nil");
|
||||
_jsonDict->insertItem(key, value);
|
||||
}
|
||||
|
||||
void ComAttribute::setBool(const char *key, bool value)
|
||||
{
|
||||
CCASSERT(key != NULL, "Argument must be non-nil");
|
||||
_jsonDict->insertItem(key, value);
|
||||
}
|
||||
|
||||
void ComAttribute::setCString(const char *key, const char *value)
|
||||
{
|
||||
CCASSERT(key != NULL, "Argument must be non-nil");
|
||||
_jsonDict->insertItem(key, value);
|
||||
}
|
||||
|
||||
|
||||
int ComAttribute::getInt(const char *key) const
|
||||
{
|
||||
return _jsonDict->getItemIntValue(key, -1);
|
||||
}
|
||||
|
||||
float ComAttribute::getFloat(const char *key) const
|
||||
{
|
||||
return _jsonDict->getItemFloatValue(key, -1.0f);
|
||||
}
|
||||
|
||||
bool ComAttribute::getBool(const char *key) const
|
||||
{
|
||||
return _jsonDict->getItemBoolvalue(key, false);
|
||||
}
|
||||
|
||||
const char* ComAttribute::getCString(const char *key) const
|
||||
{
|
||||
return _jsonDict->getItemStringValue(key);
|
||||
}
|
||||
|
||||
JsonDictionary* ComAttribute::getDict() const
|
||||
{
|
||||
return _jsonDict;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -27,7 +27,7 @@ THE SOFTWARE.
|
|||
|
||||
#include "cocos2d.h"
|
||||
#include <string>
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
#include "cocostudio/DictionaryHelper.h"
|
||||
|
||||
namespace cocostudio {
|
||||
|
||||
|
@ -48,23 +48,17 @@ public:
|
|||
virtual bool init();
|
||||
static ComAttribute* create(void);
|
||||
|
||||
void setInt(const char *key, int value);
|
||||
void setFloat(const char *key, float value);
|
||||
void setBool(const char *key, bool value);
|
||||
void setCString(const char *key, const char *value);
|
||||
|
||||
int getInt(const char *key) const;
|
||||
float getFloat(const char *key) const;
|
||||
bool getBool(const char *key) const;
|
||||
const char* getCString(const char *key) const;
|
||||
/**
|
||||
* @js NA
|
||||
*/
|
||||
JsonDictionary* getDict() const;
|
||||
void setInt(const std::string& key, int value);
|
||||
void setFloat(const std::string& key, float value);
|
||||
void setBool(const std::string& key, bool value);
|
||||
void setString(const std::string& key, const std::string& value);
|
||||
|
||||
int getInt(const std::string& key, int def = 0) const;
|
||||
float getFloat(const std::string& key, float def = 0.0f) const;
|
||||
bool getBool(const std::string& key, bool def = false) const;
|
||||
std::string getString(const std::string& key, const std::string& def = "") const;
|
||||
private:
|
||||
JsonDictionary *_jsonDict;
|
||||
|
||||
cocos2d::ValueMap _dict;
|
||||
};
|
||||
|
||||
}
|
||||
|
|
|
@ -86,11 +86,14 @@ void ComAudio::end()
|
|||
void ComAudio::preloadBackgroundMusic(const char* pszFilePath)
|
||||
{
|
||||
CocosDenshion::SimpleAudioEngine::getInstance()->preloadBackgroundMusic(pszFilePath);
|
||||
setFile(pszFilePath);
|
||||
setLoop(false);
|
||||
}
|
||||
|
||||
void ComAudio::playBackgroundMusic(const char* pszFilePath, bool bLoop)
|
||||
{
|
||||
CocosDenshion::SimpleAudioEngine::getInstance()->playBackgroundMusic(pszFilePath, bLoop);
|
||||
|
||||
}
|
||||
|
||||
void ComAudio::playBackgroundMusic(const char* pszFilePath)
|
||||
|
@ -98,6 +101,11 @@ void ComAudio::playBackgroundMusic(const char* pszFilePath)
|
|||
CocosDenshion::SimpleAudioEngine::getInstance()->playBackgroundMusic(pszFilePath);
|
||||
}
|
||||
|
||||
void ComAudio::playBackgroundMusic()
|
||||
{
|
||||
CocosDenshion::SimpleAudioEngine::getInstance()->playBackgroundMusic(_filePath.c_str(), _loop);
|
||||
}
|
||||
|
||||
void ComAudio::stopBackgroundMusic(bool bReleaseData)
|
||||
{
|
||||
CocosDenshion::SimpleAudioEngine::getInstance()->stopBackgroundMusic(bReleaseData);
|
||||
|
@ -163,6 +171,11 @@ unsigned int ComAudio::playEffect(const char* pszFilePath)
|
|||
return CocosDenshion::SimpleAudioEngine::getInstance()->playEffect(pszFilePath);
|
||||
}
|
||||
|
||||
unsigned int ComAudio::playEffect()
|
||||
{
|
||||
return CocosDenshion::SimpleAudioEngine::getInstance()->playEffect(_filePath.c_str(), _loop);
|
||||
}
|
||||
|
||||
void ComAudio::pauseEffect(unsigned int nSoundId)
|
||||
{
|
||||
return CocosDenshion::SimpleAudioEngine::getInstance()->pauseEffect(nSoundId);
|
||||
|
@ -196,6 +209,8 @@ void ComAudio::stopAllEffects()
|
|||
void ComAudio::preloadEffect(const char* pszFilePath)
|
||||
{
|
||||
CocosDenshion::SimpleAudioEngine::getInstance()->preloadEffect(pszFilePath);
|
||||
setFile(pszFilePath);
|
||||
setLoop(false);
|
||||
}
|
||||
|
||||
void ComAudio::unloadEffect(const char *pszFilePath)
|
||||
|
|
|
@ -64,6 +64,7 @@ public:
|
|||
void preloadBackgroundMusic(const char* pszFilePath);
|
||||
void playBackgroundMusic(const char* pszFilePath, bool bLoop);
|
||||
void playBackgroundMusic(const char* pszFilePath);
|
||||
void playBackgroundMusic();
|
||||
void stopBackgroundMusic(bool bReleaseData);
|
||||
void stopBackgroundMusic();
|
||||
void pauseBackgroundMusic();
|
||||
|
@ -77,6 +78,7 @@ public:
|
|||
void setEffectsVolume(float volume);
|
||||
unsigned int playEffect(const char* pszFilePath, bool bLoop);
|
||||
unsigned int playEffect(const char* pszFilePath);
|
||||
unsigned int playEffect();
|
||||
void pauseEffect(unsigned int nSoundId);
|
||||
void pauseAllEffects();
|
||||
void resumeEffect(unsigned int nSoundId);
|
||||
|
|
|
@ -295,7 +295,6 @@ void DataReaderHelper::addDataFromFile(const std::string& filePath)
|
|||
dataInfo.filename = filePathStr;
|
||||
dataInfo.asyncStruct = nullptr;
|
||||
dataInfo.baseFilePath = basefilePath;
|
||||
|
||||
if (str == ".xml")
|
||||
{
|
||||
DataReaderHelper::addDataFromCache(contentStr, &dataInfo);
|
||||
|
@ -1180,17 +1179,21 @@ ContourData *DataReaderHelper::decodeContour(tinyxml2::XMLElement *contourXML, D
|
|||
|
||||
void DataReaderHelper::addDataFromJsonCache(const std::string& fileContent, DataInfo *dataInfo)
|
||||
{
|
||||
JsonDictionary json;
|
||||
json.initWithDescription(fileContent.c_str());
|
||||
rapidjson::Document json;
|
||||
|
||||
dataInfo->contentScale = json.getItemFloatValue(CONTENT_SCALE, 1);
|
||||
json.Parse<0>(fileContent.c_str());
|
||||
if (json.HasParseError()) {
|
||||
CCLOG("GetParseError %s\n",json.GetParseError());
|
||||
}
|
||||
|
||||
dataInfo->contentScale = DICTOOL->getFloatValue_json(json, CONTENT_SCALE, 1.0f);
|
||||
|
||||
// Decode armatures
|
||||
int length = json.getArrayItemCount(ARMATURE_DATA);
|
||||
int length = DICTOOL->getArrayCount_json(json, ARMATURE_DATA);
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *armatureDic = json.getSubItemFromArray(ARMATURE_DATA, i);
|
||||
ArmatureData *armatureData = decodeArmature(*armatureDic, dataInfo);
|
||||
const rapidjson::Value &armatureDic = DICTOOL->getSubDictionary_json(json, ARMATURE_DATA, i);
|
||||
ArmatureData *armatureData = decodeArmature(armatureDic, dataInfo);
|
||||
|
||||
if (dataInfo->asyncStruct)
|
||||
{
|
||||
|
@ -1202,15 +1205,14 @@ void DataReaderHelper::addDataFromJsonCache(const std::string& fileContent, Data
|
|||
{
|
||||
_dataReaderHelper->_addDataMutex.unlock();
|
||||
}
|
||||
delete armatureDic;
|
||||
}
|
||||
|
||||
// Decode animations
|
||||
length = json.getArrayItemCount(ANIMATION_DATA);
|
||||
length = DICTOOL->getArrayCount_json(json, ANIMATION_DATA); //json[ANIMATION_DATA].IsNull() ? 0 : json[ANIMATION_DATA].Size();
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *animationDic = json.getSubItemFromArray(ANIMATION_DATA, i);
|
||||
AnimationData *animationData = decodeAnimation(*animationDic, dataInfo);
|
||||
const rapidjson::Value &animationDic = DICTOOL->getSubDictionary_json(json, ANIMATION_DATA, i);
|
||||
AnimationData *animationData = decodeAnimation(animationDic, dataInfo);
|
||||
|
||||
if (dataInfo->asyncStruct)
|
||||
{
|
||||
|
@ -1222,15 +1224,14 @@ void DataReaderHelper::addDataFromJsonCache(const std::string& fileContent, Data
|
|||
{
|
||||
_dataReaderHelper->_addDataMutex.unlock();
|
||||
}
|
||||
delete animationDic;
|
||||
}
|
||||
|
||||
// Decode textures
|
||||
length = json.getArrayItemCount(TEXTURE_DATA);
|
||||
length = DICTOOL->getArrayCount_json(json, TEXTURE_DATA);
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *textureDic = json.getSubItemFromArray(TEXTURE_DATA, i);
|
||||
TextureData *textureData = decodeTexture(*textureDic);
|
||||
const rapidjson::Value &textureDic = DICTOOL->getSubDictionary_json(json, TEXTURE_DATA, i);
|
||||
TextureData *textureData = decodeTexture(textureDic);
|
||||
|
||||
if (dataInfo->asyncStruct)
|
||||
{
|
||||
|
@ -1242,17 +1243,16 @@ void DataReaderHelper::addDataFromJsonCache(const std::string& fileContent, Data
|
|||
{
|
||||
_dataReaderHelper->_addDataMutex.unlock();
|
||||
}
|
||||
delete textureDic;
|
||||
}
|
||||
|
||||
// Auto load sprite file
|
||||
bool autoLoad = dataInfo->asyncStruct == nullptr ? ArmatureDataManager::getInstance()->isAutoLoadSpriteFile() : dataInfo->asyncStruct->autoLoadSpriteFile;
|
||||
if (autoLoad)
|
||||
{
|
||||
length = json.getArrayItemCount(CONFIG_FILE_PATH);
|
||||
length = DICTOOL->getArrayCount_json(json, CONFIG_FILE_PATH); // json[CONFIG_FILE_PATH].IsNull() ? 0 : json[CONFIG_FILE_PATH].Size();
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
const char *path = json.getStringValueFromArray(CONFIG_FILE_PATH, i);
|
||||
const char *path = DICTOOL->getStringValueFromArray_json(json, CONFIG_FILE_PATH, i); // json[CONFIG_FILE_PATH][i].IsNull() ? NULL : json[CONFIG_FILE_PATH][i].GetString();
|
||||
if (path == nullptr)
|
||||
{
|
||||
CCLOG("load CONFIG_FILE_PATH error.");
|
||||
|
@ -1277,70 +1277,68 @@ void DataReaderHelper::addDataFromJsonCache(const std::string& fileContent, Data
|
|||
}
|
||||
}
|
||||
|
||||
ArmatureData *DataReaderHelper::decodeArmature(JsonDictionary &json, DataInfo *dataInfo)
|
||||
ArmatureData *DataReaderHelper::decodeArmature(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
ArmatureData *armatureData = new ArmatureData();
|
||||
armatureData->init();
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != nullptr)
|
||||
{
|
||||
armatureData->name = name;
|
||||
}
|
||||
|
||||
dataInfo->cocoStudioVersion = armatureData->dataVersion = json.getItemFloatValue(VERSION, 0.1f);
|
||||
dataInfo->cocoStudioVersion = armatureData->dataVersion = DICTOOL->getFloatValue_json(json, VERSION, 0.1f);
|
||||
|
||||
int length = json.getArrayItemCount(BONE_DATA);
|
||||
int length = DICTOOL->getArrayCount_json(json, BONE_DATA, 0);
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(BONE_DATA, i);
|
||||
BoneData *boneData = decodeBone(*dic, dataInfo);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, BONE_DATA, i); //json[BONE_DATA][i];
|
||||
BoneData *boneData = decodeBone(dic, dataInfo);
|
||||
armatureData->addBoneData(boneData);
|
||||
boneData->release();
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
return armatureData;
|
||||
}
|
||||
|
||||
BoneData *DataReaderHelper::decodeBone(JsonDictionary &json, DataInfo *dataInfo)
|
||||
BoneData *DataReaderHelper::decodeBone(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
BoneData *boneData = new BoneData();
|
||||
boneData->init();
|
||||
|
||||
decodeNode(boneData, json, dataInfo);
|
||||
|
||||
const char *str = json.getItemStringValue(A_NAME);
|
||||
const char *str = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(str != nullptr)
|
||||
{
|
||||
boneData->name = str;
|
||||
}
|
||||
|
||||
str = json.getItemStringValue(A_PARENT);
|
||||
str = DICTOOL->getStringValue_json(json, A_PARENT);
|
||||
if(str != nullptr)
|
||||
{
|
||||
boneData->parentName = str;
|
||||
}
|
||||
|
||||
int length = json.getArrayItemCount(DISPLAY_DATA);
|
||||
int length = DICTOOL->getArrayCount_json(json, DISPLAY_DATA);
|
||||
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(DISPLAY_DATA, i);
|
||||
DisplayData *displayData = decodeBoneDisplay(*dic, dataInfo);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, DISPLAY_DATA, i);
|
||||
DisplayData *displayData = decodeBoneDisplay(dic, dataInfo);
|
||||
boneData->addDisplayData(displayData);
|
||||
displayData->release();
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
return boneData;
|
||||
}
|
||||
|
||||
DisplayData *DataReaderHelper::decodeBoneDisplay(JsonDictionary &json, DataInfo *dataInfo)
|
||||
DisplayData *DataReaderHelper::decodeBoneDisplay(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
DisplayType displayType = (DisplayType)json.getItemIntValue(A_DISPLAY_TYPE, CS_DISPLAY_SPRITE);
|
||||
DisplayType displayType = (DisplayType)(DICTOOL->getIntValue_json(json, A_DISPLAY_TYPE, CS_DISPLAY_SPRITE));
|
||||
|
||||
DisplayData *displayData = nullptr;
|
||||
|
||||
|
@ -1350,27 +1348,29 @@ DisplayData *DataReaderHelper::decodeBoneDisplay(JsonDictionary &json, DataInfo
|
|||
{
|
||||
displayData = new SpriteDisplayData();
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
if(name != nullptr)
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != NULL)
|
||||
{
|
||||
((SpriteDisplayData *)displayData)->displayName = name;
|
||||
}
|
||||
|
||||
JsonDictionary *dic = json.getSubItemFromArray(SKIN_DATA, 0);
|
||||
if (dic != nullptr)
|
||||
const rapidjson::Value &dicArray = DICTOOL->getSubDictionary_json(json, SKIN_DATA);
|
||||
if(!dicArray.IsNull())
|
||||
{
|
||||
rapidjson::SizeType index = 0;
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(dicArray, index);
|
||||
if (!dic.IsNull())
|
||||
{
|
||||
SpriteDisplayData *sdd = (SpriteDisplayData *)displayData;
|
||||
sdd->skinData.x = dic->getItemFloatValue(A_X, 0) * s_PositionReadScale;
|
||||
sdd->skinData.y = dic->getItemFloatValue(A_Y, 0) * s_PositionReadScale;
|
||||
sdd->skinData.scaleX = dic->getItemFloatValue(A_SCALE_X, 1);
|
||||
sdd->skinData.scaleY = dic->getItemFloatValue(A_SCALE_Y, 1);
|
||||
sdd->skinData.skewX = dic->getItemFloatValue(A_SKEW_X, 0);
|
||||
sdd->skinData.skewY = dic->getItemFloatValue(A_SKEW_Y, 0);
|
||||
sdd->skinData.x = DICTOOL->getFloatValue_json(dic, A_X) * s_PositionReadScale;
|
||||
sdd->skinData.y = DICTOOL->getFloatValue_json(dic, A_Y) * s_PositionReadScale;
|
||||
sdd->skinData.scaleX = DICTOOL->getFloatValue_json(dic, A_SCALE_X, 1.0f);
|
||||
sdd->skinData.scaleY = DICTOOL->getFloatValue_json(dic, A_SCALE_Y, 1.0f);
|
||||
sdd->skinData.skewX = DICTOOL->getFloatValue_json(dic, A_SKEW_X, 1.0f);
|
||||
sdd->skinData.skewY = DICTOOL->getFloatValue_json(dic, A_SKEW_Y, 1.0f);
|
||||
|
||||
sdd->skinData.x *= dataInfo->contentScale;
|
||||
sdd->skinData.y *= dataInfo->contentScale;
|
||||
|
||||
delete dic;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1379,7 +1379,7 @@ DisplayData *DataReaderHelper::decodeBoneDisplay(JsonDictionary &json, DataInfo
|
|||
{
|
||||
displayData = new ArmatureDisplayData();
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != nullptr)
|
||||
{
|
||||
((ArmatureDisplayData *)displayData)->displayName = name;
|
||||
|
@ -1390,7 +1390,7 @@ DisplayData *DataReaderHelper::decodeBoneDisplay(JsonDictionary &json, DataInfo
|
|||
{
|
||||
displayData = new ParticleDisplayData();
|
||||
|
||||
const char *plist = json.getItemStringValue(A_PLIST);
|
||||
const char *plist = DICTOOL->getStringValue_json(json, A_PLIST);
|
||||
if(plist != nullptr)
|
||||
{
|
||||
if (dataInfo->asyncStruct)
|
||||
|
@ -1416,80 +1416,84 @@ DisplayData *DataReaderHelper::decodeBoneDisplay(JsonDictionary &json, DataInfo
|
|||
return displayData;
|
||||
}
|
||||
|
||||
AnimationData *DataReaderHelper::decodeAnimation(JsonDictionary &json, DataInfo *dataInfo)
|
||||
AnimationData *DataReaderHelper::decodeAnimation(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
AnimationData *aniData = new AnimationData();
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != nullptr)
|
||||
{
|
||||
aniData->name = name;
|
||||
}
|
||||
|
||||
int length = json.getArrayItemCount(MOVEMENT_DATA);
|
||||
int length = DICTOOL->getArrayCount_json(json, MOVEMENT_DATA);
|
||||
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(MOVEMENT_DATA, i);
|
||||
MovementData *movementData = decodeMovement(*dic, dataInfo);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, MOVEMENT_DATA, i);
|
||||
MovementData *movementData = decodeMovement(dic, dataInfo);
|
||||
aniData->addMovement(movementData);
|
||||
movementData->release();
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
return aniData;
|
||||
}
|
||||
|
||||
MovementData *DataReaderHelper::decodeMovement(JsonDictionary &json, DataInfo *dataInfo)
|
||||
MovementData *DataReaderHelper::decodeMovement(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
MovementData *movementData = new MovementData();
|
||||
|
||||
movementData->loop = json.getItemBoolvalue(A_LOOP, true);
|
||||
movementData->durationTween = json.getItemIntValue(A_DURATION_TWEEN, 0);
|
||||
movementData->durationTo = json.getItemIntValue(A_DURATION_TO, 0);
|
||||
movementData->duration = json.getItemIntValue(A_DURATION, 0);
|
||||
movementData->scale = json.getItemFloatValue(A_MOVEMENT_SCALE, 1);
|
||||
movementData->tweenEasing = (TweenType)json.getItemIntValue(A_TWEEN_EASING, Linear);
|
||||
movementData->loop = DICTOOL->getBooleanValue_json(json, A_LOOP, true);
|
||||
movementData->durationTween = DICTOOL->getIntValue_json(json, A_DURATION_TWEEN, 0);
|
||||
movementData->durationTo = DICTOOL->getIntValue_json(json, A_DURATION_TO, 0);
|
||||
movementData->duration = DICTOOL->getIntValue_json(json, A_DURATION, 0);
|
||||
if (!DICTOOL->checkObjectExist_json(json, A_DURATION))
|
||||
{
|
||||
movementData->scale = 1.0f;
|
||||
}
|
||||
else
|
||||
{
|
||||
movementData->scale = DICTOOL->getFloatValue_json(json, A_MOVEMENT_SCALE, 1.0f);
|
||||
}
|
||||
movementData->tweenEasing = (TweenType)(DICTOOL->getIntValue_json(json, A_TWEEN_EASING, Linear));
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != nullptr)
|
||||
{
|
||||
movementData->name = name;
|
||||
}
|
||||
|
||||
int length = json.getArrayItemCount(MOVEMENT_BONE_DATA);
|
||||
int length = DICTOOL->getArrayCount_json(json, MOVEMENT_BONE_DATA);
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(MOVEMENT_BONE_DATA, i);
|
||||
MovementBoneData *movementBoneData = decodeMovementBone(*dic, dataInfo);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, MOVEMENT_BONE_DATA, i);
|
||||
MovementBoneData *movementBoneData = decodeMovementBone(dic, dataInfo);
|
||||
movementData->addMovementBoneData(movementBoneData);
|
||||
movementBoneData->release();
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
return movementData;
|
||||
}
|
||||
|
||||
MovementBoneData *DataReaderHelper::decodeMovementBone(JsonDictionary &json, DataInfo *dataInfo)
|
||||
MovementBoneData *DataReaderHelper::decodeMovementBone(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
MovementBoneData *movementBoneData = new MovementBoneData();
|
||||
movementBoneData->init();
|
||||
|
||||
movementBoneData->delay = json.getItemFloatValue(A_MOVEMENT_DELAY, 0);
|
||||
movementBoneData->delay = DICTOOL->getFloatValue_json(json, A_MOVEMENT_DELAY);
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != nullptr)
|
||||
{
|
||||
movementBoneData->name = name;
|
||||
}
|
||||
|
||||
int length = json.getArrayItemCount(FRAME_DATA);
|
||||
for (int i = 0; i < length; i++)
|
||||
rapidjson::SizeType length = DICTOOL->getArrayCount_json(json, FRAME_DATA);
|
||||
for (rapidjson::SizeType i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(FRAME_DATA, i);
|
||||
FrameData *frameData = decodeFrame(*dic, dataInfo);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, FRAME_DATA, i);
|
||||
FrameData *frameData = decodeFrame(dic, dataInfo);
|
||||
|
||||
movementBoneData->addFrameData(frameData);
|
||||
frameData->release();
|
||||
|
@ -1499,8 +1503,6 @@ MovementBoneData *DataReaderHelper::decodeMovementBone(JsonDictionary &json, Dat
|
|||
frameData->frameID = movementBoneData->duration;
|
||||
movementBoneData->duration += frameData->duration;
|
||||
}
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1544,19 +1546,19 @@ MovementBoneData *DataReaderHelper::decodeMovementBone(JsonDictionary &json, Dat
|
|||
return movementBoneData;
|
||||
}
|
||||
|
||||
FrameData *DataReaderHelper::decodeFrame(JsonDictionary &json, DataInfo *dataInfo)
|
||||
FrameData *DataReaderHelper::decodeFrame(const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
FrameData *frameData = new FrameData();
|
||||
|
||||
decodeNode(frameData, json, dataInfo);
|
||||
|
||||
frameData->tweenEasing = (TweenType)json.getItemIntValue(A_TWEEN_EASING, Linear);
|
||||
frameData->displayIndex = json.getItemIntValue(A_DISPLAY_INDEX, 0);
|
||||
frameData->blendFunc.src = (GLenum)(json.getItemIntValue(A_BLEND_SRC, BlendFunc::ALPHA_NON_PREMULTIPLIED.src));
|
||||
frameData->blendFunc.dst = (GLenum)(json.getItemIntValue(A_BLEND_DST, BlendFunc::ALPHA_NON_PREMULTIPLIED.dst));
|
||||
frameData->isTween = (bool)json.getItemBoolvalue(A_TWEEN_FRAME, true);
|
||||
frameData->tweenEasing = (TweenType)(DICTOOL->getIntValue_json(json, A_TWEEN_EASING, Linear));
|
||||
frameData->displayIndex = DICTOOL->getIntValue_json(json, A_DISPLAY_INDEX);
|
||||
frameData->blendFunc.src = (GLenum)(DICTOOL->getIntValue_json(json, A_BLEND_SRC, BlendFunc::ALPHA_NON_PREMULTIPLIED.src));
|
||||
frameData->blendFunc.dst = (GLenum)(DICTOOL->getIntValue_json(json, A_BLEND_DST, BlendFunc::ALPHA_NON_PREMULTIPLIED.dst));
|
||||
frameData->isTween = DICTOOL->getBooleanValue_json(json, A_TWEEN_FRAME, true);
|
||||
|
||||
const char *event = json.getItemStringValue(A_EVENT);
|
||||
const char *event = DICTOOL->getStringValue_json(json, A_EVENT);
|
||||
if (event != nullptr)
|
||||
{
|
||||
frameData->strEvent = event;
|
||||
|
@ -1564,116 +1566,118 @@ FrameData *DataReaderHelper::decodeFrame(JsonDictionary &json, DataInfo *dataInf
|
|||
|
||||
if (dataInfo->cocoStudioVersion < VERSION_COMBINED)
|
||||
{
|
||||
frameData->duration = json.getItemIntValue(A_DURATION, 1);
|
||||
frameData->duration = DICTOOL->getIntValue_json(json, A_DURATION, 1);
|
||||
}
|
||||
else
|
||||
{
|
||||
frameData->frameID = json.getItemIntValue(A_FRAME_INDEX, 0);
|
||||
frameData->frameID = DICTOOL->getIntValue_json(json, A_FRAME_INDEX);
|
||||
}
|
||||
|
||||
|
||||
int length = json.getArrayItemCount(A_EASING_PARAM);
|
||||
int length = DICTOOL->getArrayCount_json(json, A_EASING_PARAM);
|
||||
if (length != 0)
|
||||
{
|
||||
frameData->easingParams = new float[length];
|
||||
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
frameData->easingParams[i] = json.getFloatValueFromArray(A_EASING_PARAM, i, 0);
|
||||
frameData->easingParams[i] = DICTOOL->getFloatValueFromArray_json(json, A_EASING_PARAM, i);
|
||||
}
|
||||
}
|
||||
|
||||
return frameData;
|
||||
}
|
||||
|
||||
TextureData *DataReaderHelper::decodeTexture(JsonDictionary &json)
|
||||
TextureData *DataReaderHelper::decodeTexture(const rapidjson::Value& json)
|
||||
{
|
||||
TextureData *textureData = new TextureData();
|
||||
textureData->init();
|
||||
|
||||
const char *name = json.getItemStringValue(A_NAME);
|
||||
const char *name = DICTOOL->getStringValue_json(json, A_NAME);
|
||||
if(name != nullptr)
|
||||
{
|
||||
textureData->name = name;
|
||||
}
|
||||
|
||||
textureData->width = json.getItemFloatValue(A_WIDTH, 0);
|
||||
textureData->height = json.getItemFloatValue(A_HEIGHT, 0);
|
||||
textureData->pivotX = json.getItemFloatValue(A_PIVOT_X, 0);
|
||||
textureData->pivotY = json.getItemFloatValue(A_PIVOT_Y, 0);
|
||||
textureData->width = DICTOOL->getFloatValue_json(json, A_WIDTH);
|
||||
textureData->height = DICTOOL->getFloatValue_json(json, A_HEIGHT);
|
||||
textureData->pivotX = DICTOOL->getFloatValue_json(json, A_PIVOT_X);
|
||||
textureData->pivotY = DICTOOL->getFloatValue_json(json, A_PIVOT_Y);
|
||||
|
||||
int length = json.getArrayItemCount(CONTOUR_DATA);
|
||||
int length = DICTOOL->getArrayCount_json(json, CONTOUR_DATA);
|
||||
for (int i = 0; i < length; i++)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(CONTOUR_DATA, i);
|
||||
ContourData *contourData = decodeContour(*dic);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, CONTOUR_DATA, i);
|
||||
ContourData *contourData = decodeContour(dic);
|
||||
textureData->contourDataList.pushBack(contourData);
|
||||
contourData->release();
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
return textureData;
|
||||
}
|
||||
|
||||
ContourData *DataReaderHelper::decodeContour(JsonDictionary &json)
|
||||
ContourData *DataReaderHelper::decodeContour(const rapidjson::Value& json)
|
||||
{
|
||||
ContourData *contourData = new ContourData();
|
||||
contourData->init();
|
||||
|
||||
int length = json.getArrayItemCount(VERTEX_POINT);
|
||||
int length = DICTOOL->getArrayCount_json(json, VERTEX_POINT);
|
||||
for (int i = length - 1; i >= 0; i--)
|
||||
{
|
||||
JsonDictionary *dic = json.getSubItemFromArray(VERTEX_POINT, i);
|
||||
const rapidjson::Value &dic = DICTOOL->getSubDictionary_json(json, VERTEX_POINT, i);
|
||||
|
||||
Point vertex;
|
||||
|
||||
vertex.x = dic->getItemFloatValue(A_X, 0);
|
||||
vertex.y = dic->getItemFloatValue(A_Y, 0);
|
||||
vertex.x = DICTOOL->getFloatValue_json(dic, A_X);
|
||||
vertex.y = DICTOOL->getFloatValue_json(dic, A_Y);
|
||||
|
||||
contourData->vertexList.push_back(vertex);
|
||||
|
||||
delete dic;
|
||||
}
|
||||
|
||||
return contourData;
|
||||
}
|
||||
|
||||
void DataReaderHelper::decodeNode(BaseData *node, JsonDictionary &json, DataInfo *dataInfo)
|
||||
void DataReaderHelper::decodeNode(BaseData *node, const rapidjson::Value& json, DataInfo *dataInfo)
|
||||
{
|
||||
node->x = json.getItemFloatValue(A_X, 0) * s_PositionReadScale;
|
||||
node->y = json.getItemFloatValue(A_Y, 0) * s_PositionReadScale;
|
||||
node->x = DICTOOL->getFloatValue_json(json, A_X) * s_PositionReadScale;
|
||||
node->y = DICTOOL->getFloatValue_json(json, A_Y) * s_PositionReadScale;
|
||||
|
||||
node->x *= dataInfo->contentScale;
|
||||
node->y *= dataInfo->contentScale;
|
||||
|
||||
node->zOrder = json.getItemIntValue(A_Z, 0);
|
||||
node->zOrder = DICTOOL->getIntValue_json(json, A_Z);
|
||||
|
||||
node->skewX = json.getItemFloatValue(A_SKEW_X, 0);
|
||||
node->skewY = json.getItemFloatValue(A_SKEW_Y, 0);
|
||||
node->scaleX = json.getItemFloatValue(A_SCALE_X, 1);
|
||||
node->scaleY = json.getItemFloatValue(A_SCALE_Y, 1);
|
||||
node->skewX = DICTOOL->getFloatValue_json(json, A_SKEW_X);
|
||||
node->skewY = DICTOOL->getFloatValue_json(json, A_SKEW_Y);
|
||||
node->scaleX = DICTOOL->getFloatValue_json(json, A_SCALE_X, 1.0f);
|
||||
node->scaleY = DICTOOL->getFloatValue_json(json, A_SCALE_Y, 1.0f);
|
||||
|
||||
JsonDictionary *colorDic = nullptr;
|
||||
if (dataInfo->cocoStudioVersion < VERSION_COLOR_READING)
|
||||
{
|
||||
colorDic = json.getSubItemFromArray(COLOR_INFO, 0);
|
||||
if (DICTOOL->checkObjectExist_json(json, 0))
|
||||
{
|
||||
const rapidjson::Value &colorDic = DICTOOL->getSubDictionary_json(json, 0);
|
||||
node->a = DICTOOL->getIntValue_json(colorDic, A_ALPHA, 255);
|
||||
node->r = DICTOOL->getIntValue_json(colorDic, A_RED, 255);
|
||||
node->g = DICTOOL->getIntValue_json(colorDic, A_GREEN, 255);
|
||||
node->b = DICTOOL->getIntValue_json(colorDic, A_BLUE, 255);
|
||||
|
||||
node->isUseColorInfo = true;
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
colorDic = json.getSubDictionary(COLOR_INFO);
|
||||
}
|
||||
|
||||
if (colorDic)
|
||||
if (DICTOOL->checkObjectExist_json(json, COLOR_INFO))
|
||||
{
|
||||
node->a = colorDic->getItemIntValue(A_ALPHA, 255);
|
||||
node->r = colorDic->getItemIntValue(A_RED, 255);
|
||||
node->g = colorDic->getItemIntValue(A_GREEN, 255);
|
||||
node->b = colorDic->getItemIntValue(A_BLUE, 255);
|
||||
const rapidjson::Value &colorDic = DICTOOL->getSubDictionary_json(json, COLOR_INFO); //json.getSubDictionary(COLOR_INFO);
|
||||
node->a = DICTOOL->getIntValue_json(colorDic, A_ALPHA, 255);
|
||||
node->r = DICTOOL->getIntValue_json(colorDic, A_RED, 255);
|
||||
node->g = DICTOOL->getIntValue_json(colorDic, A_GREEN, 255);
|
||||
node->b = DICTOOL->getIntValue_json(colorDic, A_BLUE, 255);
|
||||
|
||||
node->isUseColorInfo = true;
|
||||
|
||||
delete colorDic;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -28,7 +28,7 @@ THE SOFTWARE.
|
|||
#include "cocostudio/CCArmatureDefine.h"
|
||||
#include "cocostudio/CCDatas.h"
|
||||
#include "cocostudio/CCArmature.h"
|
||||
#include "cocostudio/CSContentJsonDictionary.h"
|
||||
#include "cocostudio/DictionaryHelper.h"
|
||||
|
||||
#include <string>
|
||||
#include <queue>
|
||||
|
@ -156,20 +156,20 @@ public:
|
|||
public:
|
||||
static void addDataFromJsonCache(const std::string& fileContent, DataInfo *dataInfo = nullptr);
|
||||
|
||||
static ArmatureData *decodeArmature(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static BoneData *decodeBone(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static DisplayData *decodeBoneDisplay(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static ArmatureData *decodeArmature(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
static BoneData *decodeBone(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
static DisplayData *decodeBoneDisplay(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
|
||||
static AnimationData *decodeAnimation(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static MovementData *decodeMovement(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static MovementBoneData *decodeMovementBone(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static FrameData *decodeFrame(JsonDictionary &json, DataInfo *dataInfo);
|
||||
static AnimationData *decodeAnimation(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
static MovementData *decodeMovement(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
static MovementBoneData *decodeMovementBone(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
static FrameData *decodeFrame(const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
|
||||
static TextureData *decodeTexture(JsonDictionary &json);
|
||||
static TextureData *decodeTexture(const rapidjson::Value& json);
|
||||
|
||||
static ContourData *decodeContour(JsonDictionary &json);
|
||||
static ContourData *decodeContour(const rapidjson::Value& json);
|
||||
|
||||
static void decodeNode(BaseData *node, JsonDictionary &json, DataInfo *dataInfo);
|
||||
static void decodeNode(BaseData *node, const rapidjson::Value& json, DataInfo *dataInfo);
|
||||
|
||||
protected:
|
||||
void loadData();
|
||||
|
|
|
@ -142,7 +142,7 @@ Color4B BaseData::getColor()
|
|||
return Color4B(r, g, b, a);
|
||||
}
|
||||
|
||||
const std::string& DisplayData::changeDisplayToTexture(const std::string& displayName)
|
||||
const std::string DisplayData::changeDisplayToTexture(const std::string& displayName)
|
||||
{
|
||||
// remove .xxx
|
||||
std::string textureName = displayName;
|
||||
|
@ -153,7 +153,7 @@ const std::string& DisplayData::changeDisplayToTexture(const std::string& displa
|
|||
textureName = textureName.erase(startPos);
|
||||
}
|
||||
|
||||
return textureName.c_str();
|
||||
return textureName;
|
||||
}
|
||||
|
||||
DisplayData::DisplayData(void)
|
||||
|
|
|
@ -136,7 +136,7 @@ class DisplayData : public cocos2d::Object
|
|||
public:
|
||||
CC_CREATE_NO_PARAM_NO_INIT(DisplayData)
|
||||
|
||||
static const std::string& changeDisplayToTexture(const std::string& displayName);
|
||||
static const std::string changeDisplayToTexture(const std::string& displayName);
|
||||
public:
|
||||
/**
|
||||
* @js ctor
|
||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue