From 105e4ad880a810300bf4b3a0a0752ae58924667b Mon Sep 17 00:00:00 2001 From: crupest Date: Wed, 15 Sep 2021 17:12:51 +0800 Subject: ... --- src/platform/Color.cpp | 28 +++++----------------------- 1 file changed, 5 insertions(+), 23 deletions(-) (limited to 'src/platform/Color.cpp') diff --git a/src/platform/Color.cpp b/src/platform/Color.cpp index c4cc511b..52534048 100644 --- a/src/platform/Color.cpp +++ b/src/platform/Color.cpp @@ -8,24 +8,7 @@ #include namespace cru::platform { -std::string Color::ToUtf8String() const { - auto to_hex = [](std::uint8_t v) -> char { - return v >= 10 ? v - 10 + 'a' : v + '0'; - }; - - auto to_two_hex_digit = [to_hex](std::uint8_t v) -> std::string { - return {to_hex(v /= 16), to_hex(v %= 16)}; - }; - - std::string result = "#"; - result.append(to_two_hex_digit(red)); - result.append(to_two_hex_digit(green)); - result.append(to_two_hex_digit(blue)); - result.append(to_two_hex_digit(alpha)); - return result; -} - -std::u16string Color::ToString() const { +String Color::ToString() const { auto to_hex = [](std::uint8_t v) -> char16_t { return v >= 10 ? v - 10 + u'a' : v + u'0'; }; @@ -42,7 +25,7 @@ std::u16string Color::ToString() const { return result; } -std::optional Color::Parse(std::u16string_view string, +std::optional Color::Parse(StringView string, bool parse_predefined_color) { if (parse_predefined_color) { auto optional_predefined_color = GetPredefinedColorByName(string); @@ -58,8 +41,7 @@ std::optional Color::Parse(std::u16string_view string, return std::nullopt; }; - auto get_num_for_two_digit = - [get_num](std::u16string_view str) -> std::optional { + auto get_num_for_two_digit = [get_num](StringView str) -> std::optional { int num = 0; auto d1 = get_num(str[0]); if (!d1) return std::nullopt; @@ -102,7 +84,7 @@ std::optional Color::Parse(std::u16string_view string, } namespace details { -const std::unordered_map predefined_name_color_map{ +const std::unordered_map predefined_name_color_map{ {u"transparent", colors::transparent}, {u"black", colors::black}, {u"silver", colors::silver}, @@ -255,7 +237,7 @@ const std::unordered_map predefined_name_color_map{ }; } // namespace details -std::optional GetPredefinedColorByName(std::u16string_view name) { +std::optional GetPredefinedColorByName(StringView name) { auto result = details::predefined_name_color_map.find(name); if (result != details::predefined_name_color_map.cend()) { return result->second; -- cgit v1.2.3