summaryrefslogtreecommitdiffstats
path: root/platform
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-02-15 17:35:48 +0100
committerRémi Verschelde <rverschelde@gmail.com>2024-02-15 17:35:48 +0100
commitc4869cf15af63841d89165b5a225b9fce7a0c08c (patch)
tree6415f91c1f907bf5fd6a5f6b8a44391c54c652dd /platform
parent7e14974d075f115faa11c328d4d12169d565c451 (diff)
parentd9b7075ba6464f62d942a78b8030ad6a534cdf05 (diff)
downloadredot-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.mm21
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 {