mirror of https://github.com/axmolengine/axmol.git
issue #1470:fix some logical errors
This commit is contained in:
parent
4b969e35c8
commit
a0feb5f289
|
@ -299,7 +299,7 @@ void CCBAnimationManager::setAnimatedProperty(const char *pPropName, CCNode *pNo
|
||||||
}
|
}
|
||||||
else if (strcmp(pPropName, "scale") == 0)
|
else if (strcmp(pPropName, "scale") == 0)
|
||||||
{
|
{
|
||||||
// Get position type
|
// Get scale type
|
||||||
CCArray *array = (CCArray*)getBaseValue(pNode, pPropName);
|
CCArray *array = (CCArray*)getBaseValue(pNode, pPropName);
|
||||||
int type = ((CCBValue*)array->objectAtIndex(2))->getIntValue();
|
int type = ((CCBValue*)array->objectAtIndex(2))->getIntValue();
|
||||||
|
|
||||||
|
@ -314,7 +314,7 @@ void CCBAnimationManager::setAnimatedProperty(const char *pPropName, CCNode *pNo
|
||||||
{
|
{
|
||||||
// [node setValue:value forKey:name];
|
// [node setValue:value forKey:name];
|
||||||
|
|
||||||
// TODO only handle rotation, opacity,
|
// TODO only handle rotation, opacity, displayFrame, color
|
||||||
if (strcmp(pPropName, "rotation") == 0)
|
if (strcmp(pPropName, "rotation") == 0)
|
||||||
{
|
{
|
||||||
float rotate = ((CCBValue*)pValue)->getFloatValue();
|
float rotate = ((CCBValue*)pValue)->getFloatValue();
|
||||||
|
@ -374,7 +374,7 @@ CCActionInterval* CCBAnimationManager::getEaseAction(CCActionInterval *pAction,
|
||||||
}
|
}
|
||||||
else if (nEasingType == kCCBKeyframeEasingCubicOut)
|
else if (nEasingType == kCCBKeyframeEasingCubicOut)
|
||||||
{
|
{
|
||||||
return CCEaseInOut::create(pAction, fEasingOpt);
|
return CCEaseOut::create(pAction, fEasingOpt);
|
||||||
}
|
}
|
||||||
else if (nEasingType == kCCBKeyframeEasingCubicInOut)
|
else if (nEasingType == kCCBKeyframeEasingCubicInOut)
|
||||||
{
|
{
|
||||||
|
@ -485,9 +485,9 @@ void CCBAnimationManager::runAnimations(int nSeqId, float fTweenDuration)
|
||||||
CCDictElement* pElement1 = NULL;
|
CCDictElement* pElement1 = NULL;
|
||||||
CCDICT_FOREACH(seqNodeProps, pElement1)
|
CCDICT_FOREACH(seqNodeProps, pElement1)
|
||||||
{
|
{
|
||||||
const char *propNmae = pElement1->getStrKey();
|
const char *propName = pElement1->getStrKey();
|
||||||
CCBSequenceProperty *seqProp = (CCBSequenceProperty*)seqNodeProps->objectForKey(propNmae);
|
CCBSequenceProperty *seqProp = (CCBSequenceProperty*)seqNodeProps->objectForKey(propName);
|
||||||
seqNodePropNames.insert(propNmae);
|
seqNodePropNames.insert(propName);
|
||||||
|
|
||||||
setFirstFrame(node, seqProp, fTweenDuration);
|
setFirstFrame(node, seqProp, fTweenDuration);
|
||||||
runAction(node, seqProp, fTweenDuration);
|
runAction(node, seqProp, fTweenDuration);
|
||||||
|
@ -501,13 +501,13 @@ void CCBAnimationManager::runAnimations(int nSeqId, float fTweenDuration)
|
||||||
CCDictElement* pElement2 = NULL;
|
CCDictElement* pElement2 = NULL;
|
||||||
CCDICT_FOREACH(nodeBaseValues, pElement2)
|
CCDICT_FOREACH(nodeBaseValues, pElement2)
|
||||||
{
|
{
|
||||||
if (seqNodePropNames.find(pElement2->getStrKey()) != seqNodePropNames.end())
|
if (seqNodePropNames.find(pElement2->getStrKey()) == seqNodePropNames.end())
|
||||||
{
|
{
|
||||||
CCObject *value = pElement2->getObject();
|
CCObject *value = pElement2->getObject();
|
||||||
|
|
||||||
if (value)
|
if (value)
|
||||||
{
|
{
|
||||||
setAnimatedProperty(pElement2->getStrKey(), node, value, fTweenDuration);
|
setAnimatedProperty(pElement2->getStrKey(), node, value, fTweenDuration);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,6 +64,7 @@ CCBReader::CCBReader(CCNodeLoaderLibrary * pCCNodeLoaderLibrary, CCBMemberVariab
|
||||||
, mCurrentBit(-1)
|
, mCurrentBit(-1)
|
||||||
, mOwner(NULL)
|
, mOwner(NULL)
|
||||||
, mActionManager(NULL)
|
, mActionManager(NULL)
|
||||||
|
, mAnimatedProps(NULL)
|
||||||
{
|
{
|
||||||
this->mCCNodeLoaderLibrary = pCCNodeLoaderLibrary;
|
this->mCCNodeLoaderLibrary = pCCNodeLoaderLibrary;
|
||||||
this->mCCNodeLoaderLibrary->retain();
|
this->mCCNodeLoaderLibrary->retain();
|
||||||
|
@ -79,6 +80,7 @@ CCBReader::CCBReader(CCBReader * pCCBReader)
|
||||||
, mCurrentBit(-1)
|
, mCurrentBit(-1)
|
||||||
, mOwner(NULL)
|
, mOwner(NULL)
|
||||||
, mActionManager(NULL)
|
, mActionManager(NULL)
|
||||||
|
, mAnimatedProps(NULL)
|
||||||
{
|
{
|
||||||
this->mLoadedSpriteSheets = pCCBReader->mLoadedSpriteSheets;
|
this->mLoadedSpriteSheets = pCCBReader->mLoadedSpriteSheets;
|
||||||
this->mCCNodeLoaderLibrary = pCCBReader->mCCNodeLoaderLibrary;
|
this->mCCNodeLoaderLibrary = pCCBReader->mCCNodeLoaderLibrary;
|
||||||
|
@ -100,6 +102,7 @@ CCBReader::CCBReader()
|
||||||
, mCCNodeLoaderListener(NULL)
|
, mCCNodeLoaderListener(NULL)
|
||||||
, mCCBMemberVariableAssigner(NULL)
|
, mCCBMemberVariableAssigner(NULL)
|
||||||
, mCCBSelectorResolver(NULL)
|
, mCCBSelectorResolver(NULL)
|
||||||
|
, mAnimatedProps(NULL)
|
||||||
{}
|
{}
|
||||||
|
|
||||||
CCBReader::~CCBReader() {
|
CCBReader::~CCBReader() {
|
||||||
|
@ -161,7 +164,7 @@ CCBSelectorResolver * CCBReader::getCCBSelectorResolver() {
|
||||||
return this->mCCBSelectorResolver;
|
return this->mCCBSelectorResolver;
|
||||||
}
|
}
|
||||||
|
|
||||||
set<string>& CCBReader::getAnimatedProperties()
|
set<string>* CCBReader::getAnimatedProperties()
|
||||||
{
|
{
|
||||||
return mAnimatedProps;
|
return mAnimatedProps;
|
||||||
}
|
}
|
||||||
|
@ -477,6 +480,7 @@ CCNode * CCBReader::readNodeGraph(CCNode * pParent) {
|
||||||
|
|
||||||
// Read animated properties
|
// Read animated properties
|
||||||
CCDictionary *seqs = CCDictionary::create();
|
CCDictionary *seqs = CCDictionary::create();
|
||||||
|
mAnimatedProps = new set<string>();
|
||||||
|
|
||||||
int numSequence = readInt(false);
|
int numSequence = readInt(false);
|
||||||
for (int i = 0; i < numSequence; ++i)
|
for (int i = 0; i < numSequence; ++i)
|
||||||
|
@ -493,7 +497,7 @@ CCNode * CCBReader::readNodeGraph(CCNode * pParent) {
|
||||||
|
|
||||||
seqProp->setName(readCachedString()->getCString());
|
seqProp->setName(readCachedString()->getCString());
|
||||||
seqProp->setType(readInt(false));
|
seqProp->setType(readInt(false));
|
||||||
mAnimatedProps.insert(seqProp->getName());
|
mAnimatedProps->insert(seqProp->getName());
|
||||||
|
|
||||||
int numKeyframes = readInt(false);
|
int numKeyframes = readInt(false);
|
||||||
|
|
||||||
|
@ -570,6 +574,9 @@ CCNode * CCBReader::readNodeGraph(CCNode * pParent) {
|
||||||
}
|
}
|
||||||
#endif // CCB_ENABLE_JAVASCRIPT
|
#endif // CCB_ENABLE_JAVASCRIPT
|
||||||
|
|
||||||
|
delete mAnimatedProps;
|
||||||
|
mAnimatedProps = NULL;
|
||||||
|
|
||||||
/* Read and add children. */
|
/* Read and add children. */
|
||||||
int numChildren = this->readInt(false);
|
int numChildren = this->readInt(false);
|
||||||
for(int i = 0; i < numChildren; i++) {
|
for(int i = 0; i < numChildren; i++) {
|
||||||
|
|
|
@ -177,7 +177,7 @@ private:
|
||||||
CCObject *mOwner;
|
CCObject *mOwner;
|
||||||
|
|
||||||
CCBAnimationManager *mActionManager;
|
CCBAnimationManager *mActionManager;
|
||||||
std::set<std::string> mAnimatedProps;
|
std::set<std::string> *mAnimatedProps;
|
||||||
|
|
||||||
CCNodeLoaderLibrary *mCCNodeLoaderLibrary;
|
CCNodeLoaderLibrary *mCCNodeLoaderLibrary;
|
||||||
CCNodeLoaderListener *mCCNodeLoaderListener;
|
CCNodeLoaderListener *mCCNodeLoaderListener;
|
||||||
|
@ -214,7 +214,7 @@ public:
|
||||||
void setAnimationManager(CCBAnimationManager *pAnimationManager);
|
void setAnimationManager(CCBAnimationManager *pAnimationManager);
|
||||||
|
|
||||||
// Used in CCNodeLoader::parseProperties()
|
// Used in CCNodeLoader::parseProperties()
|
||||||
std::set<std::string>& getAnimatedProperties();
|
std::set<std::string>* getAnimatedProperties();
|
||||||
std::set<std::string>& getLoadedSpriteSheet();
|
std::set<std::string>& getLoadedSpriteSheet();
|
||||||
CCObject* getOwner();
|
CCObject* getOwner();
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
#include "CCBMemberVariableAssigner.h"
|
#include "CCBMemberVariableAssigner.h"
|
||||||
#include "CCBAnimationManager.h"
|
#include "CCBAnimationManager.h"
|
||||||
#include "CCData.h"
|
#include "CCData.h"
|
||||||
|
#include "CCNode+CCBRelativePositioning.h"
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
|
@ -322,43 +323,10 @@ CCPoint CCNodeLoader::parsePropTypePosition(CCNode * pNode, CCNode * pParent, CC
|
||||||
|
|
||||||
CCSize containerSize = pCCBReader->getAnimationManager()->getContainerSize(pParent);
|
CCSize containerSize = pCCBReader->getAnimationManager()->getContainerSize(pParent);
|
||||||
|
|
||||||
switch (type)
|
CCPoint pt = getAbsolutePosition(ccp(x,y), type, containerSize, pPropertyName);
|
||||||
{
|
pNode->setPosition(getAbsolutePosition(pt, type, containerSize, pPropertyName));;
|
||||||
case kCCBPositionTypeRelativeBottomLeft:
|
|
||||||
{
|
|
||||||
/* Nothing. */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case kCCBPositionTypeRelativeTopLeft:
|
|
||||||
{
|
|
||||||
y = containerSize.height - y;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case kCCBPositionTypeRelativeTopRight:
|
|
||||||
{
|
|
||||||
x = containerSize.width - x;
|
|
||||||
y = containerSize.height - y;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case kCCBPositionTypeRelativeBottomRight:
|
|
||||||
{
|
|
||||||
x = containerSize.width - x;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case kCCBPositionTypePercent:
|
|
||||||
{
|
|
||||||
x = (int)(containerSize.width * x / 100.0f);
|
|
||||||
y = (int)(containerSize.height * y / 100.0f);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case kCCBPositionTypeMultiplyResolution:
|
|
||||||
{
|
|
||||||
x *= CCBReader::getResolutionScale();
|
|
||||||
y *= CCBReader::getResolutionScale();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
CCArray *baseValue = CCArray::create(CCBValue::create(x),
|
CCArray *baseValue = CCArray::create(CCBValue::create(x),
|
||||||
CCBValue::create(y),
|
CCBValue::create(y),
|
||||||
|
@ -367,7 +335,7 @@ CCPoint CCNodeLoader::parsePropTypePosition(CCNode * pNode, CCNode * pParent, CC
|
||||||
pCCBReader->getAnimationManager()->setBaseValue(baseValue, pNode, pPropertyName);
|
pCCBReader->getAnimationManager()->setBaseValue(baseValue, pNode, pPropertyName);
|
||||||
}
|
}
|
||||||
|
|
||||||
return CCPoint(x, y);
|
return pt;
|
||||||
}
|
}
|
||||||
|
|
||||||
CCPoint CCNodeLoader::parsePropTypePoint(CCNode * pNode, CCNode * pParent, CCBReader * pCCBReader)
|
CCPoint CCNodeLoader::parsePropTypePoint(CCNode * pNode, CCNode * pParent, CCBReader * pCCBReader)
|
||||||
|
@ -452,7 +420,7 @@ float * CCNodeLoader::parsePropTypeScaleLock(CCNode * pNode, CCNode * pParent, C
|
||||||
scaleLock[0] = x;
|
scaleLock[0] = x;
|
||||||
scaleLock[1] = y;
|
scaleLock[1] = y;
|
||||||
|
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
CCArray *baseValue = CCArray::create(CCBValue::create(x),
|
CCArray *baseValue = CCArray::create(CCBValue::create(x),
|
||||||
CCBValue::create(y),
|
CCBValue::create(y),
|
||||||
|
@ -470,7 +438,7 @@ float CCNodeLoader::parsePropTypeFloat(CCNode * pNode, CCNode * pParent, CCBRead
|
||||||
|
|
||||||
float CCNodeLoader::parsePropTypeDegrees(CCNode * pNode, CCNode * pParent, CCBReader * pCCBReader, const char *pPropertyName) {
|
float CCNodeLoader::parsePropTypeDegrees(CCNode * pNode, CCNode * pParent, CCBReader * pCCBReader, const char *pPropertyName) {
|
||||||
float ret = pCCBReader->readFloat();
|
float ret = pCCBReader->readFloat();
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
CCBValue *value = CCBValue::create(ret);
|
CCBValue *value = CCBValue::create(ret);
|
||||||
pCCBReader->getAnimationManager()->setBaseValue(value, pNode, pPropertyName);
|
pCCBReader->getAnimationManager()->setBaseValue(value, pNode, pPropertyName);
|
||||||
|
@ -519,7 +487,7 @@ bool CCNodeLoader::parsePropTypeCheck(CCNode * pNode, CCNode * pParent, CCBReade
|
||||||
{
|
{
|
||||||
bool ret = pCCBReader->readBool();
|
bool ret = pCCBReader->readBool();
|
||||||
|
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
CCBValue *value = CCBValue::create(ret);
|
CCBValue *value = CCBValue::create(ret);
|
||||||
pCCBReader->getAnimationManager()->setBaseValue(value, pNode, pPropertyName);
|
pCCBReader->getAnimationManager()->setBaseValue(value, pNode, pPropertyName);
|
||||||
|
@ -557,7 +525,7 @@ CCSpriteFrame * CCNodeLoader::parsePropTypeSpriteFrame(CCNode * pNode, CCNode *
|
||||||
spriteFrame = frameCache->spriteFrameByName(spriteFile->getCString());
|
spriteFrame = frameCache->spriteFrameByName(spriteFile->getCString());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
pCCBReader->getAnimationManager()->setBaseValue(spriteFrame, pNode, pPropertyName);
|
pCCBReader->getAnimationManager()->setBaseValue(spriteFrame, pNode, pPropertyName);
|
||||||
}
|
}
|
||||||
|
@ -607,7 +575,7 @@ unsigned char CCNodeLoader::parsePropTypeByte(CCNode * pNode, CCNode * pParent,
|
||||||
{
|
{
|
||||||
unsigned char ret = pCCBReader->readByte();
|
unsigned char ret = pCCBReader->readByte();
|
||||||
|
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
pCCBReader->getAnimationManager()->setBaseValue(CCBValue::create(ret), pNode, pPropertyName);
|
pCCBReader->getAnimationManager()->setBaseValue(CCBValue::create(ret), pNode, pPropertyName);
|
||||||
}
|
}
|
||||||
|
@ -621,7 +589,7 @@ ccColor3B CCNodeLoader::parsePropTypeColor3(CCNode * pNode, CCNode * pParent, CC
|
||||||
unsigned char blue = pCCBReader->readByte();
|
unsigned char blue = pCCBReader->readByte();
|
||||||
|
|
||||||
ccColor3B color = { red, green, blue };
|
ccColor3B color = { red, green, blue };
|
||||||
if (pCCBReader->getAnimatedProperties().find(pPropertyName) != pCCBReader->getAnimatedProperties().end())
|
if (pCCBReader->getAnimatedProperties()->find(pPropertyName) != pCCBReader->getAnimatedProperties()->end())
|
||||||
{
|
{
|
||||||
ccColor3BWapper *value = ccColor3BWapper::create(color);
|
ccColor3BWapper *value = ccColor3BWapper::create(color);
|
||||||
pCCBReader->getAnimationManager()->setBaseValue(value, pNode, pPropertyName);
|
pCCBReader->getAnimationManager()->setBaseValue(value, pNode, pPropertyName);
|
||||||
|
|
Loading…
Reference in New Issue