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

Side by Side Diff: src/record/SkRecorder.cpp

Issue 231653002: SkRecordDraw: skip draw ops when the clip is empty (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: pop cull unconditionally 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
« no previous file with comments | « src/record/SkRecorder.h ('k') | tests/RecordCullingTest.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #include "SkRecorder.h" 1 #include "SkRecorder.h"
2 #include "SkPicture.h" 2 #include "SkPicture.h"
3 3
4 // SkCanvas will fail in mysterious ways if it doesn't know the real width and h eight. 4 // SkCanvas will fail in mysterious ways if it doesn't know the real width and h eight.
5 SkRecorder::SkRecorder(SkRecord* record, int width, int height) 5 SkRecorder::SkRecorder(SkRecorder::Mode mode, SkRecord* record, int width, int h eight)
6 : SkCanvas(width, height), fRecord(record) {} 6 : SkCanvas(width, height), fMode(mode), fRecord(record) {}
7 7
8 // To make appending to fRecord a little less verbose. 8 // To make appending to fRecord a little less verbose.
9 #define APPEND(T, ...) \ 9 #define APPEND(T, ...) \
10 SkNEW_PLACEMENT_ARGS(fRecord->append<SkRecords::T>(), SkRecords::T, (__V A_ARGS__)) 10 SkNEW_PLACEMENT_ARGS(fRecord->append<SkRecords::T>(), SkRecords::T, (__V A_ARGS__))
11 11
12 // For methods which must call back into SkCanvas in kReadWrite_Mode.
13 #define INHERITED(method, ...) if (fMode == kReadWrite_Mode) this->SkCanvas::met hod(__VA_ARGS__)
14
12 // The structs we're creating all copy their constructor arguments. Given the w ay the SkRecords 15 // The structs we're creating all copy their constructor arguments. Given the w ay the SkRecords
13 // framework works, sometimes they happen to technically be copied twice, which is fine and elided 16 // framework works, sometimes they happen to technically be copied twice, which is fine and elided
14 // into a single copy unless the class has a non-trivial copy constructor. For classes with 17 // into a single copy unless the class has a non-trivial copy constructor. For classes with
15 // non-trivial copy constructors, we skip the first copy (and its destruction) b y wrapping the value 18 // non-trivial copy constructors, we skip the first copy (and its destruction) b y wrapping the value
16 // with delay_copy(), forcing the argument to be passed by const&. 19 // with delay_copy(), forcing the argument to be passed by const&.
17 // 20 //
18 // This is used below for SkBitmap, SkPaint, SkPath, and SkRegion, which all hav e non-trivial copy 21 // This is used below for SkBitmap, SkPaint, SkPath, and SkRegion, which all hav e non-trivial copy
19 // constructors and destructors. You'll know you've got a good candidate T if y ou see ~T() show up 22 // constructors and destructors. You'll know you've got a good candidate T if y ou see ~T() show up
20 // unexpectedly on a profile of record time. Otherwise don't bother. 23 // unexpectedly on a profile of record time. Otherwise don't bother.
21 template <typename T> 24 template <typename T>
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after
87 } 90 }
88 91
89 void SkRecorder::drawOval(const SkRect& oval, const SkPaint& paint) { 92 void SkRecorder::drawOval(const SkRect& oval, const SkPaint& paint) {
90 APPEND(DrawOval, oval, delay_copy(paint)); 93 APPEND(DrawOval, oval, delay_copy(paint));
91 } 94 }
92 95
93 void SkRecorder::drawRRect(const SkRRect& rrect, const SkPaint& paint) { 96 void SkRecorder::drawRRect(const SkRRect& rrect, const SkPaint& paint) {
94 APPEND(DrawRRect, rrect, delay_copy(paint)); 97 APPEND(DrawRRect, rrect, delay_copy(paint));
95 } 98 }
96 99
100 void SkRecorder::onDrawDRRect(const SkRRect& outer, const SkRRect& inner, const SkPaint& paint) {
101 APPEND(DrawDRRect, outer, inner, delay_copy(paint));
102 }
103
97 void SkRecorder::drawPath(const SkPath& path, const SkPaint& paint) { 104 void SkRecorder::drawPath(const SkPath& path, const SkPaint& paint) {
98 APPEND(DrawPath, delay_copy(path), delay_copy(paint)); 105 APPEND(DrawPath, delay_copy(path), delay_copy(paint));
99 } 106 }
100 107
101 void SkRecorder::drawBitmap(const SkBitmap& bitmap, 108 void SkRecorder::drawBitmap(const SkBitmap& bitmap,
102 SkScalar left, 109 SkScalar left,
103 SkScalar top, 110 SkScalar top,
104 const SkPaint* paint) { 111 const SkPaint* paint) {
105 APPEND(DrawBitmap, delay_copy(bitmap), left, top, this->copy(paint)); 112 APPEND(DrawBitmap, delay_copy(bitmap), left, top, this->copy(paint));
106 } 113 }
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
175 texs ? this->copy(texs, vertexCount) : NULL, 182 texs ? this->copy(texs, vertexCount) : NULL,
176 colors ? this->copy(colors, vertexCount) : NULL, 183 colors ? this->copy(colors, vertexCount) : NULL,
177 xmode, 184 xmode,
178 this->copy(indices, indexCount), 185 this->copy(indices, indexCount),
179 indexCount, 186 indexCount,
180 delay_copy(paint)); 187 delay_copy(paint));
181 } 188 }
182 189
183 void SkRecorder::willSave(SkCanvas::SaveFlags flags) { 190 void SkRecorder::willSave(SkCanvas::SaveFlags flags) {
184 APPEND(Save, flags); 191 APPEND(Save, flags);
192 INHERITED(willSave, flags);
185 } 193 }
186 194
187 SkCanvas::SaveLayerStrategy SkRecorder::willSaveLayer(const SkRect* bounds, 195 SkCanvas::SaveLayerStrategy SkRecorder::willSaveLayer(const SkRect* bounds,
188 const SkPaint* paint, 196 const SkPaint* paint,
189 SkCanvas::SaveFlags flags) { 197 SkCanvas::SaveFlags flags) {
190 APPEND(SaveLayer, this->copy(bounds), this->copy(paint), flags); 198 APPEND(SaveLayer, this->copy(bounds), this->copy(paint), flags);
199 INHERITED(willSaveLayer, bounds, paint, flags);
191 return SkCanvas::kNoLayer_SaveLayerStrategy; 200 return SkCanvas::kNoLayer_SaveLayerStrategy;
192 } 201 }
193 202
194 void SkRecorder::willRestore() { 203 void SkRecorder::willRestore() {
195 APPEND(Restore); 204 APPEND(Restore);
205 INHERITED(willRestore);
196 } 206 }
197 207
198 void SkRecorder::onPushCull(const SkRect& rect) { 208 void SkRecorder::onPushCull(const SkRect& rect) {
199 APPEND(PushCull, rect, SkRecords::kUnsetPopOffset); 209 APPEND(PushCull, rect, SkRecords::kUnsetPopOffset);
200 } 210 }
201 211
202 void SkRecorder::onPopCull() { 212 void SkRecorder::onPopCull() {
203 APPEND(PopCull); 213 APPEND(PopCull);
204 } 214 }
205 215
206 void SkRecorder::didConcat(const SkMatrix& matrix) { 216 void SkRecorder::didConcat(const SkMatrix& matrix) {
207 APPEND(Concat, matrix); 217 APPEND(Concat, matrix);
218 INHERITED(didConcat, matrix);
208 } 219 }
209 220
210 void SkRecorder::didSetMatrix(const SkMatrix& matrix) { 221 void SkRecorder::didSetMatrix(const SkMatrix& matrix) {
211 APPEND(SetMatrix, matrix); 222 APPEND(SetMatrix, matrix);
212 } 223 INHERITED(didSetMatrix, matrix);
213
214 void SkRecorder::onDrawDRRect(const SkRRect& outer, const SkRRect& inner, const SkPaint& paint) {
215 APPEND(DrawDRRect, outer, inner, delay_copy(paint));
216 } 224 }
217 225
218 void SkRecorder::onClipRect(const SkRect& rect, SkRegion::Op op, ClipEdgeStyle e dgeStyle) { 226 void SkRecorder::onClipRect(const SkRect& rect, SkRegion::Op op, ClipEdgeStyle e dgeStyle) {
219 APPEND(ClipRect, rect, op, edgeStyle == kSoft_ClipEdgeStyle); 227 APPEND(ClipRect, rect, op, edgeStyle == kSoft_ClipEdgeStyle);
228 INHERITED(onClipRect, rect, op, edgeStyle);
220 } 229 }
221 230
222 void SkRecorder::onClipRRect(const SkRRect& rrect, SkRegion::Op op, ClipEdgeStyl e edgeStyle) { 231 void SkRecorder::onClipRRect(const SkRRect& rrect, SkRegion::Op op, ClipEdgeStyl e edgeStyle) {
223 APPEND(ClipRRect, rrect, op, edgeStyle == kSoft_ClipEdgeStyle); 232 APPEND(ClipRRect, rrect, op, edgeStyle == kSoft_ClipEdgeStyle);
233 INHERITED(updateClipConservativelyUsingBounds, rrect.getBounds(), op, false) ;
224 } 234 }
225 235
226 void SkRecorder::onClipPath(const SkPath& path, SkRegion::Op op, ClipEdgeStyle e dgeStyle) { 236 void SkRecorder::onClipPath(const SkPath& path, SkRegion::Op op, ClipEdgeStyle e dgeStyle) {
227 APPEND(ClipPath, delay_copy(path), op, edgeStyle == kSoft_ClipEdgeStyle); 237 APPEND(ClipPath, delay_copy(path), op, edgeStyle == kSoft_ClipEdgeStyle);
238 INHERITED(updateClipConservativelyUsingBounds, path.getBounds(), op, path.is InverseFillType());
228 } 239 }
229 240
230 void SkRecorder::onClipRegion(const SkRegion& deviceRgn, SkRegion::Op op) { 241 void SkRecorder::onClipRegion(const SkRegion& deviceRgn, SkRegion::Op op) {
231 APPEND(ClipRegion, delay_copy(deviceRgn), op); 242 APPEND(ClipRegion, delay_copy(deviceRgn), op);
243 INHERITED(onClipRegion, deviceRgn, op);
232 } 244 }
OLDNEW
« no previous file with comments | « src/record/SkRecorder.h ('k') | tests/RecordCullingTest.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698