blob: 539d2fe95531bd0e2ddd8c740cfbe872cd43e158 [file] [log] [blame]
// 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_