OLD | NEW |
1 #include "DMUtil.h" | 1 #include "DMUtil.h" |
2 | 2 |
3 #include "SkPicture.h" | 3 #include "SkPicture.h" |
4 | 4 |
5 namespace DM { | 5 namespace DM { |
6 | 6 |
7 SkString UnderJoin(const char* a, const char* b) { | 7 SkString UnderJoin(const char* a, const char* b) { |
8 SkString s; | 8 SkString s; |
9 s.appendf("%s_%s", a, b); | 9 s.appendf("%s_%s", a, b); |
10 return s; | 10 return s; |
11 } | 11 } |
12 | 12 |
13 SkString Png(SkString s) { | 13 SkString Png(SkString s) { |
14 s.appendf(".png"); | 14 s.appendf(".png"); |
15 return s; | 15 return s; |
16 } | 16 } |
17 | 17 |
18 bool MeetsExpectations(const skiagm::Expectations& expectations, const SkBitmap
bitmap) { | |
19 if (expectations.ignoreFailure() || expectations.empty()) { | |
20 return true; | |
21 } | |
22 const skiagm::GmResultDigest digest(bitmap); | |
23 return expectations.match(digest); | |
24 } | |
25 | |
26 void RecordPicture(skiagm::GM* gm, SkPicture* picture, uint32_t recordFlags) { | 18 void RecordPicture(skiagm::GM* gm, SkPicture* picture, uint32_t recordFlags) { |
27 SkCanvas* canvas = picture->beginRecording(SkScalarCeilToInt(gm->width()), | 19 const SkISize size = gm->getISize(); |
28 SkScalarCeilToInt(gm->height()), | 20 SkCanvas* canvas = picture->beginRecording(size.width(), size.height(), reco
rdFlags); |
29 recordFlags); | |
30 canvas->concat(gm->getInitialTransform()); | 21 canvas->concat(gm->getInitialTransform()); |
31 gm->draw(canvas); | 22 gm->draw(canvas); |
32 canvas->flush(); | 23 canvas->flush(); |
33 picture->endRecording(); | 24 picture->endRecording(); |
34 } | 25 } |
35 | 26 |
36 void SetupBitmap(const SkBitmap::Config config, skiagm::GM* gm, SkBitmap* bitmap
) { | 27 void SetupBitmap(const SkBitmap::Config config, skiagm::GM* gm, SkBitmap* bitmap
) { |
37 bitmap->setConfig(config, SkScalarCeilToInt(gm->width()), SkScalarCeilToInt(
gm->height())); | 28 const SkISize size = gm->getISize(); |
| 29 bitmap->setConfig(config, size.width(), size.height()); |
38 bitmap->allocPixels(); | 30 bitmap->allocPixels(); |
39 bitmap->eraseColor(0x00000000); | 31 bitmap->eraseColor(0x00000000); |
40 } | 32 } |
41 | 33 |
42 void DrawPicture(SkPicture* picture, SkBitmap* bitmap) { | 34 void DrawPicture(SkPicture* picture, SkBitmap* bitmap) { |
43 SkASSERT(picture != NULL); | 35 SkASSERT(picture != NULL); |
44 SkASSERT(bitmap != NULL); | 36 SkASSERT(bitmap != NULL); |
45 SkCanvas canvas(*bitmap); | 37 SkCanvas canvas(*bitmap); |
46 canvas.drawPicture(*picture); | 38 canvas.drawPicture(*picture); |
47 canvas.flush(); | 39 canvas.flush(); |
48 } | 40 } |
49 | 41 |
50 bool BitmapsEqual(const SkBitmap& a, const SkBitmap& b) { | 42 bool BitmapsEqual(const SkBitmap& a, const SkBitmap& b) { |
51 const SkAutoLockPixels lockA(a), lockB(b); | 43 const SkAutoLockPixels lockA(a), lockB(b); |
52 return a.getSize() == b.getSize() && 0 == memcmp(a.getPixels(), b.getPixels(
), b.getSize()); | 44 return a.getSize() == b.getSize() && 0 == memcmp(a.getPixels(), b.getPixels(
), b.getSize()); |
53 } | 45 } |
54 | 46 |
55 } // namespace DM | 47 } // namespace DM |
OLD | NEW |