blob: 8d77982a7045067f66f6c8e118d74eb6e3376791 [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2011 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +00007 */
8
epoger@google.comec3ed6a2011-07-28 14:26:00 +00009
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +000010#ifndef GrPathUtils_DEFINED
11#define GrPathUtils_DEFINED
12
bsalomon@google.com181e9bd2011-09-07 18:42:30 +000013#include "GrMatrix.h"
reed@google.com07f3ee12011-05-16 17:21:57 +000014#include "GrPath.h"
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +000015
bsalomon@google.com181e9bd2011-09-07 18:42:30 +000016class GrPoint;
17
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +000018/**
19 * Utilities for evaluating paths.
20 */
bsalomon@google.com181e9bd2011-09-07 18:42:30 +000021namespace GrPathUtils {
22 GrScalar scaleToleranceToSrc(GrScalar devTol,
23 const GrMatrix& viewM);
tomhudson@google.comc10a8882011-06-28 15:19:32 +000024
bsalomon@google.com181e9bd2011-09-07 18:42:30 +000025 /// Since we divide by tol if we're computing exact worst-case bounds,
26 /// very small tolerances will be increased to gMinCurveTol.
27 int worstCasePointCount(const GrPath&,
28 int* subpaths,
29 GrScalar tol);
30 /// Since we divide by tol if we're computing exact worst-case bounds,
31 /// very small tolerances will be increased to gMinCurveTol.
32 uint32_t quadraticPointCount(const GrPoint points[], GrScalar tol);
33 uint32_t generateQuadraticPoints(const GrPoint& p0,
34 const GrPoint& p1,
35 const GrPoint& p2,
36 GrScalar tolSqd,
37 GrPoint** points,
38 uint32_t pointsLeft);
39 /// Since we divide by tol if we're computing exact worst-case bounds,
40 /// very small tolerances will be increased to gMinCurveTol.
41 uint32_t cubicPointCount(const GrPoint points[], GrScalar tol);
42 uint32_t generateCubicPoints(const GrPoint& p0,
43 const GrPoint& p1,
44 const GrPoint& p2,
45 const GrPoint& p3,
46 GrScalar tolSqd,
47 GrPoint** points,
48 uint32_t pointsLeft);
49
senorblanco@chromium.org9d18b782011-03-28 20:47:09 +000050};
51#endif