1 /*
2  * Copyright 2014 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 SkDashPathPriv_DEFINED
9 #define SkDashPathPriv_DEFINED
10 
11 #include "SkPathEffect.h"
12 
13 namespace SkDashPath {
14     /*
15      * Calculates the initialDashLength, initialDashIndex, and intervalLength based on the
16      * inputed phase and intervals. If adjustedPhase is passed in, then the phase will be
17      * adjusted to be between 0 and intervalLength. The result will be stored in adjustedPhase.
18      * If adjustedPhase is nullptr then it is assumed phase is already between 0 and intervalLength
19      */
20     void CalcDashParameters(SkScalar phase, const SkScalar intervals[], int32_t count,
21                             SkScalar* initialDashLength, int32_t* initialDashIndex,
22                             SkScalar* intervalLength, SkScalar* adjustedPhase = nullptr);
23 
24     bool FilterDashPath(SkPath* dst, const SkPath& src, SkStrokeRec*, const SkRect*,
25                         const SkScalar aIntervals[], int32_t count, SkScalar initialDashLength,
26                         int32_t initialDashIndex, SkScalar intervalLength);
27 
28     bool FilterDashPath(SkPath* dst, const SkPath& src, SkStrokeRec*, const SkRect*,
29                         const SkPathEffect::DashInfo& info);
30 }
31 
32 #endif
33