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

Side by Side Diff: tests/PictureStateTreeTest.cpp

Issue 246893005: Refactor SkPictureStateTree::Iterator to avoid use of kClip_SaveFlag. (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: http://crbug.com/366889 fix + test Created 6 years, 8 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 /*
2 * Copyright 2014 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 "SkBBHFactory.h"
9 #include "SkCanvas.h"
10 #include "SkPictureRecorder.h"
11 #include "SkPictureStateTree.h"
12 #include "Test.h"
13
14 static SkPicture* draw_scene(SkBBHFactory* bbhFactory) {
15 SkPictureRecorder recorder;
16 SkCanvas* canvas = recorder.beginRecording(200, 200, bbhFactory, 0);
17
18 SkPaint p1, p2, p3;
19 p1.setStyle(SkPaint::kFill_Style);
20 p1.setColor(SK_ColorGREEN);
21 p2.setStyle(SkPaint::kFill_Style);
22 p2.setColor(SK_ColorBLUE);
23 p3.setXfermodeMode(SkXfermode::kColorBurn_Mode);
Justin Novosad 2014/04/25 22:43:41 This is a rarely use xfer mode. Any reason the tes
f(malita) 2014/04/28 13:10:25 Just wanted an xfer mode where the result is a fun
24
25 canvas->drawColor(SK_ColorWHITE);
26
27 canvas->save();
28 canvas->translate(10, 10);
29
30 canvas->drawRect(SkRect::MakeWH(100, 50), p1);
31 canvas->drawRect(SkRect::MakeWH(50, 100), p2);
32
33 SkRect layerBounds = SkRect::MakeXYWH(0, 0, 90, 90);
34 canvas->saveLayer(&layerBounds, &p3);
35 canvas->save();
36 canvas->clipRect(layerBounds);
37
38 canvas->save();
39 canvas->clipRect(SkRect::MakeWH(25, 25));
40 canvas->rotate(90);
41 canvas->drawRect(SkRect::MakeWH(100, 50), p1);
42 canvas->restore();
43
44 canvas->save();
45 canvas->clipRect(SkRect::MakeWH(25, 25));
46 canvas->save();
47 canvas->rotate(90);
48 canvas->drawRect(SkRect::MakeWH(50, 100), p2);
49 canvas->restore();
50 canvas->drawRect(SkRect::MakeWH(100, 50), p1);
51 canvas->restore();
52 canvas->drawRect(SkRect::MakeXYWH(99, 99, 1, 1), p1);
53 canvas->restore();
54 canvas->restore();
55
56 canvas->restore();
57
58 return recorder.endRecording();
59 }
60
61 static void check_bms(skiatest::Reporter* reporter, const SkBitmap& bm1, const S kBitmap& bm2) {
62 SkASSERT(bm1.width() == bm2.width());
63 SkASSERT(bm1.height() == bm2.height());
64
65 for (int x = 0; x < bm1.width(); ++x) {
66 for (int y = 0; y < bm1.height(); ++y) {
67 REPORTER_ASSERT(reporter, *bm1.getAddr32(x, y) == *bm2.getAddr32(x, y));
Justin Novosad 2014/04/25 22:43:41 why not just a memcmp on the whole buffer. I am j
f(malita) 2014/04/28 13:10:25 Good point, done.
68 }
69 }
70 }
71
72 static void test_reference_picture(skiatest::Reporter* reporter) {
73 SkRTreeFactory bbhFactory;
74
75 SkAutoTUnref<SkPicture> bbhPicture(draw_scene(&bbhFactory));
76 SkAutoTUnref<SkPicture> referencePicture(draw_scene(NULL));
77
78 SkBitmap referenceBitmap;
79 referenceBitmap.allocN32Pixels(100, 100);
80 SkCanvas referenceCanvas(referenceBitmap);
81
82 SkBitmap bbhBitmap;
83 bbhBitmap.allocN32Pixels(100, 100);
84 SkCanvas bbhCanvas(bbhBitmap);
85
86 referenceCanvas.drawColor(SK_ColorTRANSPARENT);
87 referenceCanvas.drawPicture(*referencePicture.get());
88 bbhCanvas.drawColor(SK_ColorTRANSPARENT);
89 bbhCanvas.drawPicture(*bbhPicture.get());
90 REPORTER_ASSERT(reporter,
91 referenceCanvas.getSaveCount() == bbhCanvas.getSaveCount());
92 REPORTER_ASSERT(reporter,
93 referenceCanvas.getTotalMatrix() == bbhCanvas.getTotalMatrix ());
94 check_bms(reporter, referenceBitmap, bbhBitmap);
95
96 referenceCanvas.drawColor(SK_ColorTRANSPARENT);
97 referenceCanvas.clipRect(SkRect::MakeWH(50, 50));
98 referenceCanvas.drawPicture(*referencePicture.get());
99 bbhCanvas.drawColor(SK_ColorTRANSPARENT);
100 bbhCanvas.clipRect(SkRect::MakeWH(50, 50));
101 bbhCanvas.drawPicture(*bbhPicture.get());
102 REPORTER_ASSERT(reporter,
103 referenceCanvas.getSaveCount() == bbhCanvas.getSaveCount());
104 REPORTER_ASSERT(reporter,
105 referenceCanvas.getTotalMatrix() == bbhCanvas.getTotalMatrix ());
106 check_bms(reporter, referenceBitmap, bbhBitmap);
107
108 referenceCanvas.drawColor(SK_ColorTRANSPARENT);
109 referenceCanvas.clipRect(SkRect::MakeWH(10, 10));
110 referenceCanvas.drawPicture(*referencePicture.get());
111 bbhCanvas.drawColor(SK_ColorTRANSPARENT);
112 bbhCanvas.clipRect(SkRect::MakeWH(10, 10));
113 bbhCanvas.drawPicture(*bbhPicture.get());
114 REPORTER_ASSERT(reporter,
115 referenceCanvas.getSaveCount() == bbhCanvas.getSaveCount());
116 REPORTER_ASSERT(reporter,
117 referenceCanvas.getTotalMatrix() == bbhCanvas.getTotalMatrix ());
118 check_bms(reporter, referenceBitmap, bbhBitmap);
119 }
120
121 DEF_TEST(PictureStateTree, reporter) {
122 test_reference_picture(reporter);
123 }
OLDNEW
« src/core/SkPictureStateTree.cpp ('K') | « src/core/SkPictureStateTree.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698