blob: a336cf669da136b1577c437202c6eb0ff3bf12f3 [file] [log] [blame]
robertphillipsb6c65e92016-02-04 10:52:42 -08001/*
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
Florin Malitaab244f02017-05-03 19:16:58 +00008#include "SkBitmap.h"
robertphillipsb6c65e92016-02-04 10:52:42 -08009#include "SkCanvas.h"
10#include "SkSpecialImage.h"
11#include "SkSpecialSurface.h"
12#include "Test.h"
13
14#if SK_SUPPORT_GPU
15#include "GrContext.h"
16#include "SkGr.h"
17#endif
18
19class TestingSpecialSurfaceAccess {
20public:
21 static const SkIRect& Subset(const SkSpecialSurface* surf) {
22 return surf->subset();
23 }
robertphillipsb6c65e92016-02-04 10:52:42 -080024};
25
26// Both 'kSmallerSize' and 'kFullSize' need to be a non-power-of-2 to exercise
27// the gpu's loose fit behavior
28static const int kSmallerSize = 10;
29static const int kPad = 5;
30static const int kFullSize = kSmallerSize + 2 * kPad;
31
32// Exercise the public API of SkSpecialSurface (e.g., getCanvas, newImageSnapshot)
robertphillips37bd7c32016-03-17 14:31:39 -070033static void test_surface(const sk_sp<SkSpecialSurface>& surf,
34 skiatest::Reporter* reporter,
35 int offset) {
robertphillipsb6c65e92016-02-04 10:52:42 -080036
robertphillips37bd7c32016-03-17 14:31:39 -070037 const SkIRect surfSubset = TestingSpecialSurfaceAccess::Subset(surf.get());
robertphillipsb6c65e92016-02-04 10:52:42 -080038 REPORTER_ASSERT(reporter, offset == surfSubset.fLeft);
39 REPORTER_ASSERT(reporter, offset == surfSubset.fTop);
40 REPORTER_ASSERT(reporter, kSmallerSize == surfSubset.width());
41 REPORTER_ASSERT(reporter, kSmallerSize == surfSubset.height());
42
43 SkCanvas* canvas = surf->getCanvas();
44 SkASSERT_RELEASE(canvas);
45
46 canvas->clear(SK_ColorRED);
47
robertphillips37bd7c32016-03-17 14:31:39 -070048 sk_sp<SkSpecialImage> img(surf->makeImageSnapshot());
robertphillipsb6c65e92016-02-04 10:52:42 -080049 REPORTER_ASSERT(reporter, img);
50
robertphillips3e302272016-04-20 11:48:36 -070051 const SkIRect imgSubset = img->subset();
robertphillipsb6c65e92016-02-04 10:52:42 -080052 REPORTER_ASSERT(reporter, surfSubset == imgSubset);
53
54 // the canvas was invalidated by the newImageSnapshot call
55 REPORTER_ASSERT(reporter, !surf->getCanvas());
56}
57
58DEF_TEST(SpecialSurface_Raster, reporter) {
59
60 SkImageInfo info = SkImageInfo::MakeN32(kSmallerSize, kSmallerSize, kOpaque_SkAlphaType);
robertphillips3e302272016-04-20 11:48:36 -070061 sk_sp<SkSpecialSurface> surf(SkSpecialSurface::MakeRaster(info));
robertphillipsb6c65e92016-02-04 10:52:42 -080062
63 test_surface(surf, reporter, 0);
64}
65
66DEF_TEST(SpecialSurface_Raster2, reporter) {
67
68 SkBitmap bm;
69 bm.allocN32Pixels(kFullSize, kFullSize, true);
70
71 const SkIRect subset = SkIRect::MakeXYWH(kPad, kPad, kSmallerSize, kSmallerSize);
72
robertphillips3e302272016-04-20 11:48:36 -070073 sk_sp<SkSpecialSurface> surf(SkSpecialSurface::MakeFromBitmap(subset, bm));
robertphillipsb6c65e92016-02-04 10:52:42 -080074
75 test_surface(surf, reporter, kPad);
76
77 // TODO: check that the clear didn't escape the active region
78}
79
80#if SK_SUPPORT_GPU
81
egdanielab527a52016-06-28 08:07:26 -070082DEF_GPUTEST_FOR_RENDERING_CONTEXTS(SpecialSurface_Gpu1, reporter, ctxInfo) {
bsalomon8b7451a2016-05-11 06:33:06 -070083 sk_sp<SkSpecialSurface> surf(SkSpecialSurface::MakeRenderTarget(ctxInfo.grContext(),
robertphillips4df16562016-04-28 15:09:34 -070084 kSmallerSize, kSmallerSize,
Brian Osman777b5632016-10-14 09:16:21 -040085 kRGBA_8888_GrPixelConfig,
brianosmandfe4f2e2016-07-21 13:28:36 -070086 nullptr));
robertphillipsb6c65e92016-02-04 10:52:42 -080087
88 test_surface(surf, reporter, 0);
89}
90
robertphillipsb6c65e92016-02-04 10:52:42 -080091#endif