| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright 2015 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 |  | 
| Mike Klein | c0bd9f9 | 2019-04-23 12:05:21 -0500 | [diff] [blame] | 8 | #include "gm/gm.h" | 
|  | 9 | #include "include/core/SkCanvas.h" | 
|  | 10 | #include "include/core/SkImage.h" | 
|  | 11 | #include "include/core/SkSurface.h" | 
|  | 12 | #include "include/utils/SkRandom.h" | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 13 |  | 
| reed | 9ce9d67 | 2016-03-17 10:51:11 -0700 | [diff] [blame] | 14 | static sk_sp<SkImage> make_image() { | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 15 | const SkImageInfo info = SkImageInfo::MakeN32Premul(319, 52); | 
| reed | e8f3062 | 2016-03-23 18:59:25 -0700 | [diff] [blame] | 16 | auto surface(SkSurface::MakeRaster(info)); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 17 | SkCanvas* canvas = surface->getCanvas(); | 
| Mike Klein | d46dce3 | 2018-08-16 10:17:03 -0400 | [diff] [blame] | 18 | canvas->drawColor(0xFFF8F8F8); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 19 |  | 
|  | 20 | SkPaint paint; | 
|  | 21 | paint.setAntiAlias(true); | 
|  | 22 |  | 
|  | 23 | paint.setStyle(SkPaint::kStroke_Style); | 
|  | 24 | for (int i = 0; i < 20; ++i) { | 
|  | 25 | canvas->drawCircle(-4, 25, 20, paint); | 
|  | 26 | canvas->translate(25, 0); | 
|  | 27 | } | 
| reed | 9ce9d67 | 2016-03-17 10:51:11 -0700 | [diff] [blame] | 28 | return surface->makeImageSnapshot(); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 29 | } | 
|  | 30 |  | 
| halcanary | 2a24338 | 2015-09-09 08:16:41 -0700 | [diff] [blame] | 31 | DEF_SIMPLE_GM(mipmap, canvas, 400, 200) { | 
| reed | 9ce9d67 | 2016-03-17 10:51:11 -0700 | [diff] [blame] | 32 | sk_sp<SkImage> img(make_image());//SkImage::NewFromEncoded(data)); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 33 |  | 
|  | 34 | SkPaint paint; | 
|  | 35 | const SkRect dst = SkRect::MakeWH(177, 15); | 
|  | 36 |  | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 37 | SkString str; | 
|  | 38 | str.printf("scale %g %g", dst.width() / img->width(), dst.height() / img->height()); | 
| Hal Canary | df2d27e | 2019-01-08 09:38:02 -0500 | [diff] [blame] | 39 | //    canvas->drawString(str, 300, 100, SkFont(nullptr, 30), paint); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 40 |  | 
|  | 41 | canvas->translate(20, 20); | 
|  | 42 | for (int i = 0; i < 4; ++i) { | 
| reed | 93a1215 | 2015-03-16 10:08:34 -0700 | [diff] [blame] | 43 | paint.setFilterQuality(SkFilterQuality(i)); | 
| reed | 9ce9d67 | 2016-03-17 10:51:11 -0700 | [diff] [blame] | 44 | canvas->drawImageRect(img.get(), dst, &paint); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 45 | canvas->translate(0, 20); | 
|  | 46 | } | 
| reed | 9ce9d67 | 2016-03-17 10:51:11 -0700 | [diff] [blame] | 47 | canvas->drawImage(img.get(), 20, 20, nullptr); | 
| reed | c8e4765 | 2015-02-19 11:39:46 -0800 | [diff] [blame] | 48 | } | 
| reed | 6644d93 | 2016-06-10 11:41:47 -0700 | [diff] [blame] | 49 |  | 
|  | 50 | /////////////////////////////////////////////////////////////////////////////////////////////////// | 
|  | 51 |  | 
|  | 52 | // create a circle image computed raw, so we can wrap it as a linear or srgb image | 
|  | 53 | static sk_sp<SkImage> make(sk_sp<SkColorSpace> cs) { | 
|  | 54 | const int N = 100; | 
|  | 55 | SkImageInfo info = SkImageInfo::Make(N, N, kN32_SkColorType, kPremul_SkAlphaType, cs); | 
|  | 56 | SkBitmap bm; | 
|  | 57 | bm.allocPixels(info); | 
|  | 58 |  | 
|  | 59 | for (int y = 0; y < N; ++y) { | 
|  | 60 | for (int x = 0; x < N; ++x) { | 
|  | 61 | *bm.getAddr32(x, y) = (x ^ y) & 1 ? 0xFFFFFFFF : 0xFF000000; | 
|  | 62 | } | 
|  | 63 | } | 
|  | 64 | bm.setImmutable(); | 
|  | 65 | return SkImage::MakeFromBitmap(bm); | 
|  | 66 | } | 
|  | 67 |  | 
|  | 68 | static void show_mips(SkCanvas* canvas, SkImage* img) { | 
|  | 69 | SkPaint paint; | 
|  | 70 | paint.setFilterQuality(kMedium_SkFilterQuality); | 
|  | 71 |  | 
| reed | 3cc37d3 | 2016-06-11 04:48:12 -0700 | [diff] [blame] | 72 | // Want to ensure we never draw fractional pixels, so we use an IRect | 
|  | 73 | SkIRect dst = SkIRect::MakeWH(img->width(), img->height()); | 
| reed | 6644d93 | 2016-06-10 11:41:47 -0700 | [diff] [blame] | 74 | while (dst.width() > 5) { | 
| reed | 3cc37d3 | 2016-06-11 04:48:12 -0700 | [diff] [blame] | 75 | canvas->drawImageRect(img, SkRect::Make(dst), &paint); | 
| reed | 6644d93 | 2016-06-10 11:41:47 -0700 | [diff] [blame] | 76 | dst.offset(dst.width() + 10, 0); | 
| reed | 3cc37d3 | 2016-06-11 04:48:12 -0700 | [diff] [blame] | 77 | dst.fRight = dst.fLeft + dst.width()/2; | 
|  | 78 | dst.fBottom = dst.fTop + dst.height()/2; | 
| reed | 6644d93 | 2016-06-10 11:41:47 -0700 | [diff] [blame] | 79 | } | 
|  | 80 | } | 
|  | 81 |  | 
|  | 82 | /* | 
|  | 83 | *  Ensure that in L32 drawing mode, both images/mips look the same as each other, and | 
|  | 84 | *  their mips are darker than the original (since the mips should ignore the gamma in L32). | 
|  | 85 | * | 
|  | 86 | *  Ensure that in S32 drawing mode, all images/mips look the same, and look correct (i.e. | 
|  | 87 | *  the mip levels match the original in brightness). | 
|  | 88 | */ | 
|  | 89 | DEF_SIMPLE_GM(mipmap_srgb, canvas, 260, 230) { | 
|  | 90 | sk_sp<SkImage> limg = make(nullptr); | 
| Matt Sarett | 77a7a1b | 2017-02-07 13:56:11 -0500 | [diff] [blame] | 91 | sk_sp<SkImage> simg = make(SkColorSpace::MakeSRGB()); | 
| reed | 6644d93 | 2016-06-10 11:41:47 -0700 | [diff] [blame] | 92 |  | 
|  | 93 | canvas->translate(10, 10); | 
|  | 94 | show_mips(canvas, limg.get()); | 
|  | 95 | canvas->translate(0, limg->height() + 10.0f); | 
|  | 96 | show_mips(canvas, simg.get()); | 
|  | 97 | } | 
|  | 98 |  | 
| brianosman | 79b15f6 | 2016-06-21 13:40:12 -0700 | [diff] [blame] | 99 | /////////////////////////////////////////////////////////////////////////////////////////////////// | 
|  | 100 |  | 
|  | 101 | // create a gradient image computed raw, so we can wrap it as a linear or srgb image | 
|  | 102 | static sk_sp<SkImage> make_g8_gradient(sk_sp<SkColorSpace> cs) { | 
|  | 103 | const int N = 100; | 
|  | 104 | SkImageInfo info = SkImageInfo::Make(N, N, kGray_8_SkColorType, kOpaque_SkAlphaType, cs); | 
|  | 105 | SkBitmap bm; | 
|  | 106 | bm.allocPixels(info); | 
|  | 107 |  | 
|  | 108 | for (int y = 0; y < N; ++y) { | 
|  | 109 | for (int x = 0; x < N; ++x) { | 
|  | 110 | *bm.getAddr8(x, y) = static_cast<uint8_t>(255.0f * ((x + y) / (2.0f * (N - 1)))); | 
|  | 111 | } | 
|  | 112 | } | 
|  | 113 | bm.setImmutable(); | 
|  | 114 | return SkImage::MakeFromBitmap(bm); | 
|  | 115 | } | 
|  | 116 |  | 
|  | 117 | static void show_mips_only(SkCanvas* canvas, SkImage* img) { | 
|  | 118 | SkPaint paint; | 
|  | 119 | paint.setFilterQuality(kMedium_SkFilterQuality); | 
|  | 120 |  | 
|  | 121 | // Want to ensure we never draw fractional pixels, so we use an IRect | 
|  | 122 | SkIRect dst = SkIRect::MakeWH(img->width() / 2, img->height() / 2); | 
|  | 123 | while (dst.width() > 5) { | 
|  | 124 | canvas->drawImageRect(img, SkRect::Make(dst), &paint); | 
|  | 125 | dst.offset(dst.width() + 10, 0); | 
|  | 126 | dst.fRight = dst.fLeft + dst.width() / 2; | 
|  | 127 | dst.fBottom = dst.fTop + dst.height() / 2; | 
|  | 128 | } | 
|  | 129 | } | 
|  | 130 |  | 
|  | 131 | /* | 
|  | 132 | *  Ensure that in L32 drawing mode, both images/mips look the same as each other, and | 
|  | 133 | *  their mips are darker than the original (since the mips should ignore the gamma in L32). | 
|  | 134 | * | 
|  | 135 | *  Ensure that in S32 drawing mode, all images/mips look the same, and look correct (i.e. | 
|  | 136 | *  the mip levels match the original in brightness). | 
| brianosman | 79b15f6 | 2016-06-21 13:40:12 -0700 | [diff] [blame] | 137 | */ | 
|  | 138 | DEF_SIMPLE_GM(mipmap_gray8_srgb, canvas, 260, 230) { | 
|  | 139 | sk_sp<SkImage> limg = make_g8_gradient(nullptr); | 
| Matt Sarett | 77a7a1b | 2017-02-07 13:56:11 -0500 | [diff] [blame] | 140 | sk_sp<SkImage> simg = make_g8_gradient(SkColorSpace::MakeSRGB()); | 
| brianosman | 79b15f6 | 2016-06-21 13:40:12 -0700 | [diff] [blame] | 141 |  | 
|  | 142 | canvas->translate(10, 10); | 
|  | 143 | show_mips_only(canvas, limg.get()); | 
|  | 144 | canvas->translate(0, limg->height() + 10.0f); | 
|  | 145 | show_mips_only(canvas, simg.get()); | 
|  | 146 | } |