/* * Copyright 2012 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #ifndef SkOpEdgeBuilder_DEFINED #define SkOpEdgeBuilder_DEFINED #include "SkOpContour.h" #include "SkPathWriter.h" #include "SkTArray.h" class SkOpEdgeBuilder { public: SkOpEdgeBuilder(const SkPathWriter& path, SkTArray& contours) : fPath(path.nativePath()) , fContours(contours) , fAllowOpenContours(true) { init(); } SkOpEdgeBuilder(const SkPath& path, SkTArray& contours) : fPath(&path) , fContours(contours) , fAllowOpenContours(false) { init(); } void addOperand(const SkPath& path); void complete() { if (fCurrentContour && fCurrentContour->segments().count()) { fCurrentContour->complete(); fCurrentContour = NULL; } } bool finish(); void init(); bool unparseable() const { return fUnparseable; } SkPathOpsMask xorMask() const { return fXorMask[fOperand]; } private: void closeContour(const SkPoint& curveEnd, const SkPoint& curveStart); bool close(); int preFetch(); bool walk(); const SkPath* fPath; SkTArray fPathPts; SkTArray fPathVerbs; SkOpContour* fCurrentContour; SkTArray& fContours; SkPathOpsMask fXorMask[2]; int fSecondHalf; bool fOperand; bool fAllowOpenContours; bool fUnparseable; }; #endif