Skip to content

Commit e1c4365

Browse files
committed
Cursor (macOS): improves color detection and rounding for cursor info
1 parent ebc60ac commit e1c4365

File tree

2 files changed

+26
-14
lines changed

2 files changed

+26
-14
lines changed

CHANGELOG.md

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
# WIP
1+
# 2.50.0
22

33
Changes:
44
* Keys in JSON configuration files are now case-sensitive, as stated in v2.49.0
@@ -22,6 +22,7 @@ Features:
2222
* For IPv6, first GUA or ULA that is not deprecated nor temporary is shown
2323
* Support interface speed detection on SunOS (LocalIP, SunOS)
2424
* Detect Xlibre (#1888, WM, Linux)
25+
* Improve accuracy of color detection (Cursor, macOS)
2526

2627
Bugfixes:
2728
* Fix possible segfault when parsing color strings in JSON config (#1878)

src/detection/cursor/cursor_apple.m

Lines changed: 24 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -2,19 +2,30 @@
22

33
#import <Foundation/Foundation.h>
44

5-
static void appendColor(FFstrbuf* str, NSDictionary* color)
5+
static void appendColor(FFstrbuf* str, NSDictionary* dict)
66
{
7-
int r = (int) (((NSNumber*) color[@"red"]).doubleValue * 255);
8-
int g = (int) (((NSNumber*) color[@"green"]).doubleValue * 255);
9-
int b = (int) (((NSNumber*) color[@"blue"]).doubleValue * 255);
10-
int a = (int) (((NSNumber*) color[@"alpha"]).doubleValue * 255);
11-
12-
if (r == 255 && g == 255 && b == 255 && a == 255)
13-
ffStrbufAppendS(str, "White");
14-
else if (r == 0 && g == 0 && b == 0 && a == 255)
15-
ffStrbufAppendS(str, "Black");
16-
else
17-
ffStrbufAppendF(str, "#%02X%02X%02X%02X", r, g, b, a);
7+
uint32_t r = (uint32_t) (((NSNumber*) dict[@"red"]).doubleValue * 255 + .5);
8+
uint32_t g = (uint32_t) (((NSNumber*) dict[@"green"]).doubleValue * 255 + .5);
9+
uint32_t b = (uint32_t) (((NSNumber*) dict[@"blue"]).doubleValue * 255 + .5);
10+
uint32_t a = (uint32_t) (((NSNumber*) dict[@"alpha"]).doubleValue * 255 + .5);
11+
uint32_t color = (r << 24) | (g << 16) | (b << 8) | a;
12+
13+
switch (color)
14+
{
15+
case 0x000000FF: ffStrbufAppendS(str, "Black"); return;
16+
case 0x0433FFFF: ffStrbufAppendS(str, "Blue"); return;
17+
case 0xAA7942FF: ffStrbufAppendS(str, "Brown"); return;
18+
case 0x00FDFFFF: ffStrbufAppendS(str, "Cyan"); return;
19+
case 0x00F900FF: ffStrbufAppendS(str, "Green"); return;
20+
case 0xFF40FFFF: ffStrbufAppendS(str, "Magenta"); return;
21+
case 0xFF9300FF: ffStrbufAppendS(str, "Orange"); return;
22+
case 0x942192FF: ffStrbufAppendS(str, "Purple"); return;
23+
case 0xFF2600FF: ffStrbufAppendS(str, "Red"); return;
24+
case 0xFFFB00FF: ffStrbufAppendS(str, "Yellow"); return;
25+
case 0xFFFFFFFF: ffStrbufAppendS(str, "White"); return;
26+
case 0x00000000: ffStrbufAppendS(str, "Transparent"); return;
27+
default: ffStrbufAppendF(str, "#%08X", color); return;
28+
}
1829
}
1930

2031
void ffDetectCursor(FFCursorResult* result)
@@ -46,7 +57,7 @@ void ffDetectCursor(FFCursorResult* result)
4657

4758
NSNumber* mouseDriverCursorSize = dict[@"mouseDriverCursorSize"];
4859
if (mouseDriverCursorSize)
49-
ffStrbufAppendF(&result->size, "%d", (int) (mouseDriverCursorSize.doubleValue * 32));
60+
ffStrbufAppendF(&result->size, "%d", (int) (mouseDriverCursorSize.doubleValue * 32 + 0.5));
5061
else
5162
ffStrbufAppendS(&result->size, "32");
5263
}

0 commit comments

Comments
 (0)