blob: 97d724d928a5fece1c88ba54006519b53e55d7e7 [file] [log] [blame]
epoger@google.comfd03db02011-07-28 14:24:55 +00001/*
2 * Copyright 2011 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 */
reed@google.com76f10a32014-02-05 15:32:21 +00007
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "gm/gm.h"
9#include "include/core/SkBitmap.h"
10#include "include/core/SkCanvas.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -040011#include "include/core/SkColor.h"
12#include "include/core/SkPaint.h"
13#include "include/core/SkRect.h"
14#include "include/core/SkScalar.h"
15#include "include/core/SkSize.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050016#include "include/core/SkString.h"
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000017
18namespace skiagm {
junov@google.com61d46a02011-07-28 13:34:31 +000019
20static void create_bitmap(SkBitmap* bitmap) {
21 const int W = 100;
22 const int H = 100;
reed@google.comeb9a46c2014-01-25 16:46:20 +000023 bitmap->allocN32Pixels(W, H);
junov@google.com61d46a02011-07-28 13:34:31 +000024
25 SkCanvas canvas(*bitmap);
26 canvas.drawColor(SK_ColorRED);
27 SkPaint paint;
28 paint.setColor(SK_ColorBLUE);
29 canvas.drawCircle(SkIntToScalar(W)/2, SkIntToScalar(H)/2, SkIntToScalar(W)/2, paint);
30}
31
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000032class ExtractBitmapGM : public GM {
junov@google.com61d46a02011-07-28 13:34:31 +000033public:
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000034 ExtractBitmapGM() {}
rmistry@google.comae933ce2012-08-23 18:19:56 +000035
junov@google.com61d46a02011-07-28 13:34:31 +000036protected:
mtklein36352bf2015-03-25 18:17:31 -070037 SkString onShortName() override {
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000038 return SkString("extractbitmap");
junov@google.com61d46a02011-07-28 13:34:31 +000039 }
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000040
mtklein36352bf2015-03-25 18:17:31 -070041 SkISize onISize() override {
tfarinaf5393182014-06-09 23:59:03 -070042 return SkISize::Make(600, 600);
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000043 }
44
mtklein36352bf2015-03-25 18:17:31 -070045 void onDraw(SkCanvas* canvas) override {
junov@google.com61d46a02011-07-28 13:34:31 +000046 SkBitmap bitmap;
47 create_bitmap(&bitmap);
48 int x = bitmap.width() / 2;
49 int y = bitmap.height() / 2;
junov@google.com61d46a02011-07-28 13:34:31 +000050
51 canvas->translate(SkIntToScalar(20), SkIntToScalar(20));
52
53 canvas->drawBitmap(bitmap, 0, 0);
scroggo@google.com6ea165d2012-07-03 14:52:08 +000054
55 {
56 // Do some subset drawing. This will test that an SkGPipe properly
57 // handles the case where bitmaps share a pixelref
58 // Draw the bottom right fourth of the bitmap over the top left
59 SkBitmap subset;
60 bitmap.extractSubset(&subset, SkIRect::MakeXYWH(x, y, x, y));
61 canvas->drawBitmap(subset, 0, 0);
62 // Draw the top left corner over the bottom right
63 bitmap.extractSubset(&subset, SkIRect::MakeWH(x, y));
64 canvas->drawBitmap(subset, SkIntToScalar(x), SkIntToScalar(y));
65 // Draw a subset which has the same height and pixelref offset but a
66 // different width
67 bitmap.extractSubset(&subset, SkIRect::MakeWH(x, bitmap.height()));
68 SkAutoCanvasRestore autoRestore(canvas, true);
69 canvas->translate(0, SkIntToScalar(bitmap.height() + 20));
70 canvas->drawBitmap(subset, 0, 0);
71 // Now draw a subet which has the same width and pixelref offset but
72 // a different height
73 bitmap.extractSubset(&subset, SkIRect::MakeWH(bitmap.height(), y));
74 canvas->translate(0, SkIntToScalar(bitmap.height() + 20));
75 canvas->drawBitmap(subset, 0, 0);
76 }
junov@google.com61d46a02011-07-28 13:34:31 +000077 }
rmistry@google.comae933ce2012-08-23 18:19:56 +000078
junov@google.com61d46a02011-07-28 13:34:31 +000079private:
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000080 typedef GM INHERITED;
junov@google.com61d46a02011-07-28 13:34:31 +000081};
82
83//////////////////////////////////////////////////////////////////////////////
84
Hal Canarye964c182019-01-23 10:22:01 -050085DEF_GM( return new ExtractBitmapGM; )
scroggo@google.com4f1f6bf2012-07-02 13:35:09 +000086
87}