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

Unified Diff: chrome/browser/ui/touch/tabs/touch_tab.cc

Issue 7065052: Improve large tab strip by leveraging touch icons when present (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: removed extra line Created 9 years, 6 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
Index: chrome/browser/ui/touch/tabs/touch_tab.cc
diff --git a/chrome/browser/ui/touch/tabs/touch_tab.cc b/chrome/browser/ui/touch/tabs/touch_tab.cc
index dca408a783e84522e451556d230f89f5d80e80a8..9ab00e07b37c1a0574a30155ccf5cd83ada34527 100644
--- a/chrome/browser/ui/touch/tabs/touch_tab.cc
+++ b/chrome/browser/ui/touch/tabs/touch_tab.cc
@@ -9,6 +9,7 @@
#include "grit/app_resources.h"
#include "grit/theme_resources.h"
#include "grit/theme_resources_standard.h"
+#include "skia/ext/image_operations.h"
#include "ui/base/resource/resource_bundle.h"
#include "ui/gfx/canvas_skia.h"
#include "ui/gfx/favicon_size.h"
@@ -19,14 +20,29 @@ static const int kLeftPadding = 16;
static const int kRightPadding = 15;
static const int kDropShadowHeight = 2;
-// The size of the favicon touch area. This generally would be the same as
-// kFaviconSize in ui/gfx/favicon_size.h
-static const int kTouchTabIconSize = 32;
+// The size of the favicon touch area. This is not the same as kFaviconSize
+// which is defined in ui/gfx/favicon_size.h.
+static const int kTouchTargetIconSize = 32;
TouchTab::TouchTabImage TouchTab::tab_alpha = {0};
TouchTab::TouchTabImage TouchTab::tab_active = {0};
TouchTab::TouchTabImage TouchTab::tab_inactive = {0};
+// static
+void calc_touch_icon_target_size(int* width, int* height) {
sky 2011/06/09 16:53:00 This should really be static.
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 Yes of course, sorry for this cut and paste error
+ if (*width > kTouchTargetIconSize || *height > kTouchTargetIconSize) {
+ // Too big, resize it maintaining the aspect ratio.
+ float aspect_ratio = static_cast<float>(*width) /
+ static_cast<float>(*height);
+ *height = kTouchTargetIconSize;
+ *width = static_cast<int>(aspect_ratio * *height);
+ if (*width > kTouchTargetIconSize) {
+ *width = kTouchTargetIconSize;
+ *height = static_cast<int>(*width / aspect_ratio);
+ }
+ }
+}
+
////////////////////////////////////////////////////////////////////////////////
// TouchTab, public:
@@ -180,7 +196,6 @@ void TouchTab::PaintActiveTabBackground(gfx::Canvas* canvas) {
}
void TouchTab::PaintIcon(gfx::Canvas* canvas) {
- // TODO(wyck): use thumbnailer to get better page images
int x = favicon_bounds_.x();
int y = favicon_bounds_.y();
@@ -190,8 +205,8 @@ void TouchTab::PaintIcon(gfx::Canvas* canvas) {
x += x_base;
if (base::i18n::IsRTL()) {
- x = width() - x -
- (data().favicon.isNull() ? kFaviconSize : data().favicon.width());
+ x = width() - x - (data().favicon.isNull()
+ ? kFaviconSize : data().favicon.width());
sky 2011/06/09 16:53:00 Shouldn't this be kTouchTargetIconSize always?
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 Yes good catch, and it will matter even more now t
}
int favicon_x = x;
sky 2011/06/09 16:53:00 I don't think 212-214 are needed.
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 Indeed, seems like old cruft
@@ -200,13 +215,14 @@ void TouchTab::PaintIcon(gfx::Canvas* canvas) {
if (data().network_state != TabRendererData::NETWORK_STATE_NONE) {
ui::ThemeProvider* tp = GetThemeProvider();
- SkBitmap frames(*tp->GetBitmapNamed(
- (data().network_state == TabRendererData::NETWORK_STATE_WAITING) ?
- IDR_THROBBER_WAITING : IDR_THROBBER));
+ SkBitmap frames(
+ *tp->GetBitmapNamed(
+ (data().network_state == TabRendererData::NETWORK_STATE_WAITING)
+ ? IDR_THROBBER_WAITING : IDR_THROBBER));
int image_size = frames.height();
int image_offset = loading_animation_frame() * image_size;
- canvas->DrawBitmapInt(frames, image_offset, 0, image_size, image_size, x, y,
- kTouchTabIconSize, kTouchTabIconSize, false);
+ canvas->DrawBitmapInt(frames, image_offset, 0, image_size, image_size, x,
+ y, kTouchTargetIconSize, kTouchTargetIconSize, false);
sky 2011/06/09 16:53:00 Is the throbber size 32x32 so that it lines up nic
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 Yes it has been 32x32 for a while. No change neede
} else {
canvas->Save();
canvas->ClipRectInt(0, 0, width(), height());
@@ -215,32 +231,22 @@ void TouchTab::PaintIcon(gfx::Canvas* canvas) {
SkBitmap crashed_favicon(*rb.GetBitmapNamed(IDR_SAD_FAVICON));
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 On the other hand the IDR_SAD_FAVICON is not 32x32
canvas->DrawBitmapInt(crashed_favicon, 0, 0, crashed_favicon.width(),
crashed_favicon.height(), x, y + favicon_hiding_offset(),
- kTouchTabIconSize, kTouchTabIconSize, true);
+ kTouchTargetIconSize, kTouchTargetIconSize, true);
} else {
if (!data().favicon.isNull()) {
-
- if ((data().favicon.width() == kTouchTabIconSize) &&
- (data().favicon.height() == kTouchTabIconSize)) {
- canvas->DrawBitmapInt(data().favicon, 0, 0,
- data().favicon.width(), data().favicon.height(),
- x, y + favicon_hiding_offset(),
- kTouchTabIconSize, kTouchTabIconSize, true);
+ int width = data().favicon.width();
+ int height = data().favicon.height();
+ if (width != kTouchTargetIconSize || height != kTouchTargetIconSize) {
+ calc_touch_icon_target_size(&width, &height);
+ SkBitmap scaled_image = skia::ImageOperations::Resize(data().favicon,
sky 2011/06/09 16:53:00 Seems painful to resize the image each time throug
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 That is a great point. We did not cache before, bu
+ skia::ImageOperations::RESIZE_BEST, width, height);
+ canvas->DrawBitmapInt(scaled_image, 0, 0, scaled_image.width(),
sky 2011/06/09 16:53:00 If the favicon width is not the same as the height
Emmanuel Saint-loubert-Bié 2011/06/10 02:21:45 Done.
+ scaled_image.height(), x, y + favicon_hiding_offset(),
+ kTouchTargetIconSize, kTouchTargetIconSize, true);
} else {
- // Draw a background around target touch area in case the favicon
- // is smaller than touch area (e.g www.google.com is 16x16 now)
- canvas->DrawRectInt(
- GetThemeProvider()->GetColor(
- ThemeService::COLOR_BUTTON_BACKGROUND),
- x, y, kTouchTabIconSize, kTouchTabIconSize);
-
- // We center the image
- // TODO(saintlou): later request larger image from HistoryService
canvas->DrawBitmapInt(data().favicon, 0, 0, data().favicon.width(),
- data().favicon.height(),
- x + ((kTouchTabIconSize - data().favicon.width()) / 2),
- y + ((kTouchTabIconSize - data().favicon.height()) / 2) +
- favicon_hiding_offset(),
- data().favicon.width(), data().favicon.height(), true);
+ data().favicon.height(), x, y + favicon_hiding_offset(),
+ kTouchTargetIconSize, kTouchTargetIconSize, true);
}
}
}

Powered by Google App Engine
This is Rietveld 408576698