// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef CHROME_BROWSER_FAVICON_FAVICON_UTILS_H_ #define CHROME_BROWSER_FAVICON_FAVICON_UTILS_H_ #include "components/favicon/content/content_favicon_driver.h" #include "third_party/skia/include/core/SkColor.h" #include "ui/base/models/image_model.h" #include "ui/color/color_id.h" namespace content { class WebContents; } // namespace content namespace gfx { class Image; } // namespace gfx namespace favicon { // Creates a ContentFaviconDriver and associates it with |web_contents| if none // exists yet. // // This is a helper method for ContentFaviconDriver::CreateForWebContents() that // gets KeyedService factories from the Profile linked to web_contents. void CreateContentFaviconDriverForWebContents( content::WebContents* web_contents); // Generates a monogram in a colored circle. The color is based on the hash // of the url and the monogram is the first letter of the URL domain. SkBitmap GenerateMonogramFavicon(GURL url, int icon_size, int circle_size); // Retrieves the favicon from given WebContents. If contents contain a // network error, desaturate the favicon. gfx::Image TabFaviconFromWebContents(content::WebContents* contents); // Returns the image to use when no favicon is available, taking dark mode // into account if necessary. gfx::Image GetDefaultFavicon(); // Returns the image to use when no favicon is available, taking the background // color into account. If no background color is provided the window background // color will be used (which is appropriate for most use cases). ui::ImageModel GetDefaultFaviconModel( ui::ColorId bg_color = ui::kColorWindowBackground); // Saves the favicon for the last committed navigation entry to the favicon // database. void SaveFaviconEvenIfInIncognito(content::WebContents* contents); // Return true if the favicon for |entry| should be themified, based on URL as // some chrome pages shouldn't be themified like apps or Password Manager. bool ShouldThemifyFavicon(GURL url); // Return true if the favicon for |entry| should be themified, based on both // its visible and actual URL. bool ShouldThemifyFaviconForEntry(content::NavigationEntry* entry); // Recolor favicon with |alternate_color| if contrast ratio is low between // source color and background |active_background| or // |inactive_background|. gfx::ImageSkia ThemeFavicon(const gfx::ImageSkia& source, SkColor alternate_color, SkColor active_background, SkColor inactive_background); // Recolor the favicon kGoogleGrey900 or white, based on which gives the most // contrast against `background`. gfx::ImageSkia ThemeMonochromeFavicon(const gfx::ImageSkia& source, SkColor background); } // namespace favicon #endif // CHROME_BROWSER_FAVICON_FAVICON_UTILS_H_