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 "SkArcToPathEffect.h"
9 #include "SkPath.h"
10 #include "SkPoint.h"
11 #include "SkReadBuffer.h"
12 #include "SkWriteBuffer.h"
13 
SkArcToPathEffect(SkScalar radius)14 SkArcToPathEffect::SkArcToPathEffect(SkScalar radius) : fRadius(radius) {}
15 
filterPath(SkPath * dst,const SkPath & src,SkStrokeRec *,const SkRect *) const16 bool SkArcToPathEffect::filterPath(SkPath* dst, const SkPath& src,
17                                    SkStrokeRec*, const SkRect*) const {
18     SkPath::Iter    iter(src, false);
19     SkPath::Verb    verb;
20     SkPoint         pts[4];
21 
22     SkPoint         lastCorner = { 0, 0 }; // avoid warning
23     SkPath::Verb    prevVerb = SkPath::kMove_Verb;
24 
25     for (;;) {
26         switch (verb = iter.next(pts, false)) {
27             case SkPath::kMove_Verb:
28                 if (SkPath::kLine_Verb == prevVerb) {
29                     dst->lineTo(lastCorner);
30                 }
31                 dst->moveTo(pts[0]);
32                 break;
33             case SkPath::kLine_Verb:
34                 if (prevVerb == SkPath::kLine_Verb) {
35                     dst->arcTo(pts[0], pts[1], fRadius);
36                 }
37                 lastCorner = pts[1];
38                 break;
39             case SkPath::kQuad_Verb:
40                 dst->quadTo(pts[1], pts[2]);
41                 lastCorner = pts[2];
42                 break;
43             case SkPath::kConic_Verb:
44                 dst->conicTo(pts[1], pts[2], iter.conicWeight());
45                 lastCorner = pts[2];
46                 break;
47             case SkPath::kCubic_Verb:
48                 dst->cubicTo(pts[1], pts[2], pts[3]);
49                 lastCorner = pts[3];
50                 break;
51             case SkPath::kClose_Verb:
52                 dst->lineTo(lastCorner);
53                 break;
54             case SkPath::kDone_Verb:
55                 dst->lineTo(lastCorner);
56                 goto DONE;
57         }
58         prevVerb = verb;
59     }
60 DONE:
61     return true;
62 }
63 
CreateProc(SkReadBuffer & buffer)64 sk_sp<SkFlattenable> SkArcToPathEffect::CreateProc(SkReadBuffer& buffer) {
65     return SkArcToPathEffect::Make(buffer.readScalar());
66 }
67 
flatten(SkWriteBuffer & buffer) const68 void SkArcToPathEffect::flatten(SkWriteBuffer& buffer) const {
69     buffer.writeScalar(fRadius);
70 }
71 
72 #ifndef SK_IGNORE_TO_STRING
toString(SkString * str) const73 void SkArcToPathEffect::toString(SkString* str) const {
74     str->appendf("SkArcToPathEffect: (");
75     str->appendf("radius: %f", fRadius);
76     str->appendf(")");
77 }
78 #endif
79