Merge pull request #340 from natural-law/master

fixed #552
This commit is contained in:
minggo 2011-07-01 00:13:22 -07:00
commit d59c71330c
9 changed files with 104 additions and 60 deletions

View File

@ -1,6 +1,7 @@
/**************************************************************************** /****************************************************************************
Copyright (c) 2010-2011 cocos2d-x.org Copyright (c) 2010-2011 cocos2d-x.org
Copyright (c) 2008-2010 Ricardo Quesada Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011 Zynga Inc.
http://www.cocos2d-x.org http://www.cocos2d-x.org
@ -132,8 +133,8 @@ All features from CCLayer are valid, plus the following new features:
class CC_DLL CCLayerColor : public CCLayer , public CCRGBAProtocol, public CCBlendProtocol class CC_DLL CCLayerColor : public CCLayer , public CCRGBAProtocol, public CCBlendProtocol
{ {
protected: protected:
GLfloat m_pSquareVertices[4 * 2]; ccVertex2F m_pSquareVertices[4];
GLubyte m_pSquareColors[4 * 4]; ccColor4B m_pSquareColors[4];
public: public:
@ -195,16 +196,18 @@ the background.
All features from CCLayerColor are valid, plus the following new features: All features from CCLayerColor are valid, plus the following new features:
- direction - direction
- final color - final color
- interpolation mode
Color is interpolated between the startColor and endColor along the given Color is interpolated between the startColor and endColor along the given
vector (starting at the origin, ending at the terminus). If no vector is vector (starting at the origin, ending at the terminus). If no vector is
supplied, it defaults to (0, -1) -- a fade from top to bottom. supplied, it defaults to (0, -1) -- a fade from top to bottom.
Given the nature of If 'compressedInterpolation' is disabled, you will not see either the start or end color for
the interpolation, you will not see either the start or end color for
non-cardinal vectors; a smooth gradient implying both end points will be still non-cardinal vectors; a smooth gradient implying both end points will be still
be drawn, however. be drawn, however.
If ' compressedInterpolation' is enabled (default mode) you will see both the start and end colors of the gradient.
@since v0.99.5 @since v0.99.5
*/ */
class CC_DLL CCLayerGradient : public CCLayerColor class CC_DLL CCLayerGradient : public CCLayerColor
@ -222,14 +225,17 @@ public:
/** Initializes the CCLayer with a gradient between start and end in the direction of v. */ /** Initializes the CCLayer with a gradient between start and end in the direction of v. */
virtual bool initWithColor(ccColor4B start, ccColor4B end, CCPoint v); virtual bool initWithColor(ccColor4B start, ccColor4B end, CCPoint v);
ccColor3B getStartColor(); CC_PROPERTY(ccColor3B, m_startColor, StartColor)
void setStartColor(ccColor3B colors);
CC_PROPERTY(ccColor3B, m_endColor, EndColor) CC_PROPERTY(ccColor3B, m_endColor, EndColor)
CC_PROPERTY(GLubyte, m_cStartOpacity, StartOpacity) CC_PROPERTY(GLubyte, m_cStartOpacity, StartOpacity)
CC_PROPERTY(GLubyte, m_cEndOpacity, EndOpacity) CC_PROPERTY(GLubyte, m_cEndOpacity, EndOpacity)
CC_PROPERTY(CCPoint, m_AlongVector, Vector) CC_PROPERTY(CCPoint, m_AlongVector, Vector)
/** Whether or not the interpolation will be compressed in order to display all the colors of the gradient both in canonical and non canonical vectors
Default: YES
*/
CC_PROPERTY(bool, m_bCompressedInterpolation, IsCompressedInterpolation)
LAYER_NODE_FUNC(CCLayerGradient); LAYER_NODE_FUNC(CCLayerGradient);
protected: protected:
virtual void updateColor(); virtual void updateColor();
@ -240,24 +246,24 @@ Features:
- It supports one or more children - It supports one or more children
- Only one children will be active a time - Only one children will be active a time
*/ */
class CC_DLL CCMultiplexLayer : public CCLayer class CC_DLL CCLayerMultiplex : public CCLayer
{ {
protected: protected:
unsigned int m_nEnabledLayer; unsigned int m_nEnabledLayer;
CCMutableArray<CCLayer *> * m_pLayers; CCMutableArray<CCLayer *> * m_pLayers;
public: public:
CCMultiplexLayer(); CCLayerMultiplex();
virtual ~CCMultiplexLayer(); virtual ~CCLayerMultiplex();
/** creates a CCMultiplexLayer with one or more layers using a variable argument list. */ /** creates a CCLayerMultiplex with one or more layers using a variable argument list. */
static CCMultiplexLayer * layerWithLayers(CCLayer* layer, ... ); static CCLayerMultiplex * layerWithLayers(CCLayer* layer, ... );
/** /**
* lua script can not init with undetermined number of variables * lua script can not init with undetermined number of variables
* so add these functinons to be used with lua. * so add these functinons to be used with lua.
*/ */
static CCMultiplexLayer * layerWithLayer(CCLayer* layer); static CCLayerMultiplex * layerWithLayer(CCLayer* layer);
void addLayer(CCLayer* layer); void addLayer(CCLayer* layer);
bool initWithLayer(CCLayer* layer); bool initWithLayer(CCLayer* layer);
@ -272,7 +278,16 @@ public:
*/ */
void switchToAndReleaseMe(unsigned int n); void switchToAndReleaseMe(unsigned int n);
LAYER_NODE_FUNC(CCMultiplexLayer); LAYER_NODE_FUNC(CCLayerMultiplex);
};
/** CCMultiplexLayer
It is the same as CCLayerMultiplex.
@deprecated Use CCLayerMultiplex instead. This class will be removed in v1.0.1
*/
class CCMultiplexLayer : public CCLayerMultiplex
{
}; };
}//namespace cocos2d }//namespace cocos2d

View File

@ -1,6 +1,7 @@
/**************************************************************************** /****************************************************************************
Copyright (c) 2010-2011 cocos2d-x.org Copyright (c) 2010-2011 cocos2d-x.org
Copyright (c) 2008-2010 Ricardo Quesada Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011 Zynga Inc.
http://www.cocos2d-x.org http://www.cocos2d-x.org

View File

@ -1,6 +1,7 @@
/**************************************************************************** /****************************************************************************
Copyright (c) 2010-2011 cocos2d-x.org Copyright (c) 2010-2011 cocos2d-x.org
Copyright (c) 2008-2010 Ricardo Quesada Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011 Zynga Inc.
http://www.cocos2d-x.org http://www.cocos2d-x.org

View File

@ -1,6 +1,7 @@
/**************************************************************************** /****************************************************************************
Copyright (c) 2010-2011 cocos2d-x.org Copyright (c) 2010-2011 cocos2d-x.org
Copyright (c) 2008-2010 Ricardo Quesada Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011 Zynga Inc.
http://www.cocos2d-x.org http://www.cocos2d-x.org
@ -55,6 +56,8 @@ bool CCLayer::init()
CCDirector * pDirector; CCDirector * pDirector;
CC_BREAK_IF(!(pDirector = CCDirector::sharedDirector())); CC_BREAK_IF(!(pDirector = CCDirector::sharedDirector()));
this->setContentSize(pDirector->getWinSize()); this->setContentSize(pDirector->getWinSize());
m_bIsTouchEnabled = false;
m_bIsAccelerometerEnabled = false;
// success // success
bRet = true; bRet = true;
} while(0); } while(0);
@ -375,7 +378,8 @@ bool CCLayerColor::initWithColorWidthHeight(ccColor4B color, GLfloat width, GLfl
for (unsigned int i=0; i<sizeof(m_pSquareVertices) / sizeof(m_pSquareVertices[0]); i++ ) for (unsigned int i=0; i<sizeof(m_pSquareVertices) / sizeof(m_pSquareVertices[0]); i++ )
{ {
m_pSquareVertices[i] = 0.0f; m_pSquareVertices[i].x = 0.0f;
m_pSquareVertices[i].y = 0.0f;
} }
this->updateColor(); this->updateColor();
@ -393,10 +397,10 @@ bool CCLayerColor::initWithColor(ccColor4B color)
/// override contentSize /// override contentSize
void CCLayerColor::setContentSize(CCSize size) void CCLayerColor::setContentSize(CCSize size)
{ {
m_pSquareVertices[2] = size.width * CC_CONTENT_SCALE_FACTOR(); m_pSquareVertices[1].x = size.width * CC_CONTENT_SCALE_FACTOR();
m_pSquareVertices[5] = size.height * CC_CONTENT_SCALE_FACTOR(); m_pSquareVertices[2].y = size.height * CC_CONTENT_SCALE_FACTOR();
m_pSquareVertices[6] = size.width * CC_CONTENT_SCALE_FACTOR(); m_pSquareVertices[3].x = size.width * CC_CONTENT_SCALE_FACTOR();
m_pSquareVertices[7] = size.height * CC_CONTENT_SCALE_FACTOR(); m_pSquareVertices[3].y = size.height * CC_CONTENT_SCALE_FACTOR();
CCLayer::setContentSize(size); CCLayer::setContentSize(size);
} }
@ -420,10 +424,10 @@ void CCLayerColor::updateColor()
{ {
for( unsigned int i=0; i < 4; i++ ) for( unsigned int i=0; i < 4; i++ )
{ {
m_pSquareColors[i * 4] = m_tColor.r; m_pSquareColors[i].r = m_tColor.r;
m_pSquareColors[i * 4 + 1] = m_tColor.g; m_pSquareColors[i].g = m_tColor.g;
m_pSquareColors[i * 4 + 2] = m_tColor.b; m_pSquareColors[i].b = m_tColor.b;
m_pSquareColors[i * 4 + 3] = m_cOpacity; m_pSquareColors[i].a = m_cOpacity;
} }
} }
@ -501,6 +505,8 @@ bool CCLayerGradient::initWithColor(ccColor4B start, ccColor4B end, CCPoint v)
m_AlongVector = v; m_AlongVector = v;
start.a = 255; start.a = 255;
m_bCompressedInterpolation = true;
return CCLayerColor::initWithColor(start); return CCLayerColor::initWithColor(start);
} }
@ -508,13 +514,20 @@ void CCLayerGradient::updateColor()
{ {
CCLayerColor::updateColor(); CCLayerColor::updateColor();
float h = sqrtf(m_AlongVector.x * m_AlongVector.x + m_AlongVector.y * m_AlongVector.y); float h = ccpLength(m_AlongVector);
if (h == 0) if (h == 0)
return; return;
double c = sqrt(2.0); double c = sqrt(2.0);
CCPoint u = ccp(m_AlongVector.x / h, m_AlongVector.y / h); CCPoint u = ccp(m_AlongVector.x / h, m_AlongVector.y / h);
// Compressed Interpolation mode
if (m_bCompressedInterpolation)
{
float h2 = 1 / ( fabsf(u.x) + fabsf(u.y) );
u = ccpMult(u, h2 * (float)c);
}
float opacityf = (float)m_cOpacity / 255.0f; float opacityf = (float)m_cOpacity / 255.0f;
ccColor4B S = { ccColor4B S = {
@ -532,25 +545,25 @@ void CCLayerGradient::updateColor()
}; };
// (-1, -1) // (-1, -1)
m_pSquareColors[0] = (GLubyte) (E.r + (S.r - E.r) * ((c + u.x + u.y) / (2.0f * c))); m_pSquareColors[0].r = (GLubyte) (E.r + (S.r - E.r) * ((c + u.x + u.y) / (2.0f * c)));
m_pSquareColors[1] = (GLubyte) (E.g + (S.g - E.g) * ((c + u.x + u.y) / (2.0f * c))); m_pSquareColors[0].g = (GLubyte) (E.g + (S.g - E.g) * ((c + u.x + u.y) / (2.0f * c)));
m_pSquareColors[2] = (GLubyte) (E.b + (S.b - E.b) * ((c + u.x + u.y) / (2.0f * c))); m_pSquareColors[0].b = (GLubyte) (E.b + (S.b - E.b) * ((c + u.x + u.y) / (2.0f * c)));
m_pSquareColors[3] = (GLubyte) (E.a + (S.a - E.a) * ((c + u.x + u.y) / (2.0f * c))); m_pSquareColors[0].a = (GLubyte) (E.a + (S.a - E.a) * ((c + u.x + u.y) / (2.0f * c)));
// (1, -1) // (1, -1)
m_pSquareColors[4] = (GLubyte) (E.r + (S.r - E.r) * ((c - u.x + u.y) / (2.0f * c))); m_pSquareColors[1].r = (GLubyte) (E.r + (S.r - E.r) * ((c - u.x + u.y) / (2.0f * c)));
m_pSquareColors[5] = (GLubyte) (E.g + (S.g - E.g) * ((c - u.x + u.y) / (2.0f * c))); m_pSquareColors[1].g = (GLubyte) (E.g + (S.g - E.g) * ((c - u.x + u.y) / (2.0f * c)));
m_pSquareColors[6] = (GLubyte) (E.b + (S.b - E.b) * ((c - u.x + u.y) / (2.0f * c))); m_pSquareColors[1].b = (GLubyte) (E.b + (S.b - E.b) * ((c - u.x + u.y) / (2.0f * c)));
m_pSquareColors[7] = (GLubyte) (E.a + (S.a - E.a) * ((c - u.x + u.y) / (2.0f * c))); m_pSquareColors[1].a = (GLubyte) (E.a + (S.a - E.a) * ((c - u.x + u.y) / (2.0f * c)));
// (-1, 1) // (-1, 1)
m_pSquareColors[8] = (GLubyte) (E.r + (S.r - E.r) * ((c + u.x - u.y) / (2.0f * c))); m_pSquareColors[2].r = (GLubyte) (E.r + (S.r - E.r) * ((c + u.x - u.y) / (2.0f * c)));
m_pSquareColors[9] = (GLubyte) (E.g + (S.g - E.g) * ((c + u.x - u.y) / (2.0f * c))); m_pSquareColors[2].g = (GLubyte) (E.g + (S.g - E.g) * ((c + u.x - u.y) / (2.0f * c)));
m_pSquareColors[10] = (GLubyte) (E.b + (S.b - E.b) * ((c + u.x - u.y) / (2.0f * c))); m_pSquareColors[2].b = (GLubyte) (E.b + (S.b - E.b) * ((c + u.x - u.y) / (2.0f * c)));
m_pSquareColors[11] = (GLubyte) (E.a + (S.a - E.a) * ((c + u.x - u.y) / (2.0f * c))); m_pSquareColors[2].a = (GLubyte) (E.a + (S.a - E.a) * ((c + u.x - u.y) / (2.0f * c)));
// (1, 1) // (1, 1)
m_pSquareColors[12] = (GLubyte) (E.r + (S.r - E.r) * ((c - u.x - u.y) / (2.0f * c))); m_pSquareColors[3].r = (GLubyte) (E.r + (S.r - E.r) * ((c - u.x - u.y) / (2.0f * c)));
m_pSquareColors[13] = (GLubyte) (E.g + (S.g - E.g) * ((c - u.x - u.y) / (2.0f * c))); m_pSquareColors[3].g = (GLubyte) (E.g + (S.g - E.g) * ((c - u.x - u.y) / (2.0f * c)));
m_pSquareColors[14] = (GLubyte) (E.b + (S.b - E.b) * ((c - u.x - u.y) / (2.0f * c))); m_pSquareColors[3].b = (GLubyte) (E.b + (S.b - E.b) * ((c - u.x - u.y) / (2.0f * c)));
m_pSquareColors[15] = (GLubyte) (E.a + (S.a - E.a) * ((c - u.x - u.y) / (2.0f * c))); m_pSquareColors[3].a = (GLubyte) (E.a + (S.a - E.a) * ((c - u.x - u.y) / (2.0f * c)));
} }
ccColor3B CCLayerGradient::getStartColor() ccColor3B CCLayerGradient::getStartColor()
@ -607,24 +620,35 @@ CCPoint CCLayerGradient::getVector()
return m_AlongVector; return m_AlongVector;
} }
bool CCLayerGradient::getIsCompressedInterpolation()
{
return m_bCompressedInterpolation;
}
void CCLayerGradient::setIsCompressedInterpolation(bool compress)
{
m_bCompressedInterpolation = compress;
updateColor();
}
/// MultiplexLayer /// MultiplexLayer
CCMultiplexLayer::CCMultiplexLayer() CCLayerMultiplex::CCLayerMultiplex()
: m_nEnabledLayer(0) : m_nEnabledLayer(0)
, m_pLayers(NULL) , m_pLayers(NULL)
{ {
} }
CCMultiplexLayer::~CCMultiplexLayer() CCLayerMultiplex::~CCLayerMultiplex()
{ {
CC_SAFE_RELEASE(m_pLayers); CC_SAFE_RELEASE(m_pLayers);
} }
CCMultiplexLayer * CCMultiplexLayer::layerWithLayers(CCLayer * layer, ...) CCLayerMultiplex * CCLayerMultiplex::layerWithLayers(CCLayer * layer, ...)
{ {
va_list args; va_list args;
va_start(args,layer); va_start(args,layer);
CCMultiplexLayer * pMultiplexLayer = new CCMultiplexLayer(); CCLayerMultiplex * pMultiplexLayer = new CCLayerMultiplex();
if(pMultiplexLayer && pMultiplexLayer->initWithLayers(layer, args)) if(pMultiplexLayer && pMultiplexLayer->initWithLayers(layer, args))
{ {
pMultiplexLayer->autorelease(); pMultiplexLayer->autorelease();
@ -636,20 +660,20 @@ CCMultiplexLayer * CCMultiplexLayer::layerWithLayers(CCLayer * layer, ...)
return NULL; return NULL;
} }
CCMultiplexLayer * CCMultiplexLayer::layerWithLayer(CCLayer* layer) CCLayerMultiplex * CCLayerMultiplex::layerWithLayer(CCLayer* layer)
{ {
CCMultiplexLayer * pMultiplexLayer = new CCMultiplexLayer(); CCLayerMultiplex * pMultiplexLayer = new CCLayerMultiplex();
pMultiplexLayer->initWithLayer(layer); pMultiplexLayer->initWithLayer(layer);
pMultiplexLayer->autorelease(); pMultiplexLayer->autorelease();
return pMultiplexLayer; return pMultiplexLayer;
} }
void CCMultiplexLayer::addLayer(CCLayer* layer) void CCLayerMultiplex::addLayer(CCLayer* layer)
{ {
assert(m_pLayers); assert(m_pLayers);
m_pLayers->addObject(layer); m_pLayers->addObject(layer);
} }
bool CCMultiplexLayer::initWithLayer(CCLayer* layer) bool CCLayerMultiplex::initWithLayer(CCLayer* layer)
{ {
m_pLayers = new CCMutableArray<CCLayer*>(1); m_pLayers = new CCMutableArray<CCLayer*>(1);
m_pLayers->addObject(layer); m_pLayers->addObject(layer);
@ -658,7 +682,7 @@ bool CCMultiplexLayer::initWithLayer(CCLayer* layer)
return true; return true;
} }
bool CCMultiplexLayer::initWithLayers(CCLayer *layer, va_list params) bool CCLayerMultiplex::initWithLayers(CCLayer *layer, va_list params)
{ {
m_pLayers = new CCMutableArray<CCLayer*>(5); m_pLayers = new CCMutableArray<CCLayer*>(5);
//m_pLayers->retain(); //m_pLayers->retain();
@ -678,7 +702,7 @@ bool CCMultiplexLayer::initWithLayers(CCLayer *layer, va_list params)
} }
void CCMultiplexLayer::switchTo(unsigned int n) void CCLayerMultiplex::switchTo(unsigned int n)
{ {
CCAssert( n < m_pLayers->count(), "Invalid index in MultiplexLayer switchTo message" ); CCAssert( n < m_pLayers->count(), "Invalid index in MultiplexLayer switchTo message" );
@ -689,7 +713,7 @@ void CCMultiplexLayer::switchTo(unsigned int n)
this->addChild(m_pLayers->getObjectAtIndex(n)); this->addChild(m_pLayers->getObjectAtIndex(n));
} }
void CCMultiplexLayer::switchToAndReleaseMe(unsigned int n) void CCLayerMultiplex::switchToAndReleaseMe(unsigned int n)
{ {
CCAssert( n < m_pLayers->count(), "Invalid index in MultiplexLayer switchTo message" ); CCAssert( n < m_pLayers->count(), "Invalid index in MultiplexLayer switchTo message" );

View File

@ -1,6 +1,7 @@
/**************************************************************************** /****************************************************************************
Copyright (c) 2010-2011 cocos2d-x.org Copyright (c) 2010-2011 cocos2d-x.org
Copyright (c) 2008-2010 Ricardo Quesada Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011 Zynga Inc.
http://www.cocos2d-x.org http://www.cocos2d-x.org

View File

@ -1,6 +1,7 @@
/**************************************************************************** /****************************************************************************
Copyright (c) 2010-2011 cocos2d-x.org Copyright (c) 2010-2011 cocos2d-x.org
Copyright (c) 2008-2010 Ricardo Quesada Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011 Zynga Inc.
http://www.cocos2d-x.org http://www.cocos2d-x.org

View File

@ -431,7 +431,8 @@ void CCTextureCache::removeTextureForKey(const char *textureKeyName)
return; return;
} }
m_pTextures->removeObjectForKey(string(textureKeyName)); string fullPath = CCFileUtils::fullPathFromRelativePath(textureKeyName);
m_pTextures->removeObjectForKey(fullPath);
} }
CCTexture2D* CCTextureCache::textureForKey(const char* key) CCTexture2D* CCTextureCache::textureForKey(const char* key)

View File

@ -1 +1 @@
38bc28fc563959965a8c07d2e075ee119d679548 a82799555bac412b3b88dbdf222f8be8b39badb8

View File

@ -112,12 +112,12 @@ MenuLayer1::~MenuLayer1()
void MenuLayer1::menuCallback(CCObject* sender) void MenuLayer1::menuCallback(CCObject* sender)
{ {
((CCMultiplexLayer*)m_pParent)->switchTo(1); ((CCLayerMultiplex*)m_pParent)->switchTo(1);
} }
void MenuLayer1::menuCallbackConfig(CCObject* sender) void MenuLayer1::menuCallbackConfig(CCObject* sender)
{ {
((CCMultiplexLayer*)m_pParent)->switchTo(3); ((CCLayerMultiplex*)m_pParent)->switchTo(3);
} }
void MenuLayer1::menuCallbackDisabled(CCObject* sender) void MenuLayer1::menuCallbackDisabled(CCObject* sender)
@ -131,7 +131,7 @@ void MenuLayer1::menuCallbackEnable(CCObject* sender)
void MenuLayer1::menuCallback2(CCObject* sender) void MenuLayer1::menuCallback2(CCObject* sender)
{ {
((CCMultiplexLayer*)m_pParent)->switchTo(2); ((CCLayerMultiplex*)m_pParent)->switchTo(2);
} }
void MenuLayer1::onQuit(CCObject* sender) void MenuLayer1::onQuit(CCObject* sender)
@ -223,7 +223,7 @@ void MenuLayer2::alignMenusV()
void MenuLayer2::menuCallback(CCObject* sender) void MenuLayer2::menuCallback(CCObject* sender)
{ {
((CCMultiplexLayer*)m_pParent)->switchTo(0); ((CCLayerMultiplex*)m_pParent)->switchTo(0);
} }
void MenuLayer2::menuCallbackOpacity(CCObject* sender) void MenuLayer2::menuCallbackOpacity(CCObject* sender)
@ -301,7 +301,7 @@ MenuLayer3::~MenuLayer3()
void MenuLayer3::menuCallback(CCObject* sender) void MenuLayer3::menuCallback(CCObject* sender)
{ {
((CCMultiplexLayer*)m_pParent)->switchTo(0); ((CCLayerMultiplex*)m_pParent)->switchTo(0);
} }
void MenuLayer3::menuCallback2(CCObject* sender) void MenuLayer3::menuCallback2(CCObject* sender)
@ -412,7 +412,7 @@ void MenuLayer4::menuCallback(CCObject* sender)
void MenuLayer4::backCallback(CCObject* sender) void MenuLayer4::backCallback(CCObject* sender)
{ {
((CCMultiplexLayer*)m_pParent)->switchTo(0); ((CCLayerMultiplex*)m_pParent)->switchTo(0);
} }
void MenuTestScene::runThisTest() void MenuTestScene::runThisTest()
@ -422,7 +422,7 @@ void MenuTestScene::runThisTest()
CCLayer* pLayer3 = new MenuLayer3(); CCLayer* pLayer3 = new MenuLayer3();
CCLayer* pLayer4 = new MenuLayer4(); CCLayer* pLayer4 = new MenuLayer4();
CCMultiplexLayer* layer = CCMultiplexLayer::layerWithLayers(pLayer1, pLayer2, pLayer3, pLayer4, NULL); CCLayerMultiplex* layer = CCLayerMultiplex::layerWithLayers(pLayer1, pLayer2, pLayer3, pLayer4, NULL);
addChild(layer, 0); addChild(layer, 0);
pLayer1->release(); pLayer1->release();