Chromium Code Reviews| OLD | NEW |
|---|---|
| (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 } | |
| OLD | NEW |