Index: src/effects/Sk2DPathEffect.cpp |
diff --git a/src/effects/Sk2DPathEffect.cpp b/src/effects/Sk2DPathEffect.cpp |
index 252866c05413bbb3931b299a8076e0d0c6ee7478..cef2266d50b8cfb61f3b9652a7d7f29c44e6a329 100644 |
--- a/src/effects/Sk2DPathEffect.cpp |
+++ b/src/effects/Sk2DPathEffect.cpp |
@@ -73,10 +73,12 @@ void Sk2DPathEffect::flatten(SkWriteBuffer& buffer) const { |
buffer.writeMatrix(fMatrix); |
} |
+#ifdef SK_SUPPORT_LEGACY_DEEPFLATTENING |
Sk2DPathEffect::Sk2DPathEffect(SkReadBuffer& buffer) { |
buffer.readMatrix(&fMatrix); |
fMatrixIsInvertible = fMatrix.invert(&fInverse); |
} |
+#endif |
/////////////////////////////////////////////////////////////////////////////// |
@@ -102,12 +104,21 @@ void SkLine2DPathEffect::nextSpan(int u, int v, int ucount, SkPath* dst) const { |
} |
} |
+#ifdef SK_SUPPORT_LEGACY_DEEPFLATTENING |
SkLine2DPathEffect::SkLine2DPathEffect(SkReadBuffer& buffer) : INHERITED(buffer) { |
fWidth = buffer.readScalar(); |
} |
+#endif |
+ |
+SkFlattenable* SkLine2DPathEffect::CreateProc(SkReadBuffer& buffer) { |
+ SkMatrix matrix; |
+ buffer.readMatrix(&matrix); |
+ SkScalar width = buffer.readScalar(); |
+ return SkLine2DPathEffect::Create(width, matrix); |
+} |
void SkLine2DPathEffect::flatten(SkWriteBuffer &buffer) const { |
- this->INHERITED::flatten(buffer); |
+ buffer.writeMatrix(this->getMatrix()); |
buffer.writeScalar(fWidth); |
} |
@@ -117,13 +128,22 @@ SkPath2DPathEffect::SkPath2DPathEffect(const SkMatrix& m, const SkPath& p) |
: INHERITED(m), fPath(p) { |
} |
-SkPath2DPathEffect::SkPath2DPathEffect(SkReadBuffer& buffer) |
- : INHERITED(buffer) { |
+#ifdef SK_SUPPORT_LEGACY_DEEPFLATTENING |
+SkPath2DPathEffect::SkPath2DPathEffect(SkReadBuffer& buffer) : INHERITED(buffer) { |
buffer.readPath(&fPath); |
} |
+#endif |
+ |
+SkFlattenable* SkPath2DPathEffect::CreateProc(SkReadBuffer& buffer) { |
+ SkMatrix matrix; |
+ buffer.readMatrix(&matrix); |
+ SkPath path; |
+ buffer.readPath(&path); |
+ return SkPath2DPathEffect::Create(matrix, path); |
+} |
void SkPath2DPathEffect::flatten(SkWriteBuffer& buffer) const { |
- this->INHERITED::flatten(buffer); |
+ buffer.writeMatrix(this->getMatrix()); |
buffer.writePath(fPath); |
} |