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

Side by Side Diff: cc/test/skia_common.cc

Issue 1294673006: Update GatherPixelRefDevice to the new SkImage/SkPixelRef API (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: update cc_unittests Created 5 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
« no previous file with comments | « cc/test/skia_common.h ('k') | skia/ext/pixel_ref_utils.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 The Chromium Authors. All rights reserved. 1 // Copyright 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 "cc/test/skia_common.h" 5 #include "cc/test/skia_common.h"
6 6
7 #include "cc/playback/display_item_list.h" 7 #include "cc/playback/display_item_list.h"
8 #include "cc/playback/picture.h" 8 #include "cc/playback/picture.h"
9 #include "skia/ext/refptr.h" 9 #include "skia/ext/refptr.h"
10 #include "third_party/skia/include/core/SkCanvas.h" 10 #include "third_party/skia/include/core/SkCanvas.h"
11 #include "third_party/skia/include/core/SkImageGenerator.h"
11 #include "ui/gfx/geometry/rect.h" 12 #include "ui/gfx/geometry/rect.h"
12 #include "ui/gfx/skia_util.h" 13 #include "ui/gfx/skia_util.h"
13 14
14 namespace cc { 15 namespace cc {
15 16
17 namespace {
18
19 class TestImageGenerator : public SkImageGenerator {
20 public:
21 explicit TestImageGenerator(const SkImageInfo& info)
22 : SkImageGenerator(info) {}
23 };
24
25 } // anonymous namespace
26
16 void DrawPicture(unsigned char* buffer, 27 void DrawPicture(unsigned char* buffer,
17 const gfx::Rect& layer_rect, 28 const gfx::Rect& layer_rect,
18 scoped_refptr<Picture> picture) { 29 scoped_refptr<Picture> picture) {
19 SkImageInfo info = 30 SkImageInfo info =
20 SkImageInfo::MakeN32Premul(layer_rect.width(), layer_rect.height()); 31 SkImageInfo::MakeN32Premul(layer_rect.width(), layer_rect.height());
21 SkBitmap bitmap; 32 SkBitmap bitmap;
22 bitmap.installPixels(info, buffer, info.minRowBytes()); 33 bitmap.installPixels(info, buffer, info.minRowBytes());
23 SkCanvas canvas(bitmap); 34 SkCanvas canvas(bitmap);
24 canvas.clipRect(gfx::RectToSkRect(layer_rect)); 35 canvas.clipRect(gfx::RectToSkRect(layer_rect));
25 // We're drawing the entire canvas, so the negated content region is empty. 36 // We're drawing the entire canvas, so the negated content region is empty.
26 gfx::Rect negated_content_region; 37 gfx::Rect negated_content_region;
27 picture->Raster(&canvas, NULL, negated_content_region, 1.0f); 38 picture->Raster(&canvas, NULL, negated_content_region, 1.0f);
28 } 39 }
29 40
30 void DrawDisplayList(unsigned char* buffer, 41 void DrawDisplayList(unsigned char* buffer,
31 const gfx::Rect& layer_rect, 42 const gfx::Rect& layer_rect,
32 scoped_refptr<DisplayItemList> list) { 43 scoped_refptr<DisplayItemList> list) {
33 SkImageInfo info = 44 SkImageInfo info =
34 SkImageInfo::MakeN32Premul(layer_rect.width(), layer_rect.height()); 45 SkImageInfo::MakeN32Premul(layer_rect.width(), layer_rect.height());
35 SkBitmap bitmap; 46 SkBitmap bitmap;
36 bitmap.installPixels(info, buffer, info.minRowBytes()); 47 bitmap.installPixels(info, buffer, info.minRowBytes());
37 SkCanvas canvas(bitmap); 48 SkCanvas canvas(bitmap);
38 canvas.clipRect(gfx::RectToSkRect(layer_rect)); 49 canvas.clipRect(gfx::RectToSkRect(layer_rect));
39 list->Raster(&canvas, NULL, gfx::Rect(), 1.0f); 50 list->Raster(&canvas, NULL, gfx::Rect(), 1.0f);
40 } 51 }
41 52
42 void CreateBitmap(const gfx::Size& size, const char* uri, SkBitmap* bitmap) { 53 void CreateDiscardableBitmap(const gfx::Size& size, SkBitmap* bitmap) {
43 SkImageInfo info = SkImageInfo::MakeN32Premul(size.width(), size.height()); 54 const SkImageInfo info =
44 55 SkImageInfo::MakeN32Premul(size.width(), size.height());
45 bitmap->allocPixels(info); 56 SkInstallDiscardablePixelRef(new TestImageGenerator(info), bitmap);
46 bitmap->pixelRef()->setImmutable();
47 bitmap->pixelRef()->setURI(uri);
48 } 57 }
49 58
50 } // namespace cc 59 } // namespace cc
OLDNEW
« no previous file with comments | « cc/test/skia_common.h ('k') | skia/ext/pixel_ref_utils.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698