diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-02-15 17:35:48 +0100 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-02-15 17:35:48 +0100 |
commit | c4869cf15af63841d89165b5a225b9fce7a0c08c (patch) | |
tree | 6415f91c1f907bf5fd6a5f6b8a44391c54c652dd /platform | |
parent | 7e14974d075f115faa11c328d4d12169d565c451 (diff) | |
parent | d9b7075ba6464f62d942a78b8030ad6a534cdf05 (diff) | |
download | redot-engine-c4869cf15af63841d89165b5a225b9fce7a0c08c.tar.gz |
Merge pull request #88274 from bruvzg/macos_hdr_picker
[macOS] Fix color picker on HDR screens.
Diffstat (limited to 'platform')
-rw-r--r-- | platform/macos/display_server_macos.mm | 21 |
1 files changed, 13 insertions, 8 deletions
diff --git a/platform/macos/display_server_macos.mm b/platform/macos/display_server_macos.mm index 165b1e4fbf..ce4c7b2e05 100644 --- a/platform/macos/display_server_macos.mm +++ b/platform/macos/display_server_macos.mm @@ -2817,6 +2817,7 @@ Color DisplayServerMacOS::screen_get_pixel(const Point2i &p_position) const { position += _get_screens_origin(); position /= screen_get_max_scale(); + Color color; for (NSScreen *screen in [NSScreen screens]) { NSRect frame = [screen frame]; if (NSMouseInRect(NSMakePoint(position.x, position.y), frame, NO)) { @@ -2824,18 +2825,22 @@ Color DisplayServerMacOS::screen_get_pixel(const Point2i &p_position) const { CGDirectDisplayID display_id = [[screenDescription objectForKey:@"NSScreenNumber"] unsignedIntValue]; CGImageRef image = CGDisplayCreateImageForRect(display_id, CGRectMake(position.x - frame.origin.x, frame.size.height - (position.y - frame.origin.y), 1, 1)); if (image) { - NSBitmapImageRep *bitmap = [[NSBitmapImageRep alloc] initWithCGImage:image]; - CGImageRelease(image); - NSColor *color = [bitmap colorAtX:0 y:0]; - if (color) { - CGFloat components[4]; - [color getRed:&components[0] green:&components[1] blue:&components[2] alpha:&components[3]]; - return Color(components[0], components[1], components[2], components[3]); + CGColorSpaceRef color_space = CGColorSpaceCreateDeviceRGB(); + if (color_space) { + uint8_t img_data[4]; + CGContextRef context = CGBitmapContextCreate(img_data, 1, 1, 8, 4, color_space, kCGImageAlphaPremultipliedLast | kCGBitmapByteOrder32Big); + if (context) { + CGContextDrawImage(context, CGRectMake(0, 0, 1, 1), image); + color = Color(img_data[0] / 255.0f, img_data[1] / 255.0f, img_data[2] / 255.0f, img_data[3] / 255.0f); + CGContextRelease(context); + } + CGColorSpaceRelease(color_space); } + CGImageRelease(image); } } } - return Color(); + return color; } Ref<Image> DisplayServerMacOS::screen_get_image(int p_screen) const { |