refactor: leverage Skia helpers for NSColor ANSI logic (#37452)
This commit is contained in:
parent
6bd9ee6988
commit
17ccb3c6ec
5 changed files with 37 additions and 115 deletions
|
@ -175,8 +175,6 @@ filenames = {
|
||||||
"shell/browser/ui/cocoa/electron_touch_bar.mm",
|
"shell/browser/ui/cocoa/electron_touch_bar.mm",
|
||||||
"shell/browser/ui/cocoa/event_dispatching_window.h",
|
"shell/browser/ui/cocoa/event_dispatching_window.h",
|
||||||
"shell/browser/ui/cocoa/event_dispatching_window.mm",
|
"shell/browser/ui/cocoa/event_dispatching_window.mm",
|
||||||
"shell/browser/ui/cocoa/NSColor+Hex.h",
|
|
||||||
"shell/browser/ui/cocoa/NSColor+Hex.mm",
|
|
||||||
"shell/browser/ui/cocoa/NSString+ANSI.h",
|
"shell/browser/ui/cocoa/NSString+ANSI.h",
|
||||||
"shell/browser/ui/cocoa/NSString+ANSI.mm",
|
"shell/browser/ui/cocoa/NSString+ANSI.mm",
|
||||||
"shell/browser/ui/cocoa/root_view_mac.h",
|
"shell/browser/ui/cocoa/root_view_mac.h",
|
||||||
|
|
|
@ -23,7 +23,6 @@
|
||||||
#include "net/base/mac/url_conversions.h"
|
#include "net/base/mac/url_conversions.h"
|
||||||
#include "shell/browser/mac/dict_util.h"
|
#include "shell/browser/mac/dict_util.h"
|
||||||
#include "shell/browser/mac/electron_application.h"
|
#include "shell/browser/mac/electron_application.h"
|
||||||
#include "shell/browser/ui/cocoa/NSColor+Hex.h"
|
|
||||||
#include "shell/common/color_util.h"
|
#include "shell/common/color_util.h"
|
||||||
#include "shell/common/gin_converters/gurl_converter.h"
|
#include "shell/common/gin_converters/gurl_converter.h"
|
||||||
#include "shell/common/gin_converters/value_converter.h"
|
#include "shell/common/gin_converters/value_converter.h"
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
// Created by Mathias Leppich on 03/02/14.
|
|
||||||
// Copyright (c) 2014 Bit Bar. All rights reserved.
|
|
||||||
// Copyright (c) 2017 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#ifndef ELECTRON_SHELL_BROWSER_UI_COCOA_NSCOLOR_HEX_H_
|
|
||||||
#define ELECTRON_SHELL_BROWSER_UI_COCOA_NSCOLOR_HEX_H_
|
|
||||||
|
|
||||||
#import <Cocoa/Cocoa.h>
|
|
||||||
|
|
||||||
@interface NSColor (Hex)
|
|
||||||
- (NSString*)hexadecimalValue;
|
|
||||||
- (NSString*)RGBAValue;
|
|
||||||
+ (NSColor*)colorWithHexColorString:(NSString*)hex;
|
|
||||||
@end
|
|
||||||
|
|
||||||
#endif // ELECTRON_SHELL_BROWSER_UI_COCOA_NSCOLOR_HEX_H_
|
|
|
@ -1,77 +0,0 @@
|
||||||
// Created by Mathias Leppich on 03/02/14.
|
|
||||||
// Copyright (c) 2014 Bit Bar. All rights reserved.
|
|
||||||
// Copyright (c) 2017 GitHub, Inc.
|
|
||||||
// Use of this source code is governed by the MIT license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
#include "shell/browser/ui/cocoa/NSColor+Hex.h"
|
|
||||||
|
|
||||||
@implementation NSColor (Hex)
|
|
||||||
|
|
||||||
- (NSString*)RGBAValue {
|
|
||||||
double redFloatValue, greenFloatValue, blueFloatValue, alphaFloatValue;
|
|
||||||
|
|
||||||
NSColor* convertedColor =
|
|
||||||
[self colorUsingColorSpaceName:NSCalibratedRGBColorSpace];
|
|
||||||
|
|
||||||
if (convertedColor) {
|
|
||||||
[convertedColor getRed:&redFloatValue
|
|
||||||
green:&greenFloatValue
|
|
||||||
blue:&blueFloatValue
|
|
||||||
alpha:&alphaFloatValue];
|
|
||||||
|
|
||||||
int redIntValue = redFloatValue * 255.99999f;
|
|
||||||
int greenIntValue = greenFloatValue * 255.99999f;
|
|
||||||
int blueIntValue = blueFloatValue * 255.99999f;
|
|
||||||
int alphaIntValue = alphaFloatValue * 255.99999f;
|
|
||||||
|
|
||||||
return
|
|
||||||
[NSString stringWithFormat:@"%02x%02x%02x%02x", redIntValue,
|
|
||||||
greenIntValue, blueIntValue, alphaIntValue];
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil;
|
|
||||||
}
|
|
||||||
|
|
||||||
- (NSString*)hexadecimalValue {
|
|
||||||
double redFloatValue, greenFloatValue, blueFloatValue;
|
|
||||||
|
|
||||||
NSColor* convertedColor =
|
|
||||||
[self colorUsingColorSpaceName:NSCalibratedRGBColorSpace];
|
|
||||||
|
|
||||||
if (convertedColor) {
|
|
||||||
[convertedColor getRed:&redFloatValue
|
|
||||||
green:&greenFloatValue
|
|
||||||
blue:&blueFloatValue
|
|
||||||
alpha:NULL];
|
|
||||||
|
|
||||||
int redIntValue = redFloatValue * 255.99999f;
|
|
||||||
int greenIntValue = greenFloatValue * 255.99999f;
|
|
||||||
int blueIntValue = blueFloatValue * 255.99999f;
|
|
||||||
|
|
||||||
return [NSString stringWithFormat:@"#%02x%02x%02x", redIntValue,
|
|
||||||
greenIntValue, blueIntValue];
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ (NSColor*)colorWithHexColorString:(NSString*)inColorString {
|
|
||||||
unsigned colorCode = 0;
|
|
||||||
|
|
||||||
if (inColorString) {
|
|
||||||
NSScanner* scanner = [NSScanner scannerWithString:inColorString];
|
|
||||||
(void)[scanner scanHexInt:&colorCode]; // ignore error
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned char redByte = (unsigned char)(colorCode >> 16);
|
|
||||||
unsigned char greenByte = (unsigned char)(colorCode >> 8);
|
|
||||||
unsigned char blueByte = (unsigned char)(colorCode); // masks off high bits
|
|
||||||
|
|
||||||
return [NSColor colorWithCalibratedRed:(CGFloat)redByte / 0xff
|
|
||||||
green:(CGFloat)greenByte / 0xff
|
|
||||||
blue:(CGFloat)blueByte / 0xff
|
|
||||||
alpha:1.0];
|
|
||||||
}
|
|
||||||
|
|
||||||
@end
|
|
|
@ -4,9 +4,12 @@
|
||||||
// Use of this source code is governed by the MIT license that can be
|
// Use of this source code is governed by the MIT license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
#import <Cocoa/Cocoa.h>
|
||||||
|
|
||||||
#include "base/mac/scoped_nsobject.h"
|
#include "base/mac/scoped_nsobject.h"
|
||||||
#include "shell/browser/ui/cocoa/NSColor+Hex.h"
|
#include "content/public/common/color_parser.h"
|
||||||
#include "shell/browser/ui/cocoa/NSString+ANSI.h"
|
#include "shell/browser/ui/cocoa/NSString+ANSI.h"
|
||||||
|
#include "skia/ext/skia_utils_mac.h"
|
||||||
|
|
||||||
@implementation NSMutableDictionary (ANSI)
|
@implementation NSMutableDictionary (ANSI)
|
||||||
|
|
||||||
|
@ -18,6 +21,7 @@
|
||||||
|
|
||||||
for (NSString* codeString in codeArray) {
|
for (NSString* codeString in codeArray) {
|
||||||
int code = codeString.intValue;
|
int code = codeString.intValue;
|
||||||
|
SkColor color;
|
||||||
switch (code) {
|
switch (code) {
|
||||||
case 0:
|
case 0:
|
||||||
[self removeAllObjects];
|
[self removeAllObjects];
|
||||||
|
@ -37,36 +41,44 @@
|
||||||
// case 24: underlined off
|
// case 24: underlined off
|
||||||
|
|
||||||
case 30:
|
case 30:
|
||||||
|
content::ParseHexColorString(bold ? "#7f7f7f" : "#000000", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"7f7f7f" : @"000000"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 31:
|
case 31:
|
||||||
|
content::ParseHexColorString(bold ? "#cd0000" : "#ff0000", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"cd0000" : @"ff0000"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 32:
|
case 32:
|
||||||
|
content::ParseHexColorString(bold ? "#00cd00" : "#00ff00", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"00cd00" : @"00ff00"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 33:
|
case 33:
|
||||||
|
content::ParseHexColorString(bold ? "#cdcd00" : "#ffff00", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"cdcd00" : @"ffff00"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 34:
|
case 34:
|
||||||
|
content::ParseHexColorString(bold ? "#0000ee" : "#5c5cff", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"0000ee" : @"5c5cff"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 35:
|
case 35:
|
||||||
|
content::ParseHexColorString(bold ? "#cd00cd" : "#ff00ff", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"cd00cd" : @"ff00ff"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 36:
|
case 36:
|
||||||
|
content::ParseHexColorString(bold ? "#00cdcd" : "#00ffff", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"00cdcd" : @"00ffff"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 37:
|
case 37:
|
||||||
|
content::ParseHexColorString(bold ? "#e5e5e5" : "#ffffff", &color);
|
||||||
self[NSForegroundColorAttributeName] =
|
self[NSForegroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:bold ? @"e5e5e5" : @"ffffff"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 39:
|
case 39:
|
||||||
|
@ -74,36 +86,44 @@
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 40:
|
case 40:
|
||||||
|
content::ParseHexColorString("#7f7f7f", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"7f7f7f"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 41:
|
case 41:
|
||||||
|
content::ParseHexColorString("#cd0000", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"cd0000"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 42:
|
case 42:
|
||||||
|
content::ParseHexColorString("#00cd00", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"00cd00"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 43:
|
case 43:
|
||||||
|
content::ParseHexColorString("#cdcd00", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"cdcd00"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 44:
|
case 44:
|
||||||
|
content::ParseHexColorString("#0000ee", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"0000ee"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 45:
|
case 45:
|
||||||
|
content::ParseHexColorString("cd00cd", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"cd00cd"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 46:
|
case 46:
|
||||||
|
content::ParseHexColorString("#00cdcd", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"00cdcd"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
case 47:
|
case 47:
|
||||||
|
content::ParseHexColorString("#e5e5e5", &color);
|
||||||
self[NSBackgroundColorAttributeName] =
|
self[NSBackgroundColorAttributeName] =
|
||||||
[NSColor colorWithHexColorString:@"e5e5e5"];
|
skia::SkColorToCalibratedNSColor(color);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 49:
|
case 49:
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue