1 /*
2  * Copyright 2012 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 #ifndef SkPathWriter_DEFINED
8 #define SkPathWriter_DEFINED
9 
10 #include "SkPath.h"
11 #include "SkTArray.h"
12 #include "SkTDArray.h"
13 
14 class SkOpPtT;
15 
16 // Construct the path one contour at a time.
17 // If the contour is closed, copy it to the final output.
18 // Otherwise, keep the partial contour for later assembly.
19 
20 class SkPathWriter {
21 public:
22     SkPathWriter(SkPath& path);
23     void assemble();
24     void conicTo(const SkPoint& pt1, const SkOpPtT* pt2, SkScalar weight);
25     void cubicTo(const SkPoint& pt1, const SkPoint& pt2, const SkOpPtT* pt3);
26     bool deferredLine(const SkOpPtT* pt);
27     void deferredMove(const SkOpPtT* pt);
28     void finishContour();
29     bool hasMove() const { return !fFirstPtT; }
30     void init();
31     bool isClosed() const;
32     const SkPath* nativePath() const { return fPathPtr; }
33     void quadTo(const SkPoint& pt1, const SkOpPtT* pt2);
34 
35 private:
36     bool changedSlopes(const SkOpPtT* pt) const;
37     void close();
38     const SkTDArray<const SkOpPtT*>& endPtTs() const { return fEndPtTs; }
39     void lineTo();
40     bool matchedLast(const SkOpPtT*) const;
41     void moveTo();
42     const SkTArray<SkPath>& partials() const { return fPartials; }
43     bool someAssemblyRequired();
44     SkPoint update(const SkOpPtT* pt);
45 
46     SkPath fCurrent;  // contour under construction
47     SkTArray<SkPath> fPartials;   // contours with mismatched starts and ends
48     SkTDArray<const SkOpPtT*> fEndPtTs;  // possible pt values for partial starts and ends
49     SkPath* fPathPtr;  // closed contours are written here
50     const SkOpPtT* fDefer[2];  // [0] deferred move, [1] deferred line
51     const SkOpPtT* fFirstPtT;  // first in current contour
52 };
53 
54 #endif /* defined(__PathOps__SkPathWriter__) */
55