blob: 2a2bf034e4eec190934e8f5d7cb86b928e100156 [file] [log] [blame]
caryclark@google.com07393ca2013-04-08 11:47:37 +00001/*
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 SkOpEdgeBuilder_DEFINED
8#define SkOpEdgeBuilder_DEFINED
9
10#include "SkOpContour.h"
11#include "SkPathWriter.h"
12#include "SkTArray.h"
caryclark@google.com07393ca2013-04-08 11:47:37 +000013
14class SkOpEdgeBuilder {
15public:
16 SkOpEdgeBuilder(const SkPathWriter& path, SkTArray<SkOpContour>& contours)
17 : fPath(path.nativePath())
caryclark@google.com66560ca2013-04-26 19:51:16 +000018 , fContours(contours)
19 , fAllowOpenContours(true) {
caryclark@google.com07393ca2013-04-08 11:47:37 +000020 init();
21 }
22
23 SkOpEdgeBuilder(const SkPath& path, SkTArray<SkOpContour>& contours)
24 : fPath(&path)
caryclark@google.com66560ca2013-04-26 19:51:16 +000025 , fContours(contours)
26 , fAllowOpenContours(false) {
caryclark@google.com07393ca2013-04-08 11:47:37 +000027 init();
28 }
29
30 void complete() {
31 if (fCurrentContour && fCurrentContour->segments().count()) {
32 fCurrentContour->complete();
33 fCurrentContour = NULL;
34 }
35 }
36
37 SkPathOpsMask xorMask() const {
38 return fXorMask[fOperand];
39 }
40
41 void addOperand(const SkPath& path);
caryclark@google.com66560ca2013-04-26 19:51:16 +000042 bool finish();
caryclark@google.com07393ca2013-04-08 11:47:37 +000043 void init();
44
45private:
caryclark@google.com66560ca2013-04-26 19:51:16 +000046 bool close();
caryclark@google.com07393ca2013-04-08 11:47:37 +000047 int preFetch();
caryclark@google.com66560ca2013-04-26 19:51:16 +000048 bool walk();
caryclark@google.com07393ca2013-04-08 11:47:37 +000049
50 const SkPath* fPath;
caryclark@google.comd892bd82013-06-17 14:10:36 +000051 SkTArray<SkPoint, true> fPathPts;
52 SkTArray<uint8_t, true> fPathVerbs;
caryclark@google.com07393ca2013-04-08 11:47:37 +000053 SkOpContour* fCurrentContour;
54 SkTArray<SkOpContour>& fContours;
caryclark@google.comd892bd82013-06-17 14:10:36 +000055 SkTArray<SkPoint, true> fReducePts; // segments created on the fly
56 SkTArray<int, true> fExtra; // -1 marks new contour, > 0 offsets into contour
caryclark@google.com07393ca2013-04-08 11:47:37 +000057 SkPathOpsMask fXorMask[2];
caryclark@google.com66560ca2013-04-26 19:51:16 +000058 const SkPoint* fFinalCurveStart;
59 const SkPoint* fFinalCurveEnd;
caryclark@google.com07393ca2013-04-08 11:47:37 +000060 int fSecondHalf;
61 bool fOperand;
caryclark@google.com66560ca2013-04-26 19:51:16 +000062 bool fAllowOpenContours;
63 bool fUnparseable;
caryclark@google.com07393ca2013-04-08 11:47:37 +000064};
65
66#endif