1fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot/*
2fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot * Copyright 2006 The Android Open Source Project
3fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot *
4fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot * Use of this source code is governed by a BSD-style license that can be
5fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot * found in the LICENSE file.
6fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot */
7fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot
8fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot#ifndef SkDashPathEffect_DEFINED
9fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot#define SkDashPathEffect_DEFINED
10fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot
11fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot#include "SkPathEffect.h"
12fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot
13fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robotclass SK_API SkDashPathEffect {
14fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robotpublic:
15fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot    /** intervals: array containing an even number of entries (>=2), with
16fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         the even indices specifying the length of "on" intervals, and the odd
17fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         indices specifying the length of "off" intervals.
18fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot        count: number of elements in the intervals array
19fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot        phase: offset into the intervals array (mod the sum of all of the
20fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         intervals).
21fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot
22fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot        For example: if intervals[] = {10, 20}, count = 2, and phase = 25,
23fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         this will set up a dashed path like so:
24fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         5 pixels off
25fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         10 pixels on
26fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         20 pixels off
27fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         10 pixels on
28fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         20 pixels off
29fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         ...
30fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot        A phase of -5, 25, 55, 85, etc. would all result in the same path,
31fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot         because the sum of all the intervals is 30.
32fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot
33fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot        Note: only affects stroked paths.
34fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot    */
35fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot    static sk_sp<SkPathEffect> Make(const SkScalar intervals[], int count, SkScalar phase);
36fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot};
37fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot
38fe17456d5e528078ce69b5f15cf7adf1fab963fandroid-build-team Robot#endif
39