Merge branch 'gles20' of git://github.com/cocos2d/cocos2d-x into gles20

This commit is contained in:
YuLei 2012-09-04 02:16:35 +08:00
commit 539a524627
5 changed files with 33 additions and 24 deletions

View File

@ -622,6 +622,10 @@ void CCTexture2D::setTexParameters(ccTexParams *texParams)
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, texParams->magFilter ); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, texParams->magFilter );
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, texParams->wrapS ); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, texParams->wrapS );
glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, texParams->wrapT ); glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, texParams->wrapT );
#if CC_ENABLE_CACHE_TEXTURE_DATA
VolatileTexture::setTexParameters(this, texParams);
#endif
} }
void CCTexture2D::setAliasTexParameters() void CCTexture2D::setAliasTexParameters()
@ -638,6 +642,10 @@ void CCTexture2D::setAliasTexParameters()
} }
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST ); glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST );
#if CC_ENABLE_CACHE_TEXTURE_DATA
ccTexParams texParams = {m_bHasMipmaps?GL_NEAREST_MIPMAP_NEAREST:GL_NEAREST,GL_NEAREST,GL_NONE,GL_NONE};
VolatileTexture::setTexParameters(this, &texParams);
#endif
} }
void CCTexture2D::setAntiAliasTexParameters() void CCTexture2D::setAntiAliasTexParameters()
@ -654,6 +662,10 @@ void CCTexture2D::setAntiAliasTexParameters()
} }
glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR ); glTexParameteri( GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR );
#if CC_ENABLE_CACHE_TEXTURE_DATA
ccTexParams texParams = {m_bHasMipmaps?GL_LINEAR_MIPMAP_NEAREST:GL_LINEAR,GL_LINEAR,GL_NONE,GL_NONE};
VolatileTexture::setTexParameters(this, &texParams);
#endif
} }
const char* CCTexture2D::stringForFormat() const char* CCTexture2D::stringForFormat()

View File

@ -713,6 +713,10 @@ VolatileTexture::VolatileTexture(CCTexture2D *t)
, m_fFontSize(0.0f) , m_fFontSize(0.0f)
{ {
m_size = CCSizeMake(0, 0); m_size = CCSizeMake(0, 0);
m_texParams.minFilter = GL_LINEAR;
m_texParams.magFilter = GL_LINEAR;
m_texParams.wrapS = GL_CLAMP_TO_EDGE;
m_texParams.wrapT = GL_CLAMP_TO_EDGE;
textures.push_back(this); textures.push_back(this);
} }
@ -801,6 +805,20 @@ void VolatileTexture::addStringTexture(CCTexture2D *tt, const char* text, const
vt->m_strText = text; vt->m_strText = text;
} }
void VolatileTexture::setTexParameters(CCTexture2D *t, ccTexParams *texParams)
{
VolatileTexture *vt = findVolotileTexture(t);
if (texParams->minFilter != GL_NONE)
vt->m_texParams.minFilter = texParams->minFilter;
if (texParams->magFilter != GL_NONE)
vt->m_texParams.magFilter = texParams->magFilter;
if (texParams->wrapS != GL_NONE)
vt->m_texParams.wrapS = texParams->wrapS;
if (texParams->wrapT != GL_NONE)
vt->m_texParams.wrapT = texParams->wrapT;
}
void VolatileTexture::removeTexture(CCTexture2D *t) void VolatileTexture::removeTexture(CCTexture2D *t)
{ {
@ -890,6 +908,7 @@ void VolatileTexture::reloadAllTextures()
default: default:
break; break;
} }
vt->texture->setTexParameters(&vt->m_texParams);
} }
isReloading = false; isReloading = false;

View File

@ -195,6 +195,7 @@ public:
static void addDataTexture(CCTexture2D *tt, void* data, CCTexture2DPixelFormat pixelFormat, const CCSize& contentSize); static void addDataTexture(CCTexture2D *tt, void* data, CCTexture2DPixelFormat pixelFormat, const CCSize& contentSize);
static void addCCImage(CCTexture2D *tt, CCImage *image); static void addCCImage(CCTexture2D *tt, CCImage *image);
static void setTexParameters(CCTexture2D *t, ccTexParams *texParams);
static void removeTexture(CCTexture2D *t); static void removeTexture(CCTexture2D *t);
static void reloadAllTextures(); static void reloadAllTextures();
@ -221,6 +222,7 @@ protected:
std::string m_strFileName; std::string m_strFileName;
CCImage::EImageFormat m_FmtImage; CCImage::EImageFormat m_FmtImage;
ccTexParams m_texParams;
CCSize m_size; CCSize m_size;
CCTextAlignment m_alignment; CCTextAlignment m_alignment;
CCVerticalTextAlignment m_vAlignment; CCVerticalTextAlignment m_vAlignment;

View File

@ -32,8 +32,6 @@ THE SOFTWARE.
#include "shaders/CCGLProgram.h" #include "shaders/CCGLProgram.h"
#include "support/CCPointExtension.h" #include "support/CCPointExtension.h"
#include "support/data_support/ccCArray.h" #include "support/data_support/ccCArray.h"
#include "support/CCNotificationCenter.h"
#include "CCEventType.h"
#include "CCDirector.h" #include "CCDirector.h"
NS_CC_BEGIN NS_CC_BEGIN
@ -99,26 +97,11 @@ bool CCTMXLayer::initWithTilesetInfo(CCTMXTilesetInfo *tilesetInfo, CCTMXLayerIn
m_bUseAutomaticVertexZ = false; m_bUseAutomaticVertexZ = false;
m_nVertexZvalue = 0; m_nVertexZvalue = 0;
// listen the event of "EVNET_COME_TO_FOREGROUND", this event only trigged on android
CCNotificationCenter::sharedNotificationCenter()->addObserver(this,
callfuncO_selector(CCTMXLayer::listenBackToForeground),
EVNET_COME_TO_FOREGROUND,
NULL);
return true; return true;
} }
return false; return false;
} }
void CCTMXLayer::listenBackToForeground(CCObject *sender)
{
if (m_pobTextureAtlas)
{
m_pobTextureAtlas->getTexture()->setAliasTexParameters();
}
}
CCTMXLayer::CCTMXLayer() CCTMXLayer::CCTMXLayer()
:m_tLayerSize(CCSizeZero) :m_tLayerSize(CCSizeZero)
,m_tMapTileSize(CCSizeZero) ,m_tMapTileSize(CCSizeZero)
@ -143,8 +126,6 @@ CCTMXLayer::~CCTMXLayer()
} }
CC_SAFE_DELETE_ARRAY(m_pTiles); CC_SAFE_DELETE_ARRAY(m_pTiles);
CCNotificationCenter::sharedNotificationCenter()->removeObserver(this, EVNET_COME_TO_FOREGROUND);
} }
CCTMXTilesetInfo * CCTMXLayer::getTileSet() CCTMXTilesetInfo * CCTMXLayer::getTileSet()

View File

@ -159,11 +159,6 @@ public:
// super method // super method
void removeChild(CCNode* child, bool cleanup); void removeChild(CCNode* child, bool cleanup);
/** listen the event to invoke CCTexture2D::setAliasTexParameters() after
comming to foreground on android
*/
void listenBackToForeground(CCObject *sender);
inline const char* getLayerName(){ return m_sLayerName.c_str(); } inline const char* getLayerName(){ return m_sLayerName.c_str(); }
inline void setLayerName(const char *layerName){ m_sLayerName = layerName; } inline void setLayerName(const char *layerName){ m_sLayerName = layerName; }
private: private: