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

Side by Side Diff: chrome/browser/ui/views/tabs/dragged_tab_view.cc

Issue 10790128: Revert 147915 - Cleanup gfx::Canvas now that 10562027 has landed (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 8 years, 4 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/views/tabs/dragged_tab_view.h" 5 #include "chrome/browser/ui/views/tabs/dragged_tab_view.h"
6 6
7 #include "base/stl_util.h" 7 #include "base/stl_util.h"
8 #include "chrome/browser/ui/views/tabs/native_view_photobooth.h" 8 #include "chrome/browser/ui/views/tabs/native_view_photobooth.h"
9 #include "third_party/skia/include/core/SkShader.h" 9 #include "third_party/skia/include/core/SkShader.h"
10 #include "ui/gfx/canvas.h" 10 #include "ui/gfx/canvas.h"
(...skipping 115 matching lines...) Expand 10 before | Expand all | Expand 10 after
126 int height = renderer_bounds_.back().height() + kDragFrameBorderSize + 126 int height = renderer_bounds_.back().height() + kDragFrameBorderSize +
127 contents_size_.height(); 127 contents_size_.height();
128 return gfx::Size(width, height); 128 return gfx::Size(width, height);
129 } 129 }
130 130
131 //////////////////////////////////////////////////////////////////////////////// 131 ////////////////////////////////////////////////////////////////////////////////
132 // DraggedTabView, private: 132 // DraggedTabView, private:
133 133
134 void DraggedTabView::PaintDetachedView(gfx::Canvas* canvas) { 134 void DraggedTabView::PaintDetachedView(gfx::Canvas* canvas) {
135 gfx::Size ps = GetPreferredSize(); 135 gfx::Size ps = GetPreferredSize();
136 // TODO(pkotwicz): DIP enable this class. 136 gfx::Canvas scale_canvas(ps, false);
137 gfx::Canvas scale_canvas(ps, ui::SCALE_FACTOR_100P, false);
138 SkBitmap& bitmap_device = const_cast<SkBitmap&>( 137 SkBitmap& bitmap_device = const_cast<SkBitmap&>(
139 skia::GetTopDevice(*scale_canvas.sk_canvas())->accessBitmap(true)); 138 skia::GetTopDevice(*scale_canvas.sk_canvas())->accessBitmap(true));
140 bitmap_device.eraseARGB(0, 0, 0, 0); 139 bitmap_device.eraseARGB(0, 0, 0, 0);
141 140
142 int tab_height = renderer_bounds_.back().height(); 141 int tab_height = renderer_bounds_.back().height();
143 scale_canvas.FillRect(gfx::Rect(0, tab_height - kDragFrameBorderSize, 142 scale_canvas.FillRect(gfx::Rect(0, tab_height - kDragFrameBorderSize,
144 ps.width(), ps.height() - tab_height), 143 ps.width(), ps.height() - tab_height),
145 kDraggedTabBorderColor); 144 kDraggedTabBorderColor);
146 gfx::Rect image_rect(kDragFrameBorderSize, 145 gfx::Rect image_rect(kDragFrameBorderSize,
147 tab_height, 146 tab_height,
148 ps.width() - kTwiceDragFrameBorderSize, 147 ps.width() - kTwiceDragFrameBorderSize,
149 contents_size_.height()); 148 contents_size_.height());
150 scale_canvas.FillRect(image_rect, SK_ColorBLACK); 149 scale_canvas.FillRect(image_rect, SK_ColorBLACK);
151 photobooth_->PaintScreenshotIntoCanvas(&scale_canvas, image_rect); 150 photobooth_->PaintScreenshotIntoCanvas(&scale_canvas, image_rect);
152 for (size_t i = 0; i < renderers_.size(); ++i) 151 for (size_t i = 0; i < renderers_.size(); ++i)
153 renderers_[i]->Paint(&scale_canvas); 152 renderers_[i]->Paint(&scale_canvas);
154 153
155 SkIRect subset; 154 SkIRect subset;
156 subset.set(0, 0, ps.width(), ps.height()); 155 subset.set(0, 0, ps.width(), ps.height());
157 SkBitmap mipmap = scale_canvas.ExtractImageRep().sk_bitmap(); 156 SkBitmap mipmap = scale_canvas.ExtractBitmap();
158 mipmap.buildMipMap(true); 157 mipmap.buildMipMap(true);
159 158
160 SkShader* bitmap_shader = 159 SkShader* bitmap_shader =
161 SkShader::CreateBitmapShader(mipmap, SkShader::kClamp_TileMode, 160 SkShader::CreateBitmapShader(mipmap, SkShader::kClamp_TileMode,
162 SkShader::kClamp_TileMode); 161 SkShader::kClamp_TileMode);
163 162
164 SkMatrix shader_scale; 163 SkMatrix shader_scale;
165 shader_scale.setScale(kScalingFactor, kScalingFactor); 164 shader_scale.setScale(kScalingFactor, kScalingFactor);
166 bitmap_shader->setLocalMatrix(shader_scale); 165 bitmap_shader->setLocalMatrix(shader_scale);
167 166
(...skipping 19 matching lines...) Expand all
187 } 186 }
188 187
189 gfx::Size DraggedTabView::PreferredContainerSize() { 188 gfx::Size DraggedTabView::PreferredContainerSize() {
190 gfx::Size ps = GetPreferredSize(); 189 gfx::Size ps = GetPreferredSize();
191 return gfx::Size(ScaleValue(ps.width()), ScaleValue(ps.height())); 190 return gfx::Size(ScaleValue(ps.width()), ScaleValue(ps.height()));
192 } 191 }
193 192
194 int DraggedTabView::ScaleValue(int value) { 193 int DraggedTabView::ScaleValue(int value) {
195 return static_cast<int>(value * kScalingFactor); 194 return static_cast<int>(value * kScalingFactor);
196 } 195 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/views/omnibox/omnibox_view_win.cc ('k') | chrome/browser/ui/views/tabs/tab.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698