Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(194)

Unified Diff: components/favicon_base/fallback_icon_style.cc

Issue 1382343002: Select dark colors for generating fallback icon if possible. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Constant for min background luminance Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: components/favicon_base/fallback_icon_style.cc
diff --git a/components/favicon_base/fallback_icon_style.cc b/components/favicon_base/fallback_icon_style.cc
index a3aa658cad2bc12b42426521faf1208babf5f655..83305f71e12a48fd4b69ceffc93607f43b5961df 100644
--- a/components/favicon_base/fallback_icon_style.cc
+++ b/components/favicon_base/fallback_icon_style.cc
@@ -20,6 +20,7 @@ const int kDarkTextLuminanceThreshold = 190;
// The maximum luminance of the background color to ensure light text is
// readable.
const double kMaxBackgroundColorLuminance = 0.67;
+const double kMinBackgroundColorLuminance = 0.15;
// Default values for FallbackIconStyle.
const SkColor kDefaultBackgroundColor = SkColorSetRGB(0x78, 0x78, 0x78);
@@ -63,10 +64,17 @@ bool ValidateFallbackIconStyle(const FallbackIconStyle& style) {
void SetDominantColorAsBackground(
const scoped_refptr<base::RefCountedMemory>& bitmap_data,
FallbackIconStyle* style) {
- SkColor dominant_color =
- color_utils::CalculateKMeanColorOfPNG(bitmap_data);
- // Assumes |style.text_color| is light, and clamps luminance down to a
- // reasonable maximum value so text is readable.
+ // Try to ensure color's luminance isn't too large so that light text is
+ // visible. Set an upper bound for the dominant color.
+ const color_utils::HSL lower_bound{-1.0, -1.0, kMinBackgroundColorLuminance};
+ const color_utils::HSL upper_bound{-1.0, -1.0, kMaxBackgroundColorLuminance};
+ color_utils::GridSampler sampler;
+ SkColor dominant_color = color_utils::CalculateKMeanColorOfPNG(
+ bitmap_data, lower_bound, upper_bound, &sampler);
+ // |CalculateKMeanColorOfPNG| will try to return a color that lies within the
+ // specified bounds if one exists in the image. If there's no such color, it
+ // will return the dominant color which may be lighter than our upper bound.
+ // Clamp luminance down to a reasonable maximum value so text is readable.
color_utils::HSL color_hsl;
color_utils::SkColorToHSL(dominant_color, &color_hsl);
color_hsl.l = std::min(color_hsl.l, kMaxBackgroundColorLuminance);
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698