OLD | NEW |
1 #include "DMQuiltTask.h" | 1 #include "DMQuiltTask.h" |
2 #include "DMUtil.h" | 2 #include "DMUtil.h" |
3 #include "DMWriteTask.h" | 3 #include "DMWriteTask.h" |
4 | 4 |
5 #include "SkBBHFactory.h" | 5 #include "SkBBHFactory.h" |
6 #include "SkCommandLineFlags.h" | 6 #include "SkCommandLineFlags.h" |
7 #include "SkPicture.h" | 7 #include "SkPicture.h" |
8 #include "SkThreadPool.h" | 8 #include "SkThreadPool.h" |
9 | 9 |
10 DEFINE_bool(quilt, true, "If true, draw GM via a picture into a quilt of small t
iles and compare."); | 10 DEFINE_bool(quilt, true, "If true, draw GM via a picture into a quilt of small t
iles and compare."); |
11 DEFINE_int32(quiltTile, 256, "Dimension of (square) quilt tile."); | 11 DEFINE_int32(quiltTile, 256, "Dimension of (square) quilt tile."); |
12 | 12 |
13 static const char* kSuffixes[] = { "nobbh", "rtree", "quadtree", "tilegrid", "sk
r" }; | |
14 | |
15 namespace DM { | 13 namespace DM { |
16 | 14 |
17 QuiltTask::QuiltTask(const Task& parent, skiagm::GM* gm, SkBitmap reference, Qui
ltTask::Mode mode) | 15 static SkString suffix(QuiltTask::Backend backend, QuiltTask::BBH bbh) { |
| 16 static const char* kBackends[] = { "default", "skrecord" }; |
| 17 static const char* kBBHs[] = { "nobbh", "rtree", "quadtree", "tilegrid"
}; |
| 18 return SkStringPrintf("%s-%s", kBackends[backend], kBBHs[bbh]); |
| 19 } |
| 20 |
| 21 QuiltTask::QuiltTask(const Task& parent, skiagm::GM* gm, SkBitmap reference, |
| 22 QuiltTask::BBH bbh, QuiltTask::Backend backend) |
18 : CpuTask(parent) | 23 : CpuTask(parent) |
19 , fMode(mode) | 24 , fBBH(bbh) |
20 , fName(UnderJoin(parent.name().c_str(), kSuffixes[mode])) | 25 , fBackend(backend) |
| 26 , fName(UnderJoin(parent.name().c_str(), suffix(backend, bbh).c_str())) |
21 , fGM(gm) | 27 , fGM(gm) |
22 , fReference(reference) | 28 , fReference(reference) |
23 {} | 29 {} |
24 | 30 |
25 static int tiles_needed(int fullDimension, int tileDimension) { | 31 static int tiles_needed(int fullDimension, int tileDimension) { |
26 return (fullDimension + tileDimension - 1) / tileDimension; | 32 return (fullDimension + tileDimension - 1) / tileDimension; |
27 } | 33 } |
28 | 34 |
29 class Tile : public SkRunnable { | 35 class Tile : public SkRunnable { |
30 public: | 36 public: |
(...skipping 16 matching lines...) Expand all Loading... |
47 } | 53 } |
48 | 54 |
49 private: | 55 private: |
50 const int fX, fY; | 56 const int fX, fY; |
51 const SkPicture& fPicture; | 57 const SkPicture& fPicture; |
52 SkBitmap* fQuilt; | 58 SkBitmap* fQuilt; |
53 }; | 59 }; |
54 | 60 |
55 void QuiltTask::draw() { | 61 void QuiltTask::draw() { |
56 SkAutoTDelete<SkBBHFactory> factory; | 62 SkAutoTDelete<SkBBHFactory> factory; |
57 switch (fMode) { | 63 switch (fBBH) { |
58 case kRTree_Mode: | 64 case kNone_BBH: break; |
| 65 case kRTree_BBH: |
59 factory.reset(SkNEW(SkRTreeFactory)); | 66 factory.reset(SkNEW(SkRTreeFactory)); |
60 break; | 67 break; |
61 case kQuadTree_Mode: | 68 case kQuadTree_BBH: |
62 factory.reset(SkNEW(SkQuadTreeFactory)); | 69 factory.reset(SkNEW(SkQuadTreeFactory)); |
63 break; | 70 break; |
64 case kTileGrid_Mode: { | 71 case kTileGrid_BBH: { |
65 const SkTileGridFactory::TileGridInfo tiles = { | 72 const SkTileGridFactory::TileGridInfo tiles = { |
66 { FLAGS_quiltTile, FLAGS_quiltTile }, | 73 { FLAGS_quiltTile, FLAGS_quiltTile }, |
67 /*overlap: */{0, 0}, | 74 /*overlap: */{0, 0}, |
68 /*offset: */{0, 0}, | 75 /*offset: */{0, 0}, |
69 }; | 76 }; |
70 factory.reset(SkNEW_ARGS(SkTileGridFactory, (tiles))); | 77 factory.reset(SkNEW_ARGS(SkTileGridFactory, (tiles))); |
71 break; | 78 break; |
72 } | 79 } |
73 | |
74 case kNoBBH_Mode: | |
75 case kSkRecord_Mode: | |
76 break; | |
77 } | 80 } |
78 | 81 |
79 // A couple GMs draw wrong when using a bounding box hierarchy. | 82 // A couple GMs draw wrong when using a bounding box hierarchy. |
80 // This almost certainly means we have a bug to fix, but for now | 83 // This almost certainly means we have a bug to fix, but for now |
81 // just draw without a bounding box hierarchy. | 84 // just draw without a bounding box hierarchy. |
82 if (fGM->getFlags() & skiagm::GM::kNoBBH_Flag) { | 85 if (fGM->getFlags() & skiagm::GM::kNoBBH_Flag) { |
83 factory.reset(NULL); | 86 factory.reset(NULL); |
84 } | 87 } |
85 | 88 |
86 SkAutoTUnref<const SkPicture> recorded( | 89 SkAutoTUnref<const SkPicture> recorded( |
87 RecordPicture(fGM.get(), factory.get(), kSkRecord_Mode == fMode)); | 90 RecordPicture(fGM.get(), factory.get(), kSkRecord_Backend == fBacken
d)); |
88 | 91 |
89 SkBitmap full; | 92 SkBitmap full; |
90 AllocatePixels(fReference, &full); | 93 AllocatePixels(fReference, &full); |
91 | 94 |
92 if (fGM->getFlags() & skiagm::GM::kSkipTiled_Flag) { | 95 if (fGM->getFlags() & skiagm::GM::kSkipTiled_Flag) { |
93 // Some GMs don't draw exactly the same when tiled. Draw them in one go
. | 96 // Some GMs don't draw exactly the same when tiled. Draw them in one go
. |
94 SkCanvas canvas(full); | 97 SkCanvas canvas(full); |
95 recorded->draw(&canvas); | 98 recorded->draw(&canvas); |
96 canvas.flush(); | 99 canvas.flush(); |
97 } else { | 100 } else { |
(...skipping 14 matching lines...) Expand all Loading... |
112 } | 115 } |
113 | 116 |
114 bool QuiltTask::shouldSkip() const { | 117 bool QuiltTask::shouldSkip() const { |
115 if (fGM->getFlags() & skiagm::GM::kSkipPicture_Flag) { | 118 if (fGM->getFlags() & skiagm::GM::kSkipPicture_Flag) { |
116 return true; | 119 return true; |
117 } | 120 } |
118 return !FLAGS_quilt; | 121 return !FLAGS_quilt; |
119 } | 122 } |
120 | 123 |
121 } // namespace DM | 124 } // namespace DM |
OLD | NEW |