blob: 045bb25d0588eb1704f670162e3ceaf6bc733c7e [file] [log] [blame]
reed@android.com8a1c16f2008-12-17 15:59:43 +00001/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00002 * Copyright 2006 The Android Open Source Project
reed@android.com8a1c16f2008-12-17 15:59:43 +00003 *
epoger@google.comec3ed6a2011-07-28 14:26:00 +00004 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
reed@android.com8a1c16f2008-12-17 15:59:43 +00006 */
7
8#ifndef SkDashPathEffect_DEFINED
9#define SkDashPathEffect_DEFINED
10
11#include "SkPathEffect.h"
12
13/** \class SkDashPathEffect
14
15 SkDashPathEffect is a subclass of SkPathEffect that implements dashing
16*/
ctguil@chromium.org7ffb1b22011-03-15 21:27:08 +000017class SK_API SkDashPathEffect : public SkPathEffect {
reed@android.com8a1c16f2008-12-17 15:59:43 +000018public:
epoger@google.com20bf4ca2012-04-27 13:34:52 +000019 /** intervals: array containing an even number of entries (>=2), with
20 the even indices specifying the length of "on" intervals, and the odd
21 indices specifying the length of "off" intervals.
rmistry@google.comfbfcd562012-08-23 18:09:54 +000022 count: number of elements in the intervals array
epoger@google.com20bf4ca2012-04-27 13:34:52 +000023 phase: offset into the intervals array (mod the sum of all of the
24 intervals).
25
26 For example: if intervals[] = {10, 20}, count = 2, and phase = 25,
27 this will set up a dashed path like so:
28 5 pixels off
29 10 pixels on
30 20 pixels off
31 10 pixels on
32 20 pixels off
33 ...
34 A phase of -5, 25, 55, 85, etc. would all result in the same path,
35 because the sum of all the intervals is 30.
36
37 Note: only affects stroked paths.
reed@android.com8a1c16f2008-12-17 15:59:43 +000038 */
reeda4393342016-03-18 11:22:57 -070039 static sk_sp<SkPathEffect> Make(const SkScalar intervals[], int count, SkScalar phase);
40
reed@google.com548a1f32012-12-18 16:12:09 +000041 virtual bool filterPath(SkPath* dst, const SkPath& src,
mtklein36352bf2015-03-25 18:17:31 -070042 SkStrokeRec*, const SkRect*) const override;
reed@android.com8a1c16f2008-12-17 15:59:43 +000043
skia.committer@gmail.com687c57c2012-11-29 02:01:19 +000044 virtual bool asPoints(PointData* results, const SkPath& src,
reed@google.com4bbdeac2013-01-24 21:03:11 +000045 const SkStrokeRec&, const SkMatrix&,
mtklein36352bf2015-03-25 18:17:31 -070046 const SkRect*) const override;
robertphillips@google.com629ab542012-11-28 17:18:11 +000047
mtklein36352bf2015-03-25 18:17:31 -070048 DashType asADash(DashInfo* info) const override;
commit-bot@chromium.orgaec14382014-04-22 15:21:18 +000049
robertphillips42dbfa82015-01-26 06:08:52 -080050 SK_TO_STRING_OVERRIDE()
reed9fa60da2014-08-21 07:59:51 -070051 SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkDashPathEffect)
reed@google.com6bac9472011-06-21 19:24:00 +000052
tomhudson64de1e12015-03-05 08:01:07 -080053#ifdef SK_BUILD_FOR_ANDROID_FRAMEWORK
mtklein36352bf2015-03-25 18:17:31 -070054 bool exposedInAndroidJavaAPI() const override { return true; }
tomhudson64de1e12015-03-05 08:01:07 -080055#endif
56
reed@android.com8a1c16f2008-12-17 15:59:43 +000057protected:
reedca726ab2016-02-22 12:50:25 -080058 virtual ~SkDashPathEffect();
commit-bot@chromium.org35c03fb2014-03-31 18:52:51 +000059 SkDashPathEffect(const SkScalar intervals[], int count, SkScalar phase);
mtklein36352bf2015-03-25 18:17:31 -070060 void flatten(SkWriteBuffer&) const override;
commit-bot@chromium.org0a2bf902014-02-20 20:40:19 +000061
reed@android.com8a1c16f2008-12-17 15:59:43 +000062private:
63 SkScalar* fIntervals;
64 int32_t fCount;
commit-bot@chromium.orgaec14382014-04-22 15:21:18 +000065 SkScalar fPhase;
reed@android.com8a1c16f2008-12-17 15:59:43 +000066 // computed from phase
reedca726ab2016-02-22 12:50:25 -080067
reed@android.com8a1c16f2008-12-17 15:59:43 +000068 SkScalar fInitialDashLength;
69 int32_t fInitialDashIndex;
70 SkScalar fIntervalLength;
reed@android.com8a1c16f2008-12-17 15:59:43 +000071
reed@android.com8a1c16f2008-12-17 15:59:43 +000072 typedef SkPathEffect INHERITED;
73};
74
75#endif