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

Side by Side Diff: ui/gfx/image/image_skia.cc

Issue 10532009: Make imageSkia:::extractSubset multi-image aware. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « ui/gfx/image/image_skia.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 "ui/gfx/image/image_skia.h" 5 #include "ui/gfx/image/image_skia.h"
6 6
7 #include <limits> 7 #include <limits>
8 #include <cmath> 8 #include <cmath>
9 9
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "ui/gfx/size.h" 11 #include "ui/gfx/size.h"
12 #include "ui/gfx/skia_util.h"
12 13
13 namespace gfx { 14 namespace gfx {
14 15
15 namespace internal { 16 namespace internal {
16 17
17 // A helper class such that ImageSkia can be cheaply copied. ImageSkia holds a 18 // A helper class such that ImageSkia can be cheaply copied. ImageSkia holds a
18 // refptr instance of ImageSkiaStorage, which in turn holds all of ImageSkia's 19 // refptr instance of ImageSkiaStorage, which in turn holds all of ImageSkia's
19 // information. 20 // information.
20 class ImageSkiaStorage : public base::RefCounted<ImageSkiaStorage> { 21 class ImageSkiaStorage : public base::RefCounted<ImageSkiaStorage> {
21 public: 22 public:
(...skipping 130 matching lines...) Expand 10 before | Expand all | Expand 10 after
152 return isNull() ? 0 : storage_->size().width(); 153 return isNull() ? 0 : storage_->size().width();
153 } 154 }
154 155
155 int ImageSkia::height() const { 156 int ImageSkia::height() const {
156 return isNull() ? 0 : storage_->size().height(); 157 return isNull() ? 0 : storage_->size().height();
157 } 158 }
158 159
159 bool ImageSkia::extractSubset(ImageSkia* dst, const SkIRect& subset) const { 160 bool ImageSkia::extractSubset(ImageSkia* dst, const SkIRect& subset) const {
160 if (isNull()) 161 if (isNull())
161 return false; 162 return false;
162 SkBitmap dst_bitmap; 163 bool return_value = true;
163 bool return_value = storage_->bitmaps()[0].extractSubset(&dst_bitmap, 164 gfx::ImageSkia image;
164 subset); 165 int dip_width = width();
165 *dst = ImageSkia(dst_bitmap); 166 std::vector<SkBitmap> bitmaps = storage_->bitmaps();
167 for (std::vector<SkBitmap> ::const_iterator it = bitmaps.begin();
168 it != bitmaps.end(); ++it) {
Robert Sesek 2012/06/05 17:52:09 nit: align under s
kevers 2012/06/05 20:29:34 Done.
169 SkBitmap bitmap = *it;
170 int px_width = it->width();
171 float dip_scale = (float) px_width / (float) dip_width;
Robert Sesek 2012/06/05 17:52:09 C-style casts aren't allowed by the style guide.
kevers 2012/06/05 20:29:34 Changed to static_cast.
172 int x = (int) (subset.left() * dip_scale + 0.5);
173 int y = (int) (subset.top() * dip_scale + 0.5);
174 int w = (int) (subset.width() * dip_scale + 0.5);
175 int h = (int) (subset.height() * dip_scale + 0.5);
176 SkBitmap dst_bitmap;
177 SkIRect scaled_subset = SkIRect::MakeXYWH(x, y, w, h);
178 return_value &= bitmap.extractSubset(&dst_bitmap, scaled_subset);
179 image.AddBitmapForScale(dst_bitmap, dip_scale);
180 }
181 *dst = image;
Robert Sesek 2012/06/05 17:52:09 Should you overwrite dst ven if return_value==fals
kevers 2012/06/05 20:29:34 Changed to store only successfully extracted subse
166 return return_value; 182 return return_value;
167 } 183 }
168 184
169 const std::vector<SkBitmap> ImageSkia::bitmaps() const { 185 const std::vector<SkBitmap> ImageSkia::bitmaps() const {
170 return storage_->bitmaps(); 186 return storage_->bitmaps();
171 } 187 }
172 188
173 const SkBitmap* ImageSkia::bitmap() const { 189 const SkBitmap* ImageSkia::bitmap() const {
174 if (isNull()) { 190 if (isNull()) {
175 // Callers expect an SkBitmap even if it is |isNull()|. 191 // Callers expect an SkBitmap even if it is |isNull()|.
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after
223 239
224 if (closest_index >= 0) { 240 if (closest_index >= 0) {
225 *bitmap_scale_factor = static_cast<float>(bitmaps[closest_index].width()) / 241 *bitmap_scale_factor = static_cast<float>(bitmaps[closest_index].width()) /
226 width(); 242 width();
227 } 243 }
228 244
229 return closest_index; 245 return closest_index;
230 } 246 }
231 247
232 } // namespace gfx 248 } // namespace gfx
OLDNEW
« no previous file with comments | « ui/gfx/image/image_skia.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698