mirror of https://github.com/axmolengine/axmol.git
Merge pull request #13079 from zilongshanren/v3.7.1
fix Mac system font crash issue
This commit is contained in:
commit
f995ed8634
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue