Merge pull request #13079 from zilongshanren/v3.7.1

fix Mac system font crash issue
This commit is contained in:
pandamicro 2015-08-01 15:27:36 +08:00
commit f995ed8634
1 changed files with 20 additions and 19 deletions

View File

@ -158,20 +158,18 @@ static bool _initWithString(const char * text, Device::TextAlign align, const ch
CC_BREAK_IF(realDimensions.width <= 0 || realDimensions.height <= 0); CC_BREAK_IF(realDimensions.width <= 0 || realDimensions.height <= 0);
CGSize dimensions = CGSizeMake(info->width, info->height); CGSize dimensions = CGSizeMake(info->width, info->height);
if(dimensions.width <= 0.f) {
dimensions.width = realDimensions.width;
}
if (dimensions.height <= 0.f) {
dimensions.height = realDimensions.height;
}
NSInteger POTWide = dimensions.width;
NSInteger POTHigh = dimensions.height;
unsigned char* data = nullptr;
if(dimensions.width <= 0 && dimensions.height <= 0) {
dimensions.width = realDimensions.width;
dimensions.height = realDimensions.height;
} else if (dimensions.height <= 0) {
dimensions.height = realDimensions.height;
}
NSInteger POTWide = dimensions.width;
NSInteger POTHigh = MAX(dimensions.height, realDimensions.height);
unsigned char* data;
//Alignment //Alignment
CGFloat xPadding = 0; CGFloat xPadding = 0;
switch (textAlign) { switch (textAlign) {
case NSLeftTextAlignment: xPadding = 0; break; case NSLeftTextAlignment: xPadding = 0; break;
@ -180,13 +178,16 @@ static bool _initWithString(const char * text, Device::TextAlign align, const ch
default: break; default: break;
} }
// 1: TOP CGFloat yPadding = 0.f;
// 2: BOTTOM switch (vertFlag) {
// 3: CENTER // align to top
CGFloat yPadding = (1 == vertFlag || realDimensions.height >= dimensions.height) ? (dimensions.height - realDimensions.height) // align to top case 1: yPadding = dimensions.height - realDimensions.height; break;
: (2 == vertFlag) ? 0 // align to bottom // align to bottom
: (dimensions.height - realDimensions.height) / 2.0f; // align to center case 2: yPadding = 0.f; break;
// align to center
case 3: yPadding = (dimensions.height - realDimensions.height) / 2.0f; break;
default: break;
}
NSRect textRect = NSMakeRect(xPadding, POTHigh - dimensions.height + yPadding, realDimensions.width, realDimensions.height); NSRect textRect = NSMakeRect(xPadding, POTHigh - dimensions.height + yPadding, realDimensions.width, realDimensions.height);
//Disable antialias //Disable antialias