|  | /* | 
|  | * Copyright 2011 Google Inc. | 
|  | * | 
|  | * Use of this source code is governed by a BSD-style license that can be | 
|  | * found in the LICENSE file. | 
|  | */ | 
|  | #ifndef SkAntiEdge_DEFINED | 
|  | #define SkAntiEdge_DEFINED | 
|  |  | 
|  | #include "SkFixed.h" | 
|  | #include "SkTDArray.h" | 
|  |  | 
|  | struct SkBitmap; | 
|  | struct SkPoint; | 
|  |  | 
|  | struct SkAntiEdge { | 
|  | SkAntiEdge* fNext; // list in walking order (y, then x, then diag) | 
|  | SkAntiEdge* fPrev; // reverse in walking order | 
|  | SkAntiEdge* fLink; // list in connected order, top to bottom | 
|  |  | 
|  | SkFixed     fFirstX; // starting X | 
|  | SkFixed     fFirstY; // starting Y | 
|  | SkFixed     fLastX; // ending X | 
|  | SkFixed     fLastY; // ending Y | 
|  | SkFixed     fX0; // computed edge current value (may be off end) | 
|  | SkFixed     fY0; | 
|  | SkFixed     fX; // edge current value (always on edge) | 
|  | SkFixed     fY; | 
|  | SkFixed     fDX; // change in X per unit step in Y | 
|  | SkFixed     fDY; // change in Y per unit step in X | 
|  | SkFixed     fWalkX; // unit step position (integer after initial step) | 
|  | SkFixed     fWalkY; | 
|  | uint16_t    fPartialY; // initial partial coverage in Y (0 .. SkFixed1] | 
|  | int16_t     fWindingSum; // winding including contributions to the left | 
|  | int8_t      fWinding; // 1 or -1 (could be 2 bits) | 
|  | bool        fFinished : 1; | 
|  | unsigned    fDXFlipped : 1; // used as bool and to adjust calculations (0/1) | 
|  | bool        fLinkSet : 1; // set if edge has been attached to another edge | 
|  |  | 
|  | void calcLine(); | 
|  | bool setLine(const SkPoint& p0, const SkPoint& p1); | 
|  | uint16_t advanceX(SkFixed left); | 
|  | uint16_t advanceFlippedX(SkFixed left); | 
|  | void advanceY(SkFixed top); | 
|  | // FIXME: mark DEBUG | 
|  | void pointInLine(SkFixed x, SkFixed y); | 
|  | void pointOnLine(SkFixed x, SkFixed y); | 
|  | void validate(); | 
|  | }; | 
|  |  | 
|  | class SkAntiEdgeBuilder { | 
|  | public: | 
|  | void process(const SkPoint* points, int ptCount, | 
|  | uint8_t* result, int pixelCol, int pixelRow); | 
|  | private: | 
|  | int build(const SkPoint pts[], int count); | 
|  | void calc(); | 
|  | void link(); | 
|  | void sort(); | 
|  | void sort(SkTDArray<SkAntiEdge*>&); | 
|  | void split(); | 
|  | void split(SkAntiEdge* edge, SkFixed y); | 
|  | void walk(uint8_t* result, int rowBytes, int height); | 
|  | SkAntiEdge fHeadEdge; | 
|  | SkAntiEdge fTailEdge; | 
|  | SkTDArray<SkAntiEdge> fEdges; | 
|  | SkTDArray<SkAntiEdge*> fList; | 
|  | }; | 
|  |  | 
|  | void SkAntiEdge_Test(); | 
|  | void CreateSweep(SkBitmap* , float width); | 
|  | void CreateHorz(SkBitmap* ); | 
|  | void CreateVert(SkBitmap* ); | 
|  | void CreateAngle(SkBitmap* sweep, float angle); | 
|  |  | 
|  | #endif |