Fix #7644: [OSX] Try to use system colour space to avoid video output performance degradation.

This commit is contained in:
Michael Lutz
2019-09-14 16:31:37 +02:00
committed by Charles Pigott
parent d35254139a
commit 994664dec5

View File

@@ -106,35 +106,6 @@ public:
}; };
static CGColorSpaceRef QZ_GetCorrectColorSpace()
{
static CGColorSpaceRef colorSpace = NULL;
if (colorSpace == NULL) {
#if (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_5)
if (MacOSVersionIsAtLeast(10, 5, 0)) {
colorSpace = CGColorSpaceCreateWithName(kCGColorSpaceSRGB);
} else
#endif
{
#if (MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_5) && !defined(HAVE_OSX_1011_SDK)
CMProfileRef sysProfile;
if (CMGetSystemProfile(&sysProfile) == noErr) {
colorSpace = CGColorSpaceCreateWithPlatformColorSpace(sysProfile);
CMCloseProfile(sysProfile);
}
#endif
}
if (colorSpace == NULL) colorSpace = CGColorSpaceCreateDeviceRGB();
if (colorSpace == NULL) error("Could not get system colour space. You might need to recalibrate your monitor.");
}
return colorSpace;
}
@implementation OTTD_QuartzView @implementation OTTD_QuartzView
- (void)setDriver:(WindowQuartzSubdriver*)drv - (void)setDriver:(WindowQuartzSubdriver*)drv
@@ -289,9 +260,7 @@ bool WindowQuartzSubdriver::SetVideoMode(int width, int height, int bpp)
styleMask:style styleMask:style
backing:NSBackingStoreBuffered backing:NSBackingStoreBuffered
defer:NO ]; defer:NO ];
if ([ this->window respondsToSelector:@selector(setColorSpace:) ]) {
[ this->window setColorSpace:[ [ [ NSColorSpace alloc ] initWithCGColorSpace:QZ_GetCorrectColorSpace() ] autorelease ] ];
}
if (this->window == nil) { if (this->window == nil) {
DEBUG(driver, 0, "Could not create the Cocoa window."); DEBUG(driver, 0, "Could not create the Cocoa window.");
this->setup = false; this->setup = false;
@@ -598,6 +567,21 @@ bool WindowQuartzSubdriver::WindowResized()
this->window_width = (int)newframe.size.width; this->window_width = (int)newframe.size.width;
this->window_height = (int)newframe.size.height; this->window_height = (int)newframe.size.height;
/* Get screen colour space. */
CGColorSpaceRef color_space = NULL;
#if (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_6)
if ([ this->window respondsToSelector:@selector(colorSpace) ]) {
color_space = [ [ this->window colorSpace ] CGColorSpace ];
CGColorSpaceRetain(color_space);
}
#endif
#if (MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_5)
if (color_space == NULL && MacOSVersionIsAtLeast(10, 5, 0)) color_space = CGColorSpaceCreateWithName(kCGColorSpaceSRGB);
#endif
if (color_space == NULL) color_space = CGColorSpaceCreateDeviceRGB();
if (color_space == NULL) error("Could not get system colour space. You might need to recalibrate your monitor.");
/* Create Core Graphics Context */ /* Create Core Graphics Context */
free(this->window_buffer); free(this->window_buffer);
this->window_buffer = (uint32*)malloc(this->window_width * this->window_height * 4); this->window_buffer = (uint32*)malloc(this->window_width * this->window_height * 4);
@@ -609,9 +593,10 @@ bool WindowQuartzSubdriver::WindowResized()
this->window_height, // height this->window_height, // height
8, // bits per component 8, // bits per component
this->window_width * 4, // bytes per row this->window_width * 4, // bytes per row
QZ_GetCorrectColorSpace(), // color space color_space, // color space
kCGImageAlphaNoneSkipFirst | kCGBitmapByteOrder32Host kCGImageAlphaNoneSkipFirst | kCGBitmapByteOrder32Host
); );
CGColorSpaceRelease(color_space);
assert(this->cgcontext != NULL); assert(this->cgcontext != NULL);
CGContextSetShouldAntialias(this->cgcontext, FALSE); CGContextSetShouldAntialias(this->cgcontext, FALSE);