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

Side by Side Diff: gm/imagemasksubset.cpp

Issue 2286733002: Add imagemasksubset GM (Closed)
Patch Set: Created 4 years, 3 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 | « no previous file | 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
(Empty)
1 /*
2 * Copyright 2016 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8 #include "gm.h"
9 #include "SkCanvas.h"
10 #include "SkImage.h"
11 #include "SkImageGenerator.h"
12 #include "SkSurface.h"
robertphillips 2016/08/26 15:38:00 How are you getting by without including sk_tools_
f(malita) 2016/08/26 15:58:35 Gm.h pulls it in. But yeah, cleaner to include ex
13
14 namespace {
15
16 const SkISize kSize = SkISize::Make(100, 100);
17 const SkIRect kSubset = SkIRect::MakeLTRB(25, 25, 75, 75);
18 const SkRect kDest = SkRect::MakeXYWH(10, 10, 100, 100);
19
20 sk_sp<SkImage> make_mask(const sk_sp<SkSurface>& surface) {
21 sk_tool_utils::draw_checkerboard(surface->getCanvas(), 0x80808080, 0x0000000 0, 5);
22 return surface->makeImageSnapshot();
23 }
24
25 class MaskGenerator final : public SkImageGenerator {
26 public:
27 MaskGenerator(const SkImageInfo& info) : INHERITED(info) {}
28
29 bool onGetPixels(const SkImageInfo& info, void* pixels, size_t rowBytes, SkP MColor*,
30 int*) override {
31 if (info.colorType() == kIndex_8_SkColorType) {
32 return false;
33 }
34
35 make_mask(SkSurface::MakeRasterDirect(info, pixels, rowBytes));
36 return true;
37 }
38
39 private:
40 typedef SkImageGenerator INHERITED;
41 };
42
43 using MakerT = sk_sp<SkImage>(*)(SkCanvas*, const SkImageInfo&);
44 const MakerT makers[] = {
45 // SkImage_Raster
46 [](SkCanvas*, const SkImageInfo& info) -> sk_sp<SkImage> {
47 return make_mask(SkSurface::MakeRaster(info));
48 },
49
50 // SkImage_Gpu
51 [](SkCanvas* c, const SkImageInfo& info) -> sk_sp<SkImage> {
52 sk_sp<SkSurface> surface;
53 #if SK_SUPPORT_GPU
54 surface = SkSurface::MakeRenderTarget(c->getGrContext(), SkBudgeted::kNo , info);
55 #endif
56 return make_mask(surface ? surface : SkSurface::MakeRaster(info));
57 },
58
59 // SkImage_Generator
60 [](SkCanvas*, const SkImageInfo& info) -> sk_sp<SkImage> {
61 return SkImage::MakeFromGenerator(new MaskGenerator(info));
62 },
63 };
64
65 } // anonymous ns
66
robertphillips 2016/08/26 15:38:00 // Comment about why this is interesting ?
f(malita) 2016/08/26 15:58:35 Done.
67 DEF_SIMPLE_GM(imagemasksubset, canvas, 480, 480) {
68 SkPaint paint;
69 paint.setColor(0xff00ff00);
70
71 const SkImageInfo info = SkImageInfo::MakeA8(kSize.width(), kSize.height());
72
73 for (size_t i = 0; i < SK_ARRAY_COUNT(makers); ++i) {
74 sk_sp<SkImage> image = makers[i](canvas, info);
75 if (image) {
76 canvas->drawImageRect(image, SkRect::Make(kSubset), kDest, &paint);
77 sk_sp<SkImage> subset = image->makeSubset(kSubset);
78 canvas->drawImageRect(subset, kDest.makeOffset(kSize.width() * 1.5f, 0), &paint);
79 }
80 canvas->translate(0, kSize.height() * 1.5f);
81 }
82 }
OLDNEW
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698