diff options
author | huangs <huangs@chromium.org> | 2015-03-25 07:20:39 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2015-03-25 14:21:28 +0000 |
commit | ced2f17446e45420a4d6072d67adce436e32a6de (patch) | |
tree | f79d984ab53566e8f85b4c185a27744b6b2e6b0c /components/favicon_base | |
parent | 28307d55ab257422161f20c42cbdd693c39bcafb (diff) | |
download | chromium_src-ced2f17446e45420a4d6072d67adce436e32a6de.zip chromium_src-ced2f17446e45420a4d6072d67adce436e32a6de.tar.gz chromium_src-ced2f17446e45420a4d6072d67adce436e32a6de.tar.bz2 |
[Icons NTP] Refactoring: Moving FallbackIconService to components\favicon\core
The class used to be in components\favicon_base. The DEP changes arise
due to movement of fallback icon drawing code.
BUG=467712
Review URL: https://codereview.chromium.org/1032683002
Cr-Commit-Position: refs/heads/master@{#322157}
Diffstat (limited to 'components/favicon_base')
-rw-r--r-- | components/favicon_base/BUILD.gn | 2 | ||||
-rw-r--r-- | components/favicon_base/DEPS | 1 | ||||
-rw-r--r-- | components/favicon_base/fallback_icon_service.cc | 97 | ||||
-rw-r--r-- | components/favicon_base/fallback_icon_service.h | 51 |
4 files changed, 0 insertions, 151 deletions
diff --git a/components/favicon_base/BUILD.gn b/components/favicon_base/BUILD.gn index 07daa0a..2fcfb9c 100644 --- a/components/favicon_base/BUILD.gn +++ b/components/favicon_base/BUILD.gn @@ -4,8 +4,6 @@ source_set("favicon_base") { sources = [ - "fallback_icon_service.cc", - "fallback_icon_service.h", "fallback_icon_style.cc", "fallback_icon_style.h", "favicon_callback.h", diff --git a/components/favicon_base/DEPS b/components/favicon_base/DEPS index dc47487..0265afa 100644 --- a/components/favicon_base/DEPS +++ b/components/favicon_base/DEPS @@ -1,5 +1,4 @@ include_rules = [ - "+net/base/registry_controlled_domains/registry_controlled_domain.h", "+skia/ext", "+third_party/skia/include", "+ui/base", diff --git a/components/favicon_base/fallback_icon_service.cc b/components/favicon_base/fallback_icon_service.cc deleted file mode 100644 index adce72e..0000000 --- a/components/favicon_base/fallback_icon_service.cc +++ /dev/null @@ -1,97 +0,0 @@ -// Copyright 2015 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#include "components/favicon_base/fallback_icon_service.h" - -#include <algorithm> - -#include "base/i18n/case_conversion.h" -#include "base/strings/utf_string_conversions.h" -#include "components/favicon_base/fallback_icon_style.h" -#include "net/base/registry_controlled_domains/registry_controlled_domain.h" -#include "third_party/skia/include/core/SkPaint.h" -#include "ui/gfx/canvas.h" -#include "ui/gfx/codec/png_codec.h" -#include "ui/gfx/font_list.h" -#include "ui/gfx/geometry/rect.h" -#include "ui/gfx/geometry/size.h" -#include "url/gurl.h" - -namespace favicon_base { - -namespace { - -// Arbitrary maximum icon size, can be reasonably increased if needed. -const int kMaxFallbackFaviconSize = 288; - -// Returns a single character to represent a page URL. To do this we take the -// first letter in a domain's name and make it upper case. -// TODO(huangs): Handle non-ASCII ("xn--") domain names. -base::string16 GetFallbackIconText(const GURL& url) { - std::string domain = net::registry_controlled_domains::GetDomainAndRegistry( - url, net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES); - return domain.empty() ? base::string16() : - base::i18n::ToUpper(base::ASCIIToUTF16(domain.substr(0, 1))); -} - -} // namespace - -FallbackIconService::FallbackIconService( - const std::vector<std::string>& font_list) - : font_list_(font_list) { -} - -FallbackIconService::~FallbackIconService() { -} - -std::vector<unsigned char> FallbackIconService::RenderFallbackIconBitmap( - const GURL& icon_url, - int size, - const FallbackIconStyle& style) { - int size_to_use = std::min(kMaxFallbackFaviconSize, size); - gfx::Canvas canvas(gfx::Size(size_to_use, size_to_use), 1.0f, false); - DrawFallbackIcon(icon_url, size_to_use, style, &canvas); - - std::vector<unsigned char> bitmap_data; - if (!gfx::PNGCodec::EncodeBGRASkBitmap(canvas.ExtractImageRep().sk_bitmap(), - false, &bitmap_data)) { - bitmap_data.clear(); - } - return bitmap_data; -} - -void FallbackIconService::DrawFallbackIcon(const GURL& icon_url, - int size, - const FallbackIconStyle& style, - gfx::Canvas* canvas) { - const int kOffsetX = 0; - const int kOffsetY = 0; - SkPaint paint; - paint.setStyle(SkPaint::kFill_Style); - paint.setAntiAlias(true); - - // Draw a filled, colored rounded square. - paint.setColor(style.background_color); - int corner_radius = static_cast<int>(size * style.roundness * 0.5 + 0.5); - canvas->DrawRoundRect( - gfx::Rect(kOffsetX, kOffsetY, size, size), corner_radius, paint); - - // Draw text. - base::string16 icon_text = GetFallbackIconText(icon_url); - if (icon_text.empty()) - return; - int font_size = static_cast<int>(size * style.font_size_ratio); - if (font_size <= 0) - return; - - // TODO(huangs): See how expensive gfx::FontList() is, and possibly cache. - canvas->DrawStringRectWithFlags( - icon_text, - gfx::FontList(font_list_, gfx::Font::NORMAL, font_size), - style.text_color, - gfx::Rect(kOffsetX, kOffsetY, size, size), - gfx::Canvas::TEXT_ALIGN_CENTER); -} - -} // namespace favicon_base diff --git a/components/favicon_base/fallback_icon_service.h b/components/favicon_base/fallback_icon_service.h deleted file mode 100644 index cc98adf..0000000 --- a/components/favicon_base/fallback_icon_service.h +++ /dev/null @@ -1,51 +0,0 @@ -// Copyright 2015 The Chromium Authors. All rights reserved. -// Use of this source code is governed by a BSD-style license that can be -// found in the LICENSE file. - -#ifndef COMPONENTS_FAVICON_BASE_FALLBACK_ICON_SERVICE_H_ -#define COMPONENTS_FAVICON_BASE_FALLBACK_ICON_SERVICE_H_ - -#include <string> -#include <vector> - -#include "base/macros.h" - -class GURL; - -namespace gfx { -class Canvas; -} - -namespace favicon_base { - -struct FallbackIconStyle; - -// A service to provide methods to render fallback favicons. -class FallbackIconService { - public: - explicit FallbackIconService(const std::vector<std::string>& font_list); - ~FallbackIconService(); - - // Renders a fallback icon synchronously and returns the bitmap. Returns an - // empty std::vector on failure. |size| is icon width and height in pixels. - std::vector<unsigned char> RenderFallbackIconBitmap( - const GURL& icon_url, - int size, - const FallbackIconStyle& style); - - private: - // Renders a fallback icon on |canvas| at position (|x|, |y|). |size| is icon - // width and height in pixels. - void DrawFallbackIcon(const GURL& icon_url, - int size, - const FallbackIconStyle& style, - gfx::Canvas* canvas); - - std::vector<std::string> font_list_; - - DISALLOW_COPY_AND_ASSIGN(FallbackIconService); -}; - -} // namespace favicon_base - -#endif // COMPONENTS_FAVICON_BASE_FALLBACK_ICON_SERVICE_H_ |