issue #1555:fix a bug about CCGLProgram

This commit is contained in:
minggo 2012-11-13 11:06:32 +08:00
parent 6661f2c88d
commit 5fd56370d8
31 changed files with 756 additions and 354 deletions

View File

@ -390,7 +390,10 @@ void CCDirector::setProjection(ccDirectorProjection kProjection)
void CCDirector::purgeCachedData(void) void CCDirector::purgeCachedData(void)
{ {
CCLabelBMFont::purgeCachedData(); CCLabelBMFont::purgeCachedData();
if (s_SharedDirector->getOpenGLView())
{
CCTextureCache::sharedTextureCache()->removeUnusedTextures(); CCTextureCache::sharedTextureCache()->removeUnusedTextures();
}
CCFileUtils::sharedFileUtils()->purgeCachedEntries(); CCFileUtils::sharedFileUtils()->purgeCachedEntries();
} }
@ -407,7 +410,7 @@ void CCDirector::setAlphaBlending(bool bOn)
} }
else else
{ {
glDisable(GL_BLEND); ccGLBlendFunc(GL_ONE, GL_ZERO);
} }
CHECK_GL_ERROR_DEBUG(); CHECK_GL_ERROR_DEBUG();
@ -429,20 +432,50 @@ void CCDirector::setDepthTest(bool bOn)
CHECK_GL_ERROR_DEBUG(); CHECK_GL_ERROR_DEBUG();
} }
static void
GLToClipTransform(kmMat4 *transformOut)
{
kmMat4 projection;
kmGLGetMatrix(KM_GL_PROJECTION, &projection);
kmMat4 modelview;
kmGLGetMatrix(KM_GL_MODELVIEW, &modelview);
kmMat4Multiply(transformOut, &projection, &modelview);
}
CCPoint CCDirector::convertToGL(const CCPoint& uiPoint) CCPoint CCDirector::convertToGL(const CCPoint& uiPoint)
{ {
CCSize s = m_obWinSizeInPoints; kmMat4 transform;
float newY = s.height - uiPoint.y; GLToClipTransform(&transform);
return ccp(uiPoint.x, newY); kmMat4 transformInv;
kmMat4Inverse(&transformInv, &transform);
// Calculate z=0 using -> transform*[0, 0, 0, 1]/w
kmScalar zClip = transform.mat[14]/transform.mat[15];
CCSize glSize = m_pobOpenGLView->getFrameSize();
kmVec3 clipCoord = {2.0*uiPoint.x/glSize.width - 1.0, 1.0 - 2.0*uiPoint.y/glSize.height, zClip};
kmVec3 glCoord;
kmVec3TransformCoord(&glCoord, &clipCoord, &transformInv);
return ccp(glCoord.x, glCoord.y);
} }
CCPoint CCDirector::convertToUI(const CCPoint& glPoint) CCPoint CCDirector::convertToUI(const CCPoint& glPoint)
{ {
CCSize winSize = m_obWinSizeInPoints; kmMat4 transform;
float oppositeY = winSize.height - glPoint.y; GLToClipTransform(&transform);
return ccp(glPoint.x, oppositeY); kmVec3 clipCoord;
// Need to calculate the zero depth from the transform.
kmVec3 glCoord = {glPoint.x, glPoint.y, 0.0};
kmVec3TransformCoord(&clipCoord, &glCoord, &transform);
CCSize glSize = m_pobOpenGLView->getFrameSize();
return ccp(glSize.width*(clipCoord.x*0.5 + 0.5), glSize.height*(-clipCoord.y*0.5 + 0.5));
} }
CCSize CCDirector::getWinSize(void) CCSize CCDirector::getWinSize(void)
@ -483,7 +516,7 @@ CCPoint CCDirector::getVisibleOrigin()
void CCDirector::runWithScene(CCScene *pScene) void CCDirector::runWithScene(CCScene *pScene)
{ {
CCAssert(pScene != NULL, "running scene should not be null"); CCAssert(pScene != NULL, "This command can only be used to start the CCDirector. There is already a scene present.");
CCAssert(m_pRunningScene == NULL, "m_pRunningScene should be null"); CCAssert(m_pRunningScene == NULL, "m_pRunningScene should be null");
pushScene(pScene); pushScene(pScene);
@ -492,6 +525,7 @@ void CCDirector::runWithScene(CCScene *pScene)
void CCDirector::replaceScene(CCScene *pScene) void CCDirector::replaceScene(CCScene *pScene)
{ {
CCAssert(m_pRunningScene, "Use runWithScene: instead to start the director");
CCAssert(pScene != NULL, "the scene should not be null"); CCAssert(pScene != NULL, "the scene should not be null");
unsigned int index = m_pobScenesStack->count(); unsigned int index = m_pobScenesStack->count();
@ -547,6 +581,7 @@ void CCDirector::popToRootScene(void)
CCScene *current = (CCScene*)m_pobScenesStack->lastObject(); CCScene *current = (CCScene*)m_pobScenesStack->lastObject();
if( current->isRunning() ) if( current->isRunning() )
{ {
current->onExitTransitionDidStart();
current->onExit(); current->onExit();
} }
current->cleanup(); current->cleanup();
@ -575,6 +610,7 @@ void CCDirector::purgeDirector()
if (m_pRunningScene) if (m_pRunningScene)
{ {
m_pRunningScene->onExitTransitionDidStart();
m_pRunningScene->onExit(); m_pRunningScene->onExit();
m_pRunningScene->cleanup(); m_pRunningScene->cleanup();
m_pRunningScene->release(); m_pRunningScene->release();
@ -593,9 +629,6 @@ void CCDirector::purgeDirector()
CC_SAFE_RELEASE_NULL(m_pSPFLabel); CC_SAFE_RELEASE_NULL(m_pSPFLabel);
CC_SAFE_RELEASE_NULL(m_pDrawsLabel); CC_SAFE_RELEASE_NULL(m_pDrawsLabel);
CCObject* pProjectionDelegate = (CCObject*)m_pProjectionDelegate;
CC_SAFE_RELEASE_NULL(pProjectionDelegate);
// purge bitmap cache // purge bitmap cache
CCLabelBMFont::purgeCachedData(); CCLabelBMFont::purgeCachedData();
@ -633,6 +666,7 @@ void CCDirector::setNextScene(void)
{ {
if (m_pRunningScene) if (m_pRunningScene)
{ {
m_pRunningScene->onExitTransitionDidStart();
m_pRunningScene->onExit(); m_pRunningScene->onExit();
} }
@ -739,26 +773,13 @@ void CCDirector::createStatsLabel()
{ {
if( m_pFPSLabel && m_pSPFLabel ) if( m_pFPSLabel && m_pSPFLabel )
{ {
//CCTexture2D *texture = m_pFPSLabel->getTexture();
CC_SAFE_RELEASE_NULL(m_pFPSLabel); CC_SAFE_RELEASE_NULL(m_pFPSLabel);
CC_SAFE_RELEASE_NULL(m_pSPFLabel); CC_SAFE_RELEASE_NULL(m_pSPFLabel);
CC_SAFE_RELEASE_NULL(m_pDrawsLabel); CC_SAFE_RELEASE_NULL(m_pDrawsLabel);
// CCTextureCache::sharedTextureCache()->removeTexture(texture);
CCFileUtils::sharedFileUtils()->purgeCachedEntries(); CCFileUtils::sharedFileUtils()->purgeCachedEntries();
} }
/*
CCTexture2DPixelFormat currentFormat = CCTexture2D::defaultAlphaPixelFormat();
CCTexture2D::setDefaultAlphaPixelFormat(kCCTexture2DPixelFormat_RGBA4444);
m_pFPSLabel = new CCLabelAtlas();
m_pFPSLabel->initWithString("00.0", "fps_images.png", 12, 32, '.');
m_pSPFLabel = new CCLabelAtlas();
m_pSPFLabel->initWithString("0.000", "fps_images.png", 12, 32, '.');
m_pDrawsLabel = new CCLabelAtlas();
m_pDrawsLabel->initWithString("000", "fps_images.png", 12, 32, '.');
*/
int fontSize = 0; int fontSize = 0;
if (m_obWinSizeInPoints.width > m_obWinSizeInPoints.height) if (m_obWinSizeInPoints.width > m_obWinSizeInPoints.height)
{ {
@ -776,9 +797,6 @@ void CCDirector::createStatsLabel()
m_pDrawsLabel = CCLabelTTF::create("000", "Arial", fontSize); m_pDrawsLabel = CCLabelTTF::create("000", "Arial", fontSize);
m_pDrawsLabel->retain(); m_pDrawsLabel->retain();
//CCTexture2D::setDefaultAlphaPixelFormat(currentFormat);
CCSize contentSize = m_pDrawsLabel->getContentSize(); CCSize contentSize = m_pDrawsLabel->getContentSize();
m_pDrawsLabel->setPosition(ccpAdd(ccp(contentSize.width/2, contentSize.height*5/2), CC_DIRECTOR_STATS_POSITION)); m_pDrawsLabel->setPosition(ccpAdd(ccp(contentSize.width/2, contentSize.height*5/2), CC_DIRECTOR_STATS_POSITION));
contentSize = m_pSPFLabel->getContentSize(); contentSize = m_pSPFLabel->getContentSize();
@ -787,11 +805,6 @@ void CCDirector::createStatsLabel()
m_pFPSLabel->setPosition(ccpAdd(ccp(contentSize.width/2, contentSize.height/2), CC_DIRECTOR_STATS_POSITION)); m_pFPSLabel->setPosition(ccpAdd(ccp(contentSize.width/2, contentSize.height/2), CC_DIRECTOR_STATS_POSITION));
} }
/***************************************************
* mobile platforms specific functions
**************************************************/
float CCDirector::getContentScaleFactor(void) float CCDirector::getContentScaleFactor(void)
{ {
return m_fContentScaleFactor; return m_fContentScaleFactor;
@ -818,6 +831,16 @@ void CCDirector::setNotificationNode(CCNode *node)
CC_SAFE_RETAIN(m_pNotificationNode); CC_SAFE_RETAIN(m_pNotificationNode);
} }
CCDirectorDelegate* CCDirector::getDelegate() const
{
return m_pProjectionDelegate;
}
void CCDirector::setDelegate(CCDirectorDelegate* pDelegate)
{
m_pProjectionDelegate = pDelegate;
}
void CCDirector::setScheduler(CCScheduler* pScheduler) void CCDirector::setScheduler(CCScheduler* pScheduler)
{ {
if (m_pScheduler != pScheduler) if (m_pScheduler != pScheduler)

View File

@ -160,6 +160,12 @@ public:
CCNode* getNotificationNode(); CCNode* getNotificationNode();
void setNotificationNode(CCNode *node); void setNotificationNode(CCNode *node);
/** CCDirector delegate. It shall implemente the CCDirectorDelegate protocol
@since v0.99.5
*/
CCDirectorDelegate* getDelegate() const;
void setDelegate(CCDirectorDelegate* pDelegate);
// window size // window size
/** returns the size of the OpenGL view in points. /** returns the size of the OpenGL view in points.
@ -181,7 +187,7 @@ public:
CCPoint getVisibleOrigin(); CCPoint getVisibleOrigin();
/** converts a UIKit coordinate to an OpenGL coordinate /** converts a UIKit coordinate to an OpenGL coordinate
Useful to convert (multi) touches coordinates to the current layout (portrait or landscape) Useful to convert (multi) touch coordinates to the current layout (portrait or landscape)
*/ */
CCPoint convertToGL(const CCPoint& obPoint); CCPoint convertToGL(const CCPoint& obPoint);

View File

@ -69,7 +69,7 @@ simple macro that swaps 2 variables
*/ */
#define CC_RADIANS_TO_DEGREES(__ANGLE__) ((__ANGLE__) * 57.29577951f) // PI * 180 #define CC_RADIANS_TO_DEGREES(__ANGLE__) ((__ANGLE__) * 57.29577951f) // PI * 180
#define kCCRepeatForever UINT_MAX -1 #define kCCRepeatForever (UINT_MAX -1)
/** @def CC_BLEND_SRC /** @def CC_BLEND_SRC
default gl blend src function. Compatible with premultiplied alpha images. default gl blend src function. Compatible with premultiplied alpha images.
@ -84,7 +84,7 @@ default gl blend src function. Compatible with premultiplied alpha images.
*/ */
#define CC_NODE_DRAW_SETUP() \ #define CC_NODE_DRAW_SETUP() \
do { \ do { \
ccGLEnable( m_glServerState ); \ ccGLEnable(m_glServerState); \
CCAssert(getShaderProgram(), "No shader program set for this node"); \ CCAssert(getShaderProgram(), "No shader program set for this node"); \
{ \ { \
getShaderProgram()->use(); \ getShaderProgram()->use(); \

View File

@ -241,7 +241,7 @@ THE SOFTWARE.
#include "CCCamera.h" #include "CCCamera.h"
#include "CCConfiguration.h" #include "CCConfiguration.h"
#include "CCDirector.h" #include "CCDirector.h"
#include "CCDrawingPrimitives.h" #include "draw_nodes/CCDrawingPrimitives.h"
#include "CCScheduler.h" #include "CCScheduler.h"
NS_CC_BEGIN NS_CC_BEGIN

View File

@ -167,15 +167,6 @@ static void DrawConstraint(cpConstraint *constraint, CCDrawNode *renderer)
} }
} }
class ChipmunkSpace : public CCObject
{
public:
cpSpace* getSapce() const
{
return NULL;
}
};
// implementation of CCPhysicsDebugNode // implementation of CCPhysicsDebugNode
void CCPhysicsDebugNode::draw() void CCPhysicsDebugNode::draw()
@ -194,31 +185,8 @@ void CCPhysicsDebugNode::draw()
CCPhysicsDebugNode::CCPhysicsDebugNode() CCPhysicsDebugNode::CCPhysicsDebugNode()
: m_pSpacePtr(NULL) : m_pSpacePtr(NULL)
, m_pSpaceObj(NULL)
{} {}
CCPhysicsDebugNode* CCPhysicsDebugNode::create(ChipmunkSpace *space)
{
CCPhysicsDebugNode *node = new CCPhysicsDebugNode();
if (node)
{
node->init();
node->m_pSpaceObj = space;
CC_SAFE_RETAIN(node->m_pSpaceObj);
node->m_pSpacePtr = space->getSapce();
node->autorelease();
}
else
{
CC_SAFE_DELETE(node);
}
return node;
}
CCPhysicsDebugNode* CCPhysicsDebugNode::create(cpSpace *space) CCPhysicsDebugNode* CCPhysicsDebugNode::create(cpSpace *space)
{ {
CCPhysicsDebugNode *node = new CCPhysicsDebugNode(); CCPhysicsDebugNode *node = new CCPhysicsDebugNode();
@ -240,7 +208,6 @@ CCPhysicsDebugNode* CCPhysicsDebugNode::create(cpSpace *space)
CCPhysicsDebugNode::~CCPhysicsDebugNode() CCPhysicsDebugNode::~CCPhysicsDebugNode()
{ {
CC_SAFE_RELEASE(m_pSpaceObj);
} }
NS_CC_END NS_CC_END

View File

@ -32,8 +32,6 @@
NS_CC_BEGIN NS_CC_BEGIN
class ChipmunkSpace;
/** /**
A Node that draws the components of a physics engine. A Node that draws the components of a physics engine.
@ -46,13 +44,9 @@ class ChipmunkSpace;
class CC_DLL CCPhysicsDebugNode : public CCDrawNode class CC_DLL CCPhysicsDebugNode : public CCDrawNode
{ {
protected: protected:
ChipmunkSpace *m_pSpaceObj;
cpSpace *m_pSpacePtr; cpSpace *m_pSpacePtr;
public: public:
/** Create a debug node for an Objective-Chipmunk space. */
static CCPhysicsDebugNode* create(ChipmunkSpace *space);
/** Create a debug node for a regular Chipmunk space. */ /** Create a debug node for a regular Chipmunk space. */
static CCPhysicsDebugNode* create(cpSpace *space); static CCPhysicsDebugNode* create(cpSpace *space);

View File

@ -66,33 +66,6 @@ bool CCPhysicsSprite::isDirty()
#if CC_ENABLE_CHIPMUNK_INTEGRATION #if CC_ENABLE_CHIPMUNK_INTEGRATION
// implementation of ChipmunkBody
ChipmunkBody* ChipmunkBody::create()
{
ChipmunkBody* pRet = new ChipmunkBody();
if (pRet)
{
pRet->autorelease();
}
return pRet;
}
cpBody* ChipmunkBody::getBody()
{
return NULL;
}
// implementation of ChipmunkSprite
ChipmunkBody* ChipmunkSprite::getChipmunkBody() const
{
return (ChipmunkBody*)m_pBody->data;
}
void ChipmunkSprite::setChipmunkBody(ChipmunkBody *chipmunkBody)
{
m_pBody = chipmunkBody->getBody();
}
// Override the setters and getters to always reflect the body's properties. // Override the setters and getters to always reflect the body's properties.
const CCPoint& ChipmunkSprite::getPosition() const CCPoint& ChipmunkSprite::getPosition()
{ {

View File

@ -29,13 +29,6 @@ NS_CC_BEGIN
#if CC_ENABLE_CHIPMUNK_INTEGRATION #if CC_ENABLE_CHIPMUNK_INTEGRATION
#include chipmunk.h #include chipmunk.h
class CC_DLL ChipmunkBody : public CCObject
{
public:
static ChipmunkBody* create();
cpBody* getBody();
};
#elif CC_ENABLE_BOX2D_INTEGRATION #elif CC_ENABLE_BOX2D_INTEGRATION
class b2Body; class b2Body;

View File

@ -155,6 +155,10 @@
glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, depthBuffer_); glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_DEPTH_ATTACHMENT, GL_RENDERBUFFER, depthBuffer_);
if (depthFormat_ == GL_DEPTH24_STENCIL8_OES) {
glFramebufferRenderbuffer(GL_FRAMEBUFFER, GL_STENCIL_ATTACHMENT, GL_RENDERBUFFER, depthBuffer_);
}
// bind color buffer // bind color buffer
glBindRenderbuffer(GL_RENDERBUFFER, colorRenderbuffer_); glBindRenderbuffer(GL_RENDERBUFFER, colorRenderbuffer_);
} }

View File

@ -50,6 +50,7 @@ CCGLProgram::CCGLProgram()
, m_uVertShader(0) , m_uVertShader(0)
, m_uFragShader(0) , m_uFragShader(0)
, m_pHashForUniforms(NULL) , m_pHashForUniforms(NULL)
, m_bUsesTime(false)
{ {
memset(m_uUniforms, 0, sizeof(m_uUniforms)); memset(m_uUniforms, 0, sizeof(m_uUniforms));
} }
@ -87,18 +88,15 @@ bool CCGLProgram::initWithVertexShaderByteArray(const GLchar* vShaderByteArray,
if (vShaderByteArray) if (vShaderByteArray)
{ {
if (!compileShader(&m_uVertShader, GL_VERTEX_SHADER, vShaderByteArray)) if (!compileShader(&m_uVertShader, GL_VERTEX_SHADER, vShaderByteArray))
{ {
CCLOG("cocos2d: ERROR: Failed to compile vertex shader"); CCLOG("cocos2d: ERROR: Failed to compile vertex shader");
} }
} }
// Create and compile fragment shader // Create and compile fragment shader
if (fShaderByteArray) if (fShaderByteArray)
{ {
if (!compileShader(&m_uFragShader, GL_FRAGMENT_SHADER, fShaderByteArray)) if (!compileShader(&m_uFragShader, GL_FRAGMENT_SHADER, fShaderByteArray))
{ {
CCLOG("cocos2d: ERROR: Failed to compile fragment shader"); CCLOG("cocos2d: ERROR: Failed to compile fragment shader");
@ -161,12 +159,9 @@ bool CCGLProgram::compileShader(GLuint * shader, GLenum type, const GLchar* sour
*shader = glCreateShader(type); *shader = glCreateShader(type);
glShaderSource(*shader, sizeof(sources)/sizeof(*sources), sources, NULL); glShaderSource(*shader, sizeof(sources)/sizeof(*sources), sources, NULL);
CHECK_GL_ERROR_DEBUG();
glCompileShader(*shader); glCompileShader(*shader);
CHECK_GL_ERROR_DEBUG();
glGetShaderiv(*shader, GL_COMPILE_STATUS, &status); glGetShaderiv(*shader, GL_COMPILE_STATUS, &status);
CHECK_GL_ERROR_DEBUG();
if (! status) if (! status)
{ {
@ -189,7 +184,7 @@ bool CCGLProgram::compileShader(GLuint * shader, GLenum type, const GLchar* sour
abort(); abort();
} }
return ( status == GL_TRUE ); return (status == GL_TRUE);
} }
void CCGLProgram::addAttribute(const char* attributeName, GLuint index) void CCGLProgram::addAttribute(const char* attributeName, GLuint index)
@ -440,9 +435,9 @@ void CCGLProgram::setUniformsForBuiltins()
kmMat4Multiply(&matrixMVP, &matrixP, &matrixMV); kmMat4Multiply(&matrixMVP, &matrixP, &matrixMV);
setUniformLocationWith4fv(m_uUniforms[kCCUniformPMatrix], matrixP.mat, 1); setUniformLocationwithMatrix4fv(m_uUniforms[kCCUniformPMatrix], matrixP.mat, 1);
setUniformLocationWith4fv(m_uUniforms[kCCUniformMVMatrix], matrixMV.mat, 1); setUniformLocationwithMatrix4fv(m_uUniforms[kCCUniformMVMatrix], matrixMV.mat, 1);
setUniformLocationWith4fv(m_uUniforms[kCCUniformMVPMatrix], matrixMVP.mat, 1); setUniformLocationwithMatrix4fv(m_uUniforms[kCCUniformMVPMatrix], matrixMVP.mat, 1);
if(m_bUsesTime) if(m_bUsesTime)
{ {

View File

@ -39,6 +39,7 @@ enum {
kCCShaderType_PositionTexture_uColor, kCCShaderType_PositionTexture_uColor,
kCCShaderType_PositionTextureA8Color, kCCShaderType_PositionTextureA8Color,
kCCShaderType_Position_uColor, kCCShaderType_Position_uColor,
kCCShaderType_PositionLengthTexureColor,
kCCShaderType_MAX, kCCShaderType_MAX,
}; };
@ -141,6 +142,15 @@ void CCShaderCache::loadDefaultShaders()
m_pPrograms->setObject(p, kCCShader_Position_uColor); m_pPrograms->setObject(p, kCCShader_Position_uColor);
p->release(); p->release();
//
// Position, Legth(TexCoords, Color (used by Draw Node basically )
//
p = new CCGLProgram();
loadDefaultShader(p, kCCShaderType_PositionLengthTexureColor);
m_pPrograms->setObject(p, kCCShader_PositionLengthTexureColor);
p->release();
} }
void CCShaderCache::reloadDefaultShaders() void CCShaderCache::reloadDefaultShaders()
@ -191,6 +201,13 @@ void CCShaderCache::reloadDefaultShaders()
p = programForKey(kCCShader_Position_uColor); p = programForKey(kCCShader_Position_uColor);
p->reset(); p->reset();
loadDefaultShader(p, kCCShaderType_Position_uColor); loadDefaultShader(p, kCCShaderType_Position_uColor);
//
// Position, Legth(TexCoords, Color (used by Draw Node basically )
//
p = programForKey(kCCShader_PositionLengthTexureColor);
p->reset();
loadDefaultShader(p, kCCShaderType_Position_uColor);
} }
void CCShaderCache::loadDefaultShader(CCGLProgram *p, int type) void CCShaderCache::loadDefaultShader(CCGLProgram *p, int type)
@ -246,6 +263,14 @@ void CCShaderCache::loadDefaultShader(CCGLProgram *p, int type)
p->addAttribute("aVertex", kCCVertexAttrib_Position); p->addAttribute("aVertex", kCCVertexAttrib_Position);
break;
case kCCShaderType_PositionLengthTexureColor:
p->initWithVertexShaderByteArray(ccPositionColorLengthTexture_vert, ccPositionColorLengthTexture_frag);
p->addAttribute(kCCAttributeNamePosition, kCCVertexAttrib_Position);
p->addAttribute(kCCAttributeNameTexCoord, kCCVertexAttrib_TexCoords);
p->addAttribute(kCCAttributeNameColor, kCCVertexAttrib_Color);
break; break;
default: default:
CCLOG("cocos2d: %s:%d, error shader type", __FUNCTION__, __LINE__); CCLOG("cocos2d: %s:%d, error shader type", __FUNCTION__, __LINE__);

View File

@ -33,7 +33,7 @@ THE SOFTWARE.
#include "kazmath/GL/matrix.h" #include "kazmath/GL/matrix.h"
#include "kazmath/kazmath.h" #include "kazmath/kazmath.h"
NS_CC_BEGIN using namespace cocos2d;
static GLuint s_uCurrentProjectionMatrix = -1; static GLuint s_uCurrentProjectionMatrix = -1;
static bool s_bVertexAttribPosition = false; static bool s_bVertexAttribPosition = false;
@ -58,10 +58,12 @@ static GLuint s_uVAO = 0;
void ccGLInvalidateStateCache( void ) void ccGLInvalidateStateCache( void )
{ {
kmGLFreeAll(); kmGLFreeAll();
s_uCurrentProjectionMatrix = -1; s_uCurrentProjectionMatrix = -1;
s_bVertexAttribPosition = false; s_bVertexAttribPosition = false;
s_bVertexAttribColor = false; s_bVertexAttribColor = false;
s_bVertexAttribTexCoords = false; s_bVertexAttribTexCoords = false;
#if CC_ENABLE_GL_STATE_CACHE #if CC_ENABLE_GL_STATE_CACHE
s_uCurrentShaderProgram = -1; s_uCurrentShaderProgram = -1;
for( int i=0; i < kCCMaxActiveTexture; i++ ) for( int i=0; i < kCCMaxActiveTexture; i++ )
@ -78,8 +80,10 @@ void ccGLInvalidateStateCache( void )
void ccGLDeleteProgram( GLuint program ) void ccGLDeleteProgram( GLuint program )
{ {
#if CC_ENABLE_GL_STATE_CACHE #if CC_ENABLE_GL_STATE_CACHE
if( program == s_uCurrentShaderProgram ) if(program == s_uCurrentShaderProgram)
{
s_uCurrentShaderProgram = -1; s_uCurrentShaderProgram = -1;
}
#endif // CC_ENABLE_GL_STATE_CACHE #endif // CC_ENABLE_GL_STATE_CACHE
glDeleteProgram( program ); glDeleteProgram( program );
@ -134,24 +138,29 @@ void ccGLBlendResetToCache(void)
#endif // CC_ENABLE_GL_STATE_CACHE #endif // CC_ENABLE_GL_STATE_CACHE
} }
void ccGLBindTexture2D(GLuint textureId)
{
ccGLBindTexture2DN(0, textureId);
}
void ccGLBindTexture2DN(GLuint textureUnit, GLuint textureId) void ccGLBindTexture2DN(GLuint textureUnit, GLuint textureId)
{ {
#if CC_ENABLE_GL_STATE_CACHE #if CC_ENABLE_GL_STATE_CACHE
CCAssert(textureUnit < kCCMaxActiveTexture, "textureUnit is too big"); CCAssert(textureUnit < kCCMaxActiveTexture, "textureUnit is too big");
if( s_uCurrentBoundTexture[textureUnit] != textureId ) if (s_uCurrentBoundTexture[textureUnit] != textureId)
{ {
s_uCurrentBoundTexture[textureUnit] = textureId; s_uCurrentBoundTexture[textureUnit] = textureId;
glActiveTexture(GL_TEXTURE0 + textureUnit); glActiveTexture(GL_TEXTURE0 + textureUnit);
glBindTexture(GL_TEXTURE_2D, textureId ); glBindTexture(GL_TEXTURE_2D, textureId);
} }
#else #else
glActiveTexture(GL_TEXTURE0 + textureUnit); glActiveTexture(GL_TEXTURE0 + textureUnit);
glBindTexture(GL_TEXTURE_2D, textureId ); glBindTexture(GL_TEXTURE_2D, textureId);
#endif #endif
} }
void ccGLDeleteTexture( GLuint textureId ) void ccGLDeleteTexture(GLuint textureId)
{ {
ccGLDeleteTextureN(0, textureId); ccGLDeleteTextureN(0, textureId);
} }
@ -165,7 +174,7 @@ void ccGLDeleteTextureN(GLuint textureUnit, GLuint textureId)
} }
#endif // CC_ENABLE_GL_STATE_CACHE #endif // CC_ENABLE_GL_STATE_CACHE
glDeleteTextures(1, &textureId ); glDeleteTextures(1, &textureId);
} }
void ccGLBindVAO(GLuint vaoId) void ccGLBindVAO(GLuint vaoId)
@ -181,7 +190,7 @@ void ccGLBindVAO(GLuint vaoId)
#endif #endif
} }
void ccGLEnable( ccGLServerState flags ) void ccGLEnable(ccGLServerState flags)
{ {
#if CC_ENABLE_GL_STATE_CACHE #if CC_ENABLE_GL_STATE_CACHE
@ -255,5 +264,3 @@ void ccSetProjectionMatrixDirty( void )
{ {
s_uCurrentProjectionMatrix = -1; s_uCurrentProjectionMatrix = -1;
} }
NS_CC_END

View File

@ -30,8 +30,6 @@ THE SOFTWARE.
#include "CCGL.h" #include "CCGL.h"
#include "platform/CCPlatformMacros.h" #include "platform/CCPlatformMacros.h"
NS_CC_BEGIN
/** /**
* @addtogroup shaders * @addtogroup shaders
* @{ * @{
@ -64,6 +62,10 @@ typedef enum {
} ccGLServerState; } ccGLServerState;
#ifdef __cplusplus
extern "C" {
#endif
/** @file ccGLStateCache.h /** @file ccGLStateCache.h
*/ */
@ -117,14 +119,14 @@ void CC_DLL ccGLEnableVertexAttribs(unsigned int flags);
/** If the texture is not already bound to texture unit 0, it binds it. /** If the texture is not already bound to texture unit 0, it binds it.
If CC_ENABLE_GL_STATE_CACHE is disabled, it will call glBindTexture() directly. If CC_ENABLE_GL_STATE_CACHE is disabled, it will call glBindTexture() directly.
@since v2.1.0 @since v2.0.0
*/ */
void ccGLBindTexture2D(GLuint textureId); void ccGLBindTexture2D(GLuint textureId);
/** If the texture is not already bound to a given unit, it binds it. /** If the texture is not already bound to a given unit, it binds it.
If CC_ENABLE_GL_STATE_CACHE is disabled, it will call glBindTexture() directly. If CC_ENABLE_GL_STATE_CACHE is disabled, it will call glBindTexture() directly.
@since v2.0.0 @since v2.1.0
*/ */
void CC_DLL ccGLBindTexture2DN(GLuint textureUnit, GLuint textureId); void CC_DLL ccGLBindTexture2DN(GLuint textureUnit, GLuint textureId);
@ -155,6 +157,8 @@ void CC_DLL ccGLEnable( ccGLServerState flags );
// end of shaders group // end of shaders group
/// @} /// @}
NS_CC_END #ifdef __cplusplus
}
#endif
#endif /* __CCGLSTATE_H__ */ #endif /* __CCGLSTATE_H__ */

View File

@ -0,0 +1,41 @@
/* Copyright (c) 2012 Scott Lembcke and Howling Moon Software
*
* 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.
*/
" \n\
#extension GL_OES_standard_derivatives : enable \n\
\n\
#ifdef GL_ES \n\
varying mediump vec4 v_color; \n\
varying mediump vec2 v_texcoord; \n\
#else \n\
varying vec4 v_color; \n\
varying vec2 v_texcoord; \n\
#endif \n\
\n\
void main() \n\
{ \n\
#if defined GL_OES_standard_derivatives \n\
gl_FragColor = v_color*smoothstep(0.0, length(fwidth(v_texcoord)), 1.0 - length(v_texcoord)); \n\
#else \n\
gl_FragColor = v_color*step(0.0, 1.0 - length(v_texcoord)); \n\
#endif \n\
} \n\
";

View File

@ -0,0 +1,47 @@
/* Copyright (c) 2012 Scott Lembcke and Howling Moon Software
*
* 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.
*/
" \n\
#ifdef GL_ES \n\
attribute mediump vec4 a_position; \n\
attribute mediump vec2 a_texcoord; \n\
attribute mediump vec4 a_color; \n\
\n\
varying mediump vec4 v_color; \n\
varying mediump vec2 v_texcoord; \n\
\n\
#else \n\
attribute vec4 a_position; \n\
attribute vec2 a_texcoord; \n\
attribute vec4 a_color; \n\
\n\
varying vec4 v_color; \n\
varying vec2 v_texcoord; \n\
#endif \n\
\n\
void main() \n\
{ \n\
v_color = vec4(a_color.rgb * a_color.a, a_color.a); \n\
v_texcoord = a_texcoord; \n\
\n\
gl_Position = CC_MVPMatrix * a_position; \n\
} \n\
";

View File

@ -1,3 +1,28 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\

View File

@ -1,8 +1,31 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
attribute vec4 a_position; \n\ attribute vec4 a_position; \n\
attribute vec4 a_color; \n\ attribute vec4 a_color; \n\
uniform mat4 u_MVPMatrix; \n\
\n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
varying lowp vec4 v_fragmentColor; \n\ varying lowp vec4 v_fragmentColor; \n\
#else \n\ #else \n\
@ -11,7 +34,7 @@ varying vec4 v_fragmentColor; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_Position = u_MVPMatrix * a_position; \n\ gl_Position = CC_MVPMatrix * a_position; \n\
v_fragmentColor = a_color; \n\ v_fragmentColor = a_color; \n\
} \n\ } \n\
"; ";

View File

@ -1,3 +1,28 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\
@ -5,12 +30,12 @@ precision lowp float; \n\
\n\ \n\
varying vec4 v_fragmentColor; \n\ varying vec4 v_fragmentColor; \n\
varying vec2 v_texCoord; \n\ varying vec2 v_texCoord; \n\
uniform sampler2D u_texture; \n\ uniform sampler2D CC_Texture0; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_FragColor = vec4( v_fragmentColor.rgb, // RGB from uniform \n\ gl_FragColor = vec4( v_fragmentColor.rgb, // RGB from uniform \n\
v_fragmentColor.a * texture2D(u_texture, v_texCoord).a // A from texture & uniform \n\ v_fragmentColor.a * texture2D(CC_Texture0, v_texCoord).a // A from texture & uniform \n\
); \n\ ); \n\
} \n\ } \n\
"; ";

View File

@ -1,8 +1,32 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
attribute vec4 a_position; \n\ attribute vec4 a_position; \n\
attribute vec2 a_texCoord; \n\ attribute vec2 a_texCoord; \n\
attribute vec4 a_color; \n\ attribute vec4 a_color; \n\
uniform mat4 u_MVPMatrix; \n\
\n\ \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
varying lowp vec4 v_fragmentColor; \n\ varying lowp vec4 v_fragmentColor; \n\
@ -14,7 +38,7 @@ varying vec2 v_texCoord; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_Position = u_MVPMatrix * a_position; \n\ gl_Position = CC_MVPMatrix * a_position; \n\
v_fragmentColor = a_color; \n\ v_fragmentColor = a_color; \n\
v_texCoord = a_texCoord; \n\ v_texCoord = a_texCoord; \n\
} \n\ } \n\

View File

@ -1,3 +1,27 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Brian Chapados
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\
@ -5,17 +29,17 @@ precision lowp float; \n\
\n\ \n\
varying vec4 v_fragmentColor; \n\ varying vec4 v_fragmentColor; \n\
varying vec2 v_texCoord; \n\ varying vec2 v_texCoord; \n\
uniform sampler2D u_texture; \n\ uniform sampler2D CC_Texture0; \n\
uniform float u_alpha_value; \n\ uniform float CC_alpha_value; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
vec4 texColor = texture2D(u_texture, v_texCoord); \n\ vec4 texColor = texture2D(CC_Texture0, v_texCoord); \n\
\n\ \n\
// mimic: glAlphaFunc(GL_GREATER) \n\ // mimic: glAlphaFunc(GL_GREATER) \n\
// pass if ( incoming_pixel >= u_alpha_value ) => fail if incoming_pixel < u_alpha_value \n\ // pass if ( incoming_pixel >= CC_alpha_value ) => fail if incoming_pixel < CC_alpha_value \n\
\n\ \n\
if ( texColor.a <= u_alpha_value ) \n\ if ( texColor.a <= CC_alpha_value ) \n\
discard; \n\ discard; \n\
\n\ \n\
gl_FragColor = texColor * v_fragmentColor; \n\ gl_FragColor = texColor * v_fragmentColor; \n\

View File

@ -1,3 +1,28 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\
@ -5,10 +30,10 @@ precision lowp float; \n\
\n\ \n\
varying vec4 v_fragmentColor; \n\ varying vec4 v_fragmentColor; \n\
varying vec2 v_texCoord; \n\ varying vec2 v_texCoord; \n\
uniform sampler2D u_texture; \n\ uniform sampler2D CC_Texture0; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_FragColor = v_fragmentColor * texture2D(u_texture, v_texCoord); \n\ gl_FragColor = v_fragmentColor * texture2D(CC_Texture0, v_texCoord); \n\
} \n\ } \n\
"; ";

View File

@ -1,10 +1,33 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
attribute vec4 a_position; \n\ attribute vec4 a_position; \n\
attribute vec2 a_texCoord; \n\ attribute vec2 a_texCoord; \n\
attribute vec4 a_color; \n\ attribute vec4 a_color; \n\
\n\ \n\
uniform mat4 u_MVPMatrix; \n\
\n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
varying lowp vec4 v_fragmentColor; \n\ varying lowp vec4 v_fragmentColor; \n\
varying mediump vec2 v_texCoord; \n\ varying mediump vec2 v_texCoord; \n\
@ -15,7 +38,7 @@ varying vec2 v_texCoord; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_Position = u_MVPMatrix * a_position; \n\ gl_Position = CC_MVPMatrix * a_position; \n\
v_fragmentColor = a_color; \n\ v_fragmentColor = a_color; \n\
v_texCoord = a_texCoord; \n\ v_texCoord = a_texCoord; \n\
} \n\ } \n\

View File

@ -1,13 +1,38 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\
#endif \n\ #endif \n\
\n\ \n\
varying vec2 v_texCoord; \n\ varying vec2 v_texCoord; \n\
uniform sampler2D u_texture; \n\ uniform sampler2D CC_Texture0; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_FragColor = texture2D(u_texture, v_texCoord); \n\ gl_FragColor = texture2D(CC_Texture0, v_texCoord); \n\
} \n\ } \n\
"; ";

View File

@ -1,3 +1,28 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\
@ -7,10 +32,10 @@ uniform vec4 u_color; \n\
\n\ \n\
varying vec2 v_texCoord; \n\ varying vec2 v_texCoord; \n\
\n\ \n\
uniform sampler2D u_texture; \n\ uniform sampler2D CC_Texture0; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_FragColor = texture2D(u_texture, v_texCoord) * u_color; \n\ gl_FragColor = texture2D(CC_Texture0, v_texCoord) * u_color; \n\
} \n\ } \n\
"; ";

View File

@ -1,9 +1,32 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
attribute vec4 a_position; \n\ attribute vec4 a_position; \n\
attribute vec2 a_texCoord; \n\ attribute vec2 a_texCoord; \n\
\n\ \n\
uniform mat4 u_MVPMatrix; \n\
\n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
varying mediump vec2 v_texCoord; \n\ varying mediump vec2 v_texCoord; \n\
#else \n\ #else \n\
@ -12,7 +35,7 @@ varying vec2 v_texCoord; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_Position = u_MVPMatrix * a_position; \n\ gl_Position = CC_MVPMatrix * a_position; \n\
v_texCoord = a_texCoord; \n\ v_texCoord = a_texCoord; \n\
} \n\ } \n\
"; ";

View File

@ -1,7 +1,31 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
attribute vec4 a_position; \n\ attribute vec4 a_position; \n\
attribute vec2 a_texCoord; \n\ attribute vec2 a_texCoord; \n\
uniform mat4 u_MVPMatrix; \n\
\n\ \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
varying mediump vec2 v_texCoord; \n\ varying mediump vec2 v_texCoord; \n\
@ -11,7 +35,7 @@ varying vec2 v_texCoord; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_Position = u_MVPMatrix * a_position; \n\ gl_Position = CC_MVPMatrix * a_position; \n\
v_texCoord = a_texCoord; \n\ v_texCoord = a_texCoord; \n\
} \n\ } \n\
"; ";

View File

@ -1,3 +1,28 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
#ifdef GL_ES \n\ #ifdef GL_ES \n\
precision lowp float; \n\ precision lowp float; \n\

View File

@ -1,6 +1,30 @@
/*
* cocos2d for iPhone: http://www.cocos2d-iphone.org
*
* Copyright (c) 2011 Ricardo Quesada
* Copyright (c) 2012 Zynga Inc.
*
* 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.
*/
" \n\ " \n\
attribute vec4 a_position; \n\ attribute vec4 a_position; \n\
uniform mat4 u_MVPMatrix; \n\
uniform vec4 u_color; \n\ uniform vec4 u_color; \n\
uniform float u_pointSize; \n\ uniform float u_pointSize; \n\
\n\ \n\
@ -12,7 +36,7 @@ varying vec4 v_fragmentColor; \n\
\n\ \n\
void main() \n\ void main() \n\
{ \n\ { \n\
gl_Position = u_MVPMatrix * a_position; \n\ gl_Position = CC_MVPMatrix * a_position; \n\
gl_PointSize = u_pointSize; \n\ gl_PointSize = u_pointSize; \n\
v_fragmentColor = u_color; \n\ v_fragmentColor = u_color; \n\
} \n\ } \n\

View File

@ -69,4 +69,9 @@ const GLchar * ccPositionTexture_uColor_vert =
const GLchar * ccExSwitchMask_frag = const GLchar * ccExSwitchMask_frag =
#include "ccShaderEx_SwitchMask_frag.h" #include "ccShaderEx_SwitchMask_frag.h"
const GLchar * ccPositionColorLengthTexture_frag =
#include "ccShader_PositionColorLengthTexture_frag.h"
const GLchar * ccPositionColorLengthTexture_vert =
#include "ccShader_PositionColorLengthTexture_vert.h"
NS_CC_END NS_CC_END

View File

@ -55,6 +55,9 @@ extern CC_DLL const GLchar * ccPositionTextureColorAlphaTest_frag;
extern CC_DLL const GLchar * ccPositionTexture_uColor_frag; extern CC_DLL const GLchar * ccPositionTexture_uColor_frag;
extern CC_DLL const GLchar * ccPositionTexture_uColor_vert; extern CC_DLL const GLchar * ccPositionTexture_uColor_vert;
extern CC_DLL const GLchar * ccPositionColorLengthTexture_frag;
extern CC_DLL const GLchar * ccPositionColorLengthTexture_vert;
extern CC_DLL const GLchar * ccExSwitchMask_frag; extern CC_DLL const GLchar * ccExSwitchMask_frag;
// end of shaders group // end of shaders group