mirror of https://github.com/axmolengine/axmol.git
Merge pull request #7334 from dabingnn/v3_rollBackTexture
change the logic of texture loading
This commit is contained in:
commit
2d20b282a4
|
@ -711,7 +711,7 @@ std::string Texture2D::getDescription() const
|
||||||
// implementation Texture2D (Image)
|
// implementation Texture2D (Image)
|
||||||
bool Texture2D::initWithImage(Image *image)
|
bool Texture2D::initWithImage(Image *image)
|
||||||
{
|
{
|
||||||
return initWithImage(image, PixelFormat::NONE);
|
return initWithImage(image, g_defaultAlphaPixelFormat);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Texture2D::initWithImage(Image *image, PixelFormat format)
|
bool Texture2D::initWithImage(Image *image, PixelFormat format)
|
||||||
|
@ -736,14 +736,14 @@ bool Texture2D::initWithImage(Image *image, PixelFormat format)
|
||||||
|
|
||||||
unsigned char* tempData = image->getData();
|
unsigned char* tempData = image->getData();
|
||||||
Size imageSize = Size((float)imageWidth, (float)imageHeight);
|
Size imageSize = Size((float)imageWidth, (float)imageHeight);
|
||||||
PixelFormat pixelFormat = PixelFormat::NONE;
|
PixelFormat pixelFormat = ((PixelFormat::NONE == format) || (PixelFormat::AUTO == format)) ? image->getRenderFormat() : format;
|
||||||
PixelFormat renderFormat = image->getRenderFormat();
|
PixelFormat renderFormat = image->getRenderFormat();
|
||||||
size_t tempDataLen = image->getDataLen();
|
size_t tempDataLen = image->getDataLen();
|
||||||
|
|
||||||
|
|
||||||
if (image->getNumberOfMipmaps() > 1)
|
if (image->getNumberOfMipmaps() > 1)
|
||||||
{
|
{
|
||||||
if (format != PixelFormat::NONE)
|
if (pixelFormat != image->getRenderFormat())
|
||||||
{
|
{
|
||||||
CCLOG("cocos2d: WARNING: This image has more than 1 mipmaps and we will not convert the data format");
|
CCLOG("cocos2d: WARNING: This image has more than 1 mipmaps and we will not convert the data format");
|
||||||
}
|
}
|
||||||
|
@ -754,7 +754,7 @@ bool Texture2D::initWithImage(Image *image, PixelFormat format)
|
||||||
}
|
}
|
||||||
else if (image->isCompressed())
|
else if (image->isCompressed())
|
||||||
{
|
{
|
||||||
if (format != PixelFormat::NONE)
|
if (pixelFormat != image->getRenderFormat())
|
||||||
{
|
{
|
||||||
CCLOG("cocos2d: WARNING: This image is compressed and we cann't convert it for now");
|
CCLOG("cocos2d: WARNING: This image is compressed and we cann't convert it for now");
|
||||||
}
|
}
|
||||||
|
@ -764,15 +764,6 @@ bool Texture2D::initWithImage(Image *image, PixelFormat format)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// compute pixel format
|
|
||||||
if (format != PixelFormat::NONE)
|
|
||||||
{
|
|
||||||
pixelFormat = format;
|
|
||||||
}else
|
|
||||||
{
|
|
||||||
pixelFormat = g_defaultAlphaPixelFormat;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned char* outTempData = nullptr;
|
unsigned char* outTempData = nullptr;
|
||||||
ssize_t outTempDataLen = 0;
|
ssize_t outTempDataLen = 0;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue