blob: a1c548265367cd0b0eac1d963070799ac6652b5d [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 */
commit-bot@chromium.org0a2bf902014-02-20 20:40:19 +000039 static SkDashPathEffect* Create(const SkScalar intervals[], int count,
40 SkScalar phase, bool scaleToFit = false) {
41 return SkNEW_ARGS(SkDashPathEffect, (intervals, count, phase, scaleToFit));
42 }
reed@android.com8a1c16f2008-12-17 15:59:43 +000043 virtual ~SkDashPathEffect();
44
reed@google.com548a1f32012-12-18 16:12:09 +000045 virtual bool filterPath(SkPath* dst, const SkPath& src,
reed@google.com4bbdeac2013-01-24 21:03:11 +000046 SkStrokeRec*, const SkRect*) const SK_OVERRIDE;
reed@android.com8a1c16f2008-12-17 15:59:43 +000047
skia.committer@gmail.com687c57c2012-11-29 02:01:19 +000048 virtual bool asPoints(PointData* results, const SkPath& src,
reed@google.com4bbdeac2013-01-24 21:03:11 +000049 const SkStrokeRec&, const SkMatrix&,
50 const SkRect*) const SK_OVERRIDE;
robertphillips@google.com629ab542012-11-28 17:18:11 +000051
robertphillips@google.comc2eae472013-10-21 12:26:10 +000052 virtual Factory getFactory() const SK_OVERRIDE;
reed@google.com548a1f32012-12-18 16:12:09 +000053
commit-bot@chromium.org8b0e8ac2014-01-30 18:58:24 +000054 static SkFlattenable* CreateProc(SkReadBuffer&);
reed@google.com6bac9472011-06-21 19:24:00 +000055
reed@android.com8a1c16f2008-12-17 15:59:43 +000056protected:
commit-bot@chromium.org8b0e8ac2014-01-30 18:58:24 +000057 SkDashPathEffect(SkReadBuffer&);
58 virtual void flatten(SkWriteBuffer&) const SK_OVERRIDE;
rmistry@google.comfbfcd562012-08-23 18:09:54 +000059
commit-bot@chromium.org0a2bf902014-02-20 20:40:19 +000060#ifdef SK_SUPPORT_LEGACY_PUBLICEFFECTCONSTRUCTORS
61public:
62#endif
63 SkDashPathEffect(const SkScalar intervals[], int count, SkScalar phase,
64 bool scaleToFit = false);
65
reed@android.com8a1c16f2008-12-17 15:59:43 +000066private:
67 SkScalar* fIntervals;
68 int32_t fCount;
69 // computed from phase
70 SkScalar fInitialDashLength;
71 int32_t fInitialDashIndex;
72 SkScalar fIntervalLength;
73 bool fScaleToFit;
74
reed@android.com8a1c16f2008-12-17 15:59:43 +000075 typedef SkPathEffect INHERITED;
76};
77
78#endif