[iphone] test alignment in labels, ref to the post http://www.cocos2d-x.org/boards/6/topics/588?r=589#message-589 Thanks to Slaz

This commit is contained in:
walzer 2011-02-14 11:51:56 +08:00
parent 626a3f8b74
commit 693a8f049b
2 changed files with 28 additions and 18 deletions

View File

@ -35,7 +35,7 @@ namespace cocos2d{
CCXBitmapDC();
CCXBitmapDC(const char *text,
CGSize dimensions = CGSizeZero,
UITextAlignment alignment = UITextAlignmentCenter,
cocos2d::UITextAlignment alignment = UITextAlignmentCenter,
const char *fontName = NULL,
float fontSize = 0);
~CCXBitmapDC(void);

View File

@ -57,7 +57,7 @@ out:
}
static void initWithString(const char *content, const char *fontName, float size, /*input params*/
int *pWidth, int *pHeight, unsigned char** ppData) /*output params*/
int *pWidth, int *pHeight, UITextAlignment alignment, unsigned char** ppData) /*output params*/
{
NSUInteger width, height;
unsigned char* data;
@ -66,7 +66,6 @@ static void initWithString(const char *content, const char *fontName, float size
id uiFont;
NSString *string;
CGSize dimensions;
UITextAlignment alignment;
NSString *name;
if (!pWidth || !pHeight || !ppData)
@ -74,14 +73,23 @@ static void initWithString(const char *content, const char *fontName, float size
return;
}
alignment = UITextAlignmentCenter;
string = [[NSString alloc] initWithUTF8String:content];
//name = isValidFontName(fontName) ? [[NSString alloc] initWithUTF8String:fontName] : @"Thonburi";
name = isValidFontName(fontName) ? [[NSString alloc] initWithUTF8String:fontName] : @"MarkerFelt-Wide";
dimensions = [string sizeWithFont:[UIFont fontWithName:name size:size]];
width = *pWidth;
height = *pHeight;
// use whatever is larger, the dimension calculated, or the one passed in
if ( dimensions.width > *pWidth )
{
width = dimensions.width;
}
if ( dimensions.height > *pHeight )
{
height = dimensions.height;
}
colorSpace = CGColorSpaceCreateDeviceRGB();
data = new unsigned char[height * width * 4];
@ -99,8 +107,8 @@ static void initWithString(const char *content, const char *fontName, float size
CGRect rect;
rect.origin.x = 0;
rect.origin.y = 0;
rect.size.width = dimensions.width;
rect.size.height = dimensions.height;
rect.size.width = width;
rect.size.height = height;
[string drawInRect:rect withFont:uiFont lineBreakMode:UILineBreakModeWordWrap alignment:alignment];
UIGraphicsPopContext();
@ -127,7 +135,9 @@ namespace cocos2d {
CCXBitmapDC::CCXBitmapDC(const char *text, CGSize dimensions, UITextAlignment alignment, const char *fontName, float fontSize)
{
initWithString(text, fontName, fontSize, &m_nWidth, &m_nHeight, &m_pData);
m_nWidth = dimensions.width;
m_nHeight = dimensions.height;
initWithString(text, fontName, fontSize, &m_nWidth, &m_nHeight, (::UITextAlignment)alignment, &m_pData);
}
CCXBitmapDC::~CCXBitmapDC()