summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authorben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-06-29 22:08:44 +0000
committerben@chromium.org <ben@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-06-29 22:08:44 +0000
commitbd026803b2a3db66f2003f83c4b7e627c71828a2 (patch)
treee45b18ae05095ffae9201fe8ec905bf1fef25e50 /chrome/browser
parent6a649b71db4df80493abfb125e0a71738d4d9d8a (diff)
downloadchromium_src-bd026803b2a3db66f2003f83c4b7e627c71828a2.zip
chromium_src-bd026803b2a3db66f2003f83c4b7e627c71828a2.tar.gz
chromium_src-bd026803b2a3db66f2003f83c4b7e627c71828a2.tar.bz2
Canvas refactoring Phase 4a:
Move Save, SaveLayerAlpha and Restore onto gfx::Canvas. BUG=none TEST=none Review URL: http://codereview.chromium.org/2846035 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@51179 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/download/download_util.cc12
-rw-r--r--chrome/browser/gtk/tabs/tab_renderer_gtk.cc13
-rw-r--r--chrome/browser/views/download_item_view.cc23
-rw-r--r--chrome/browser/views/frame/browser_view.cc4
-rw-r--r--chrome/browser/views/frame/glass_browser_frame_view.cc12
-rw-r--r--chrome/browser/views/frame/opaque_browser_frame_view.cc13
-rw-r--r--chrome/browser/views/infobars/translate_infobar_base.cc6
-rw-r--r--chrome/browser/views/infobars/translate_infobars.cc6
-rw-r--r--chrome/browser/views/tabs/base_tab.cc4
-rw-r--r--chrome/browser/views/tabs/dragged_tab_controller.cc4
-rw-r--r--chrome/browser/views/tabs/side_tab.cc8
-rw-r--r--chrome/browser/views/tabs/tab.cc14
-rw-r--r--chrome/browser/views/tabs/tab_strip.cc17
13 files changed, 53 insertions, 83 deletions
diff --git a/chrome/browser/download/download_util.cc b/chrome/browser/download/download_util.cc
index 0042b75..2da4c14 100644
--- a/chrome/browser/download/download_util.cc
+++ b/chrome/browser/download/download_util.cc
@@ -266,18 +266,10 @@ void PaintDownloadComplete(gfx::Canvas* canvas,
double opacity = sin(animation_progress * PI * kCompleteAnimationCycles +
PI/2) / 2 + 0.5;
- SkRect bounds;
- bounds.set(SkIntToScalar(complete_bounds.x()),
- SkIntToScalar(complete_bounds.y()),
- SkIntToScalar(complete_bounds.x() + complete_bounds.width()),
- SkIntToScalar(complete_bounds.y() + complete_bounds.height()));
- canvas->AsCanvasSkia()->saveLayerAlpha(
- &bounds,
- static_cast<int>(255.0 * opacity),
- SkCanvas::kARGB_ClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(static_cast<int>(255.0 * opacity), complete_bounds);
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
canvas->DrawBitmapInt(*complete, complete_bounds.x(), complete_bounds.y());
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
// Load a language dependent height so that the dangerous download confirmation
diff --git a/chrome/browser/gtk/tabs/tab_renderer_gtk.cc b/chrome/browser/gtk/tabs/tab_renderer_gtk.cc
index 5bd5ec8..83f92e1 100644
--- a/chrome/browser/gtk/tabs/tab_renderer_gtk.cc
+++ b/chrome/browser/gtk/tabs/tab_renderer_gtk.cc
@@ -804,7 +804,7 @@ void TabRendererGtk::PaintIcon(gfx::Canvas* canvas) {
if (loading_animation_.animation_state() != ANIMATION_NONE) {
PaintLoadingAnimation(canvas);
} else {
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(0, 0, width(), height() - kFavIconTitleSpacing);
if (should_display_crashed_favicon_) {
canvas->DrawBitmapInt(*crashed_fav_icon, 0, 0,
@@ -834,7 +834,7 @@ void TabRendererGtk::PaintIcon(gfx::Canvas* canvas) {
}
}
}
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
}
@@ -846,15 +846,12 @@ void TabRendererGtk::PaintTabBackground(gfx::Canvas* canvas) {
double throb_value = GetThrobValue();
if (throb_value > 0) {
- SkRect bounds;
- bounds.set(0, 0, SkIntToScalar(width()), SkIntToScalar(height()));
- canvas->AsCanvasSkia()->saveLayerAlpha(
- &bounds, static_cast<int>(throb_value * 0xff),
- SkCanvas::kARGB_ClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(static_cast<int>(throb_value * 0xff),
+ gfx::Rect(width(), height()));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255,
SkXfermode::kClear_Mode);
PaintActiveTabBackground(canvas);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
}
}
diff --git a/chrome/browser/views/download_item_view.cc b/chrome/browser/views/download_item_view.cc
index edab6a5..3800685 100644
--- a/chrome/browser/views/download_item_view.cc
+++ b/chrome/browser/views/download_item_view.cc
@@ -515,7 +515,7 @@ void DownloadItemView::Paint(gfx::Canvas* canvas) {
// (hot_)body_image_set->bottom_left, and drop_down_image_set,
// for RTL UI, we flip the canvas to draw those images mirrored.
// Consequently, we do not need to mirror the x-axis of those images.
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->TranslateInt(width(), 0);
canvas->ScaleInt(-1, 1);
}
@@ -536,9 +536,8 @@ void DownloadItemView::Paint(gfx::Canvas* canvas) {
// Overlay our body hot state.
if (body_hover_animation_->GetCurrentValue() > 0) {
- canvas->AsCanvasSkia()->saveLayerAlpha(NULL,
- static_cast<int>(body_hover_animation_->GetCurrentValue() * 255),
- SkCanvas::kARGB_NoClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(
+ static_cast<int>(body_hover_animation_->GetCurrentValue() * 255));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
int x = kLeftPadding;
@@ -557,10 +556,10 @@ void DownloadItemView::Paint(gfx::Canvas* canvas) {
hot_body_image_set_.bottom_right,
x, box_y_, box_height_,
hot_body_image_set_.top_right->width());
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
if (rtl_ui) {
- canvas->AsCanvasSkia()->restore();
- canvas->AsCanvasSkia()->save();
+ canvas->Restore();
+ canvas->Save();
// Flip it for drawing drop-down images for RTL locales.
canvas->TranslateInt(width(), 0);
canvas->ScaleInt(-1, 1);
@@ -578,10 +577,8 @@ void DownloadItemView::Paint(gfx::Canvas* canvas) {
// Overlay our drop-down hot state.
if (drop_hover_animation_->GetCurrentValue() > 0) {
- canvas->AsCanvasSkia()->saveLayerAlpha(
- NULL,
- static_cast<int>(drop_hover_animation_->GetCurrentValue() * 255),
- SkCanvas::kARGB_NoClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(
+ static_cast<int>(drop_hover_animation_->GetCurrentValue() * 255));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255,
SkXfermode::kClear_Mode);
@@ -590,7 +587,7 @@ void DownloadItemView::Paint(gfx::Canvas* canvas) {
drop_down_image_set->bottom,
x, box_y_, box_height_, drop_down_image_set->top->width());
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
}
@@ -598,7 +595,7 @@ void DownloadItemView::Paint(gfx::Canvas* canvas) {
// Restore the canvas to avoid file name etc. text are drawn flipped.
// Consequently, the x-axis of following canvas->DrawXXX() method should be
// mirrored so the text and images are down in the right positions.
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
// Print the text, left aligned and always print the file extension.
diff --git a/chrome/browser/views/frame/browser_view.cc b/chrome/browser/views/frame/browser_view.cc
index 2686a61..774eb73 100644
--- a/chrome/browser/views/frame/browser_view.cc
+++ b/chrome/browser/views/frame/browser_view.cc
@@ -220,12 +220,12 @@ class ResizeCorner : public views::View {
if (rtl_dir) {
canvas->TranslateInt(width(), 0);
canvas->ScaleInt(-1, 1);
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
}
canvas->DrawBitmapInt(*bitmap, width() - bitmap->width(),
height() - bitmap->height());
if (rtl_dir)
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
static gfx::Size GetSize() {
diff --git a/chrome/browser/views/frame/glass_browser_frame_view.cc b/chrome/browser/views/frame/glass_browser_frame_view.cc
index b37552e..90e41b9 100644
--- a/chrome/browser/views/frame/glass_browser_frame_view.cc
+++ b/chrome/browser/views/frame/glass_browser_frame_view.cc
@@ -264,14 +264,14 @@ void GlassBrowserFrameView::PaintToolbarBackground(gfx::Canvas* canvas) {
// Draw left edge. We explicitly set a clip as the image is bigger than just
// the corner.
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(x - kNonClientBorderThickness,
y - kNonClientBorderThickness,
kNonClientBorderThickness,
kNonClientBorderThickness);
canvas->DrawBitmapInt(*toolbar_left, x - kNonClientBorderThickness,
y - kNonClientBorderThickness);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
// Draw center edge. We need to draw a while line above the toolbar for the
// image to overlay nicely.
@@ -279,14 +279,14 @@ void GlassBrowserFrameView::PaintToolbarBackground(gfx::Canvas* canvas) {
canvas->TileImageInt(*toolbar_center, x, y - kNonClientBorderThickness, w,
toolbar_center->height());
// Right edge. Again, we have to clip because of image size.
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(x + w - kNonClientBorderThickness,
y - kNonClientBorderThickness,
kNonClientBorderThickness,
kNonClientBorderThickness);
canvas->DrawBitmapInt(*tp->GetBitmapNamed(IDR_CONTENT_TOP_RIGHT_CORNER),
x + w, y);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
} else {
// Draw the toolbar background, setting src_y of the paint to the tab
// strip height as the toolbar background begins at the top of the tabs.
@@ -356,11 +356,11 @@ void GlassBrowserFrameView::PaintOTRAvatar(gfx::Canvas* canvas) {
gfx::Point tabstrip_origin(browser_view_->tabstrip()->bounds().origin());
View::ConvertPointToView(frame_->GetWindow()->GetClientView(), this,
&tabstrip_origin);
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(dst_x, 2, w, tabstrip_origin.y() - 4);
canvas->DrawBitmapInt(otr_avatar_icon, src_x, src_y, w, h, dst_x, dst_y,
w, h, false);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
} else {
canvas->DrawBitmapInt(otr_avatar_icon, src_x, src_y, w, h, dst_x, dst_y,
w, h, false);
diff --git a/chrome/browser/views/frame/opaque_browser_frame_view.cc b/chrome/browser/views/frame/opaque_browser_frame_view.cc
index 227205f..1709903 100644
--- a/chrome/browser/views/frame/opaque_browser_frame_view.cc
+++ b/chrome/browser/views/frame/opaque_browser_frame_view.cc
@@ -382,10 +382,10 @@ void OpaqueBrowserFrameView::PaintChildren(gfx::Canvas* canvas) {
continue;
}
if (child == otr_avatar_icon_) {
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(0, 2, width(), otr_avatar_icon_->height() - 10);
child->ProcessPaint(canvas);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
} else {
child->ProcessPaint(canvas);
}
@@ -781,11 +781,8 @@ void OpaqueBrowserFrameView::PaintToolbarBackground(gfx::Canvas* canvas) {
// Split our canvas out so we can mask out the corners of the toolbar
// without masking out the frame.
- SkRect bounds;
- bounds.set(SkIntToScalar(x - kClientEdgeThickness), SkIntToScalar(y),
- SkIntToScalar(x + w + kClientEdgeThickness * 2),
- SkIntToScalar(y + h));
- canvas->AsCanvasSkia()->saveLayerAlpha(&bounds, 255);
+ canvas->SaveLayerAlpha(
+ 255, gfx::Rect(x - kClientEdgeThickness, y, w + kClientEdgeThickness, h));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
SkColor theme_toolbar_color =
@@ -836,7 +833,7 @@ void OpaqueBrowserFrameView::PaintToolbarBackground(gfx::Canvas* canvas) {
toolbar_right_mask->height() - bottom_edge_height,
toolbar_right_mask->width(), bottom_edge_height, right_x, bottom_y,
toolbar_right_mask->width(), bottom_edge_height, false, paint);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
canvas->DrawBitmapInt(*toolbar_left, 0, 0, toolbar_left->width(), split_point,
left_x, y,
diff --git a/chrome/browser/views/infobars/translate_infobar_base.cc b/chrome/browser/views/infobars/translate_infobar_base.cc
index d344b88..b62a3ef 100644
--- a/chrome/browser/views/infobars/translate_infobar_base.cc
+++ b/chrome/browser/views/infobars/translate_infobar_base.cc
@@ -148,12 +148,10 @@ void TranslateInfoBarBase::FadeBackground(gfx::Canvas* canvas,
const InfoBarBackground& background) {
// Draw the background into an offscreen buffer with alpha value per animation
// value, then blend it back into the current canvas.
- canvas->AsCanvasSkia()->saveLayerAlpha(
- NULL, static_cast<int>(animation_value * 255),
- SkCanvas::kARGB_NoClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(static_cast<int>(animation_value * 255));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
background.Paint(canvas, this);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
// TranslateInfoBarDelegate views specific method:
diff --git a/chrome/browser/views/infobars/translate_infobars.cc b/chrome/browser/views/infobars/translate_infobars.cc
index e395c39..c2a5e2e 100644
--- a/chrome/browser/views/infobars/translate_infobars.cc
+++ b/chrome/browser/views/infobars/translate_infobars.cc
@@ -757,12 +757,10 @@ void TranslateInfoBar::FadeBackground(gfx::Canvas* canvas,
double animation_value, TranslateInfoBarDelegate::TranslateState state) {
// Draw background into an offscreen buffer with alpha value per animation
// value, then blend it back into the current canvas.
- canvas->AsCanvasSkia()->saveLayerAlpha(
- NULL, static_cast<int>(animation_value * 255),
- SkCanvas::kARGB_NoClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(static_cast<int>(animation_value * 255));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
GetBackground(state)->Paint(canvas, this);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
inline TranslateInfoBarDelegate* TranslateInfoBar::GetDelegate() const {
diff --git a/chrome/browser/views/tabs/base_tab.cc b/chrome/browser/views/tabs/base_tab.cc
index 58e853f..9583233 100644
--- a/chrome/browser/views/tabs/base_tab.cc
+++ b/chrome/browser/views/tabs/base_tab.cc
@@ -437,7 +437,7 @@ void BaseTab::PaintIcon(gfx::Canvas* canvas, int x, int y) {
image_size, favicon_x, dst_y, image_size, image_size,
false);
} else {
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(0, 0, width(), height());
if (should_display_crashed_favicon_) {
canvas->DrawBitmapInt(*crashed_fav_icon, 0, 0,
@@ -460,7 +460,7 @@ void BaseTab::PaintIcon(gfx::Canvas* canvas, int x, int y) {
true);
}
}
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
}
diff --git a/chrome/browser/views/tabs/dragged_tab_controller.cc b/chrome/browser/views/tabs/dragged_tab_controller.cc
index d0587bf..7f7f7a5 100644
--- a/chrome/browser/views/tabs/dragged_tab_controller.cc
+++ b/chrome/browser/views/tabs/dragged_tab_controller.cc
@@ -97,7 +97,7 @@ class DockView : public views::View {
bool rtl_ui = base::i18n::IsRTL();
if (rtl_ui) {
// Flip canvas to draw the mirrored tab images for RTL UI.
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->TranslateInt(width(), 0);
canvas->ScaleInt(-1, 1);
}
@@ -171,7 +171,7 @@ class DockView : public views::View {
break;
}
if (rtl_ui)
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
private:
diff --git a/chrome/browser/views/tabs/side_tab.cc b/chrome/browser/views/tabs/side_tab.cc
index 05036d6..0169772 100644
--- a/chrome/browser/views/tabs/side_tab.cc
+++ b/chrome/browser/views/tabs/side_tab.cc
@@ -99,12 +99,10 @@ void SideTab::Paint(gfx::Canvas* canvas) {
if (ShouldShowIcon()) {
if (data().phantom) {
- SkRect bounds;
- bounds.set(0, 0, SkIntToScalar(width()), SkIntToScalar(height()));
- canvas->AsCanvasSkia()->saveLayerAlpha(
- &bounds, kPhantomTabIconAlpha, SkCanvas::kARGB_ClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(kPhantomTabIconAlpha,
+ gfx::Rect(width(), height()));
PaintIcon(canvas, icon_bounds_.x(), icon_bounds_.y());
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
} else {
PaintIcon(canvas, icon_bounds_.x(), icon_bounds_.y());
}
diff --git a/chrome/browser/views/tabs/tab.cc b/chrome/browser/views/tabs/tab.cc
index 82ab751..22e424a 100644
--- a/chrome/browser/views/tabs/tab.cc
+++ b/chrome/browser/views/tabs/tab.cc
@@ -379,15 +379,12 @@ void Tab::PaintTabBackground(gfx::Canvas* canvas) {
double throb_value = GetThrobValue();
if (throb_value > 0) {
- SkRect bounds;
- bounds.set(0, 0, SkIntToScalar(width()), SkIntToScalar(height()));
- canvas->AsCanvasSkia()->saveLayerAlpha(
- &bounds, static_cast<int>(throb_value * 0xff),
- SkCanvas::kARGB_ClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(static_cast<int>(throb_value * 0xff),
+ gfx::Rect(width(), height()));
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255,
SkXfermode::kClear_Mode);
PaintActiveTabBackground(canvas);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
}
}
@@ -438,10 +435,9 @@ void Tab::PaintInactiveTabBackgroundWithTitleChange(gfx::Canvas* canvas) {
// And then the gradient on top of that.
if (mini_title_animation_->current_part_index() == 2) {
- canvas->AsCanvasSkia()->saveLayerAlpha(
- NULL, mini_title_animation_->CurrentValueBetween(255, 0));
+ canvas->SaveLayerAlpha(mini_title_animation_->CurrentValueBetween(255, 0));
canvas->DrawBitmapInt(hover_image, 0, 0);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
} else {
canvas->DrawBitmapInt(hover_image, 0, 0);
}
diff --git a/chrome/browser/views/tabs/tab_strip.cc b/chrome/browser/views/tabs/tab_strip.cc
index 2d54f66..4b61bb5 100644
--- a/chrome/browser/views/tabs/tab_strip.cc
+++ b/chrome/browser/views/tabs/tab_strip.cc
@@ -292,33 +292,30 @@ void TabStrip::PaintChildren(gfx::Canvas* canvas) {
// Phantom tabs appear behind all other tabs and are rendered first. To make
// them slightly transparent we render them to a different layer.
if (HasPhantomTabs()) {
- SkRect bounds;
- bounds.set(0, 0, SkIntToScalar(width()), SkIntToScalar(height()));
- canvas->AsCanvasSkia()->saveLayerAlpha(
- &bounds, kPhantomTabAlpha, SkCanvas::kARGB_ClipLayer_SaveFlag);
+ gfx::Rect local_bounds = GetLocalBounds(true);
+ canvas->SaveLayerAlpha(kPhantomTabAlpha, local_bounds);
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
for (int i = tab_count() - 1; i >= 0; --i) {
Tab* tab = GetTabAtTabDataIndex(i);
if (tab->data().phantom)
tab->ProcessPaint(canvas);
}
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
- canvas->AsCanvasSkia()->saveLayerAlpha(
- &bounds, kPhantomTabIconAlpha, SkCanvas::kARGB_ClipLayer_SaveFlag);
+ canvas->SaveLayerAlpha(kPhantomTabIconAlpha, local_bounds);
canvas->AsCanvasSkia()->drawARGB(0, 255, 255, 255, SkXfermode::kClear_Mode);
for (int i = tab_count() - 1; i >= 0; --i) {
Tab* tab = GetTabAtTabDataIndex(i);
if (tab->data().phantom) {
- canvas->AsCanvasSkia()->save();
+ canvas->Save();
canvas->ClipRectInt(tab->MirroredX(), tab->y(), tab->width(),
tab->height());
canvas->TranslateInt(tab->MirroredX(), tab->y());
tab->PaintIcon(canvas);
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
}
- canvas->AsCanvasSkia()->restore();
+ canvas->Restore();
}
Tab* selected_tab = NULL;