mirror of https://github.com/axmolengine/axmol.git
commit
d59c71330c
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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" );
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
38bc28fc563959965a8c07d2e075ee119d679548
|
a82799555bac412b3b88dbdf222f8be8b39badb8
|
|
@ -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();
|
||||||
|
|
Loading…
Reference in New Issue