1 /*
2  * Copyright 2015 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 #ifndef GrTessellator_DEFINED
9 #define GrTessellator_DEFINED
10 
11 #include "GrColor.h"
12 #include "SkColorData.h"
13 #include "SkPoint.h"
14 
15 class SkPath;
16 struct SkRect;
17 
18 /**
19  * Provides utility functions for converting paths to a collection of triangles.
20  */
21 
22 #define TESSELLATOR_WIREFRAME 0
23 
24 namespace GrTessellator {
25 
26 class VertexAllocator {
27 public:
VertexAllocator(size_t stride)28     VertexAllocator(size_t stride) : fStride(stride) {}
~VertexAllocator()29     virtual ~VertexAllocator() {}
30     virtual void* lock(int vertexCount) = 0;
31     virtual void unlock(int actualCount) = 0;
stride()32     size_t stride() const { return fStride; }
33 private:
34     size_t fStride;
35 };
36 
37 struct WindingVertex {
38     SkPoint fPos;
39     int fWinding;
40 };
41 
42 // Triangulates a path to an array of vertices. Each triangle is represented as a set of three
43 // WindingVertex entries, each of which contains the position and winding count (which is the same
44 // for all three vertices of a triangle). The 'verts' out parameter is set to point to the resultant
45 // vertex array. CALLER IS RESPONSIBLE for deleting this buffer to avoid a memory leak!
46 int PathToVertices(const SkPath& path, SkScalar tolerance, const SkRect& clipBounds,
47                    WindingVertex** verts);
48 
49 int PathToTriangles(const SkPath& path, SkScalar tolerance, const SkRect& clipBounds,
50                     VertexAllocator*, bool antialias, bool *isLinear);
51 }
52 
53 #endif
54