2010-07-23 14:36:16 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2010 cocos2d-x.org
|
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
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.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#include "UIImage.h"
|
|
|
|
|
2010-08-02 10:29:00 +08:00
|
|
|
#include <ImageToolKit/IT_ImageLoader.h>
|
2010-07-23 15:13:47 +08:00
|
|
|
#include <TG3.h>
|
|
|
|
|
2010-08-02 10:29:00 +08:00
|
|
|
using namespace ImageToolKit;
|
2010-07-23 14:36:16 +08:00
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
UIImage::UIImage(void)
|
|
|
|
{
|
|
|
|
m_pBitmap = NULL;
|
|
|
|
}
|
|
|
|
|
2010-07-27 15:21:21 +08:00
|
|
|
UIImage::UIImage(int nX, int nY, void *buffer)
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
UIImage::~UIImage(void)
|
|
|
|
{
|
2010-07-30 18:17:13 +08:00
|
|
|
if (m_pBitmap)
|
|
|
|
{
|
|
|
|
m_pBitmap->Destroy();
|
|
|
|
}
|
2010-07-23 14:36:16 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
bool UIImage::initWithContentsOfFile(const string &strPath)
|
|
|
|
{
|
|
|
|
if (m_pBitmap)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2010-07-30 18:17:13 +08:00
|
|
|
// load the image
|
|
|
|
|
|
|
|
ImageLoader obImgLoader;
|
|
|
|
Image obImg;
|
2010-08-02 10:29:00 +08:00
|
|
|
TUChar *pszPath = new TUChar[strPath.size() + 1];
|
2010-07-30 18:17:13 +08:00
|
|
|
TUString::StrGBToUnicode(pszPath, (const Char *) strPath.c_str());
|
2010-08-02 10:29:00 +08:00
|
|
|
bool bRet = false;
|
2010-07-30 18:17:13 +08:00
|
|
|
|
2010-08-02 10:29:00 +08:00
|
|
|
do
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
2010-08-02 10:29:00 +08:00
|
|
|
// check if the loading action is successful
|
|
|
|
if (! obImgLoader.loadImage(obImg, pszPath, IT_LOAD_FMT_UNKNOWN))
|
|
|
|
{
|
|
|
|
bRet = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
// init bitmap
|
|
|
|
m_pBitmap = (TBitmap *) obImg.GetTBitmap();
|
|
|
|
m_pBitmap = m_pBitmap->DupBitmapTo32();
|
|
|
|
|
|
|
|
// the hight is 0??
|
|
|
|
if (m_pBitmap && m_pBitmap->GetHeight() == 0)
|
|
|
|
{
|
|
|
|
m_pBitmap->Destroy();
|
|
|
|
m_pBitmap = NULL;
|
|
|
|
|
|
|
|
bRet = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_pBitmap)
|
|
|
|
{
|
|
|
|
bRet = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
bRet = false;
|
|
|
|
}
|
|
|
|
} while(0);
|
|
|
|
|
|
|
|
delete[] pszPath;
|
|
|
|
return bRet;
|
2010-07-23 14:36:16 +08:00
|
|
|
}
|
|
|
|
|
2010-07-27 15:21:21 +08:00
|
|
|
unsigned int UIImage::width(void)
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
|
|
|
if (! m_pBitmap)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return m_pBitmap->GetWidth();
|
|
|
|
}
|
|
|
|
|
2010-07-27 15:21:21 +08:00
|
|
|
unsigned int UIImage::height(void)
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
|
|
|
if (! m_pBitmap)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
return m_pBitmap->GetHeight();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool UIImage::isAlphaPixelFormat(void)
|
|
|
|
{
|
|
|
|
if (! m_pBitmap)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool bRet;
|
|
|
|
if (m_pBitmap->HasAlphaData())
|
|
|
|
{
|
|
|
|
bRet = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
bRet = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bRet;
|
|
|
|
}
|
|
|
|
|
2010-08-04 14:38:11 +08:00
|
|
|
// now, uphone only support premultiplied data
|
|
|
|
// so, we only return true
|
|
|
|
bool UIImage::isPremultipliedAlpha(void)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2010-07-27 15:21:21 +08:00
|
|
|
// compute how many bits every color component
|
|
|
|
int UIImage::CGImageGetBitsPerComponent(void)
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
|
|
|
if (! m_pBitmap)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2010-07-27 15:21:21 +08:00
|
|
|
int nRet = 0;
|
|
|
|
int nRowBytes = m_pBitmap->GetRowBytes();
|
2010-07-23 14:36:16 +08:00
|
|
|
if (m_pBitmap->HasAlphaData())
|
|
|
|
{
|
|
|
|
// it has alpha data, so
|
|
|
|
// nRawBytes / 4 -> the bytes of per component
|
|
|
|
nRet = nRowBytes / 4 * 8;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// have not alpha data
|
|
|
|
// nRawBytes / 3 -> the bytes of per component
|
|
|
|
nRet = nRowBytes / 3 * 8;
|
|
|
|
}
|
|
|
|
|
|
|
|
return nRet;
|
|
|
|
}
|
|
|
|
|
2010-07-27 16:41:18 +08:00
|
|
|
// 0 -> it is a mask
|
2010-07-27 15:21:21 +08:00
|
|
|
// 1 -> other
|
|
|
|
int UIImage::CGImageGetColorSpace(void)
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
2010-07-27 15:21:21 +08:00
|
|
|
int nRet = 1;
|
|
|
|
|
2010-07-27 16:41:18 +08:00
|
|
|
if (m_pBitmap->GetRowBytes() == 1)
|
2010-07-23 14:36:16 +08:00
|
|
|
{
|
2010-07-27 15:21:21 +08:00
|
|
|
nRet = 0;
|
2010-07-23 14:36:16 +08:00
|
|
|
}
|
|
|
|
|
2010-07-27 15:21:21 +08:00
|
|
|
return nRet;
|
2010-07-23 14:36:16 +08:00
|
|
|
}
|
2010-07-27 09:35:25 +08:00
|
|
|
|
|
|
|
UINT8* UIImage::getRGBA8888Data(void)
|
|
|
|
{
|
|
|
|
UINT8 *pBufferRet = NULL;
|
|
|
|
|
|
|
|
do {
|
|
|
|
const TBitmap *pBitmap;
|
|
|
|
int nW;
|
|
|
|
int nH;
|
2010-08-02 18:18:00 +08:00
|
|
|
UINT8 uR;
|
|
|
|
UINT8 uB;
|
2010-07-27 09:35:25 +08:00
|
|
|
|
2010-07-27 13:47:29 +08:00
|
|
|
// convert to RGBA8888 format
|
2010-07-27 09:35:25 +08:00
|
|
|
pBitmap = m_pBitmap->DupBitmapTo32();
|
2010-07-27 13:47:29 +08:00
|
|
|
if (pBitmap == NULL)
|
2010-07-27 09:35:25 +08:00
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2010-07-27 13:47:29 +08:00
|
|
|
// compute width and height
|
|
|
|
nW = pBitmap->GetWidth();
|
|
|
|
nH = pBitmap->GetHeight();
|
|
|
|
|
|
|
|
// alloc memory and store the bitmap data
|
2010-07-30 18:17:13 +08:00
|
|
|
pBufferRet = new UINT8[nW * nH * 4];
|
2010-07-27 13:47:29 +08:00
|
|
|
memcpy(pBufferRet, pBitmap->GetDataPtr(), nW * nH * 4);
|
2010-08-02 18:18:00 +08:00
|
|
|
|
|
|
|
// translate BGRA to RGBA
|
|
|
|
for (int i = 0; i < nW; ++i)
|
2010-08-02 17:21:57 +08:00
|
|
|
{
|
2010-08-02 18:18:00 +08:00
|
|
|
for (int j = 0; j < nH; ++j)
|
|
|
|
{
|
2010-08-03 11:35:55 +08:00
|
|
|
int baseAddr = (j * nW + i) * 4;
|
2010-08-02 18:18:00 +08:00
|
|
|
|
2010-08-03 11:35:55 +08:00
|
|
|
uB = pBufferRet[baseAddr];
|
|
|
|
uR = pBufferRet[baseAddr + 2];
|
|
|
|
|
|
|
|
pBufferRet[baseAddr] = uR;
|
|
|
|
pBufferRet[baseAddr + 2] = uB;
|
2010-08-02 18:18:00 +08:00
|
|
|
}
|
2010-08-02 17:21:57 +08:00
|
|
|
}
|
2010-07-27 09:35:25 +08:00
|
|
|
} while(0);
|
|
|
|
|
|
|
|
return pBufferRet;
|
|
|
|
}
|