Flutter Engine
The Flutter Engine
Public Member Functions | Protected Member Functions | Friends | List of all members
Sk2DPathEffect Class Reference
Inheritance diagram for Sk2DPathEffect:
SkPathEffectBase SkPathEffect SkFlattenable SkRefCnt SkRefCntBase SkLine2DPathEffectImpl SkPath2DPathEffectImpl

Public Member Functions

 Sk2DPathEffect (const SkMatrix &mat)
 
- Public Member Functions inherited from SkPathEffectBase
 SkPathEffectBase ()
 
bool asPoints (PointData *results, const SkPath &src, const SkStrokeRec &, const SkMatrix &, const SkRect *cullR) const
 
SkFlattenable::Type getFlattenableType () const override
 
virtual bool onFilterPath (SkPath *, const SkPath &, SkStrokeRec *, const SkRect *, const SkMatrix &) const =0
 
virtual bool onNeedsCTM () const
 
virtual bool onAsPoints (PointData *, const SkPath &, const SkStrokeRec &, const SkMatrix &, const SkRect *) const
 
virtual DashType onAsADash (DashInfo *) const
 
virtual bool computeFastBounds (SkRect *bounds) const =0
 
- Public Member Functions inherited from SkPathEffect
DashType asADash (DashInfo *info) const
 
bool filterPath (SkPath *dst, const SkPath &src, SkStrokeRec *, const SkRect *cullR) const
 
bool filterPath (SkPath *dst, const SkPath &src, SkStrokeRec *, const SkRect *cullR, const SkMatrix &ctm) const
 
bool needsCTM () const
 
- Public Member Functions inherited from SkFlattenable
 SkFlattenable ()
 
virtual Factory getFactory () const =0
 
virtual const char * getTypeName () const =0
 
virtual void flatten (SkWriteBuffer &) const
 
virtual Type getFlattenableType () const =0
 
sk_sp< SkDataserialize (const SkSerialProcs *=nullptr) const
 
size_t serialize (void *memory, size_t memory_size, const SkSerialProcs *=nullptr) const
 
- Public Member Functions inherited from SkRefCntBase
 SkRefCntBase ()
 
virtual ~SkRefCntBase ()
 
bool unique () const
 
void ref () const
 
void unref () const
 

Protected Member Functions

virtual void begin (const SkIRect &uvBounds, SkPath *dst) const
 
virtual void next (const SkPoint &loc, int u, int v, SkPath *dst) const
 
virtual void end (SkPath *dst) const
 
virtual void nextSpan (int x, int y, int ucount, SkPath *path) const
 
const SkMatrixgetMatrix () const
 
void flatten (SkWriteBuffer &buffer) const override
 
bool onFilterPath (SkPath *dst, const SkPath &src, SkStrokeRec *rec, const SkRect *cullRect, const SkMatrix &) const override
 

Friends

class Sk2DPathEffectBlitter
 

Additional Inherited Members

- Public Types inherited from SkPathEffect
enum  DashType { kNone_DashType , kDash_DashType }
 
- Public Types inherited from SkFlattenable
enum  Type {
  kSkColorFilter_Type , kSkBlender_Type , kSkDrawable_Type , kSkDrawLooper_Type ,
  kSkImageFilter_Type , kSkMaskFilter_Type , kSkPathEffect_Type , kSkShader_Type
}
 
typedef sk_sp< SkFlattenable >(* Factory) (SkReadBuffer &)
 
- Static Public Member Functions inherited from SkPathEffectBase
static sk_sp< SkPathEffectDeserialize (const void *data, size_t size, const SkDeserialProcs *procs=nullptr)
 
static void RegisterFlattenables ()
 
- Static Public Member Functions inherited from SkPathEffect
static sk_sp< SkPathEffectMakeSum (sk_sp< SkPathEffect > first, sk_sp< SkPathEffect > second)
 
static sk_sp< SkPathEffectMakeCompose (sk_sp< SkPathEffect > outer, sk_sp< SkPathEffect > inner)
 
static SkFlattenable::Type GetFlattenableType ()
 
static sk_sp< SkPathEffectDeserialize (const void *data, size_t size, const SkDeserialProcs *procs=nullptr)
 
- Static Public Member Functions inherited from SkFlattenable
static Factory NameToFactory (const char name[])
 
static const char * FactoryToName (Factory)
 
static void Register (const char name[], Factory)
 
static sk_sp< SkFlattenableDeserialize (Type, const void *data, size_t length, const SkDeserialProcs *procs=nullptr)
 

Detailed Description

Definition at line 25 of file Sk2DPathEffect.cpp.

Constructor & Destructor Documentation

◆ Sk2DPathEffect()

Sk2DPathEffect::Sk2DPathEffect ( const SkMatrix mat)
inline

Definition at line 27 of file Sk2DPathEffect.cpp.

27 : fMatrix(mat) {
28 // Calling invert will set the type mask on both matrices, making them thread safe.
29 fMatrixIsInvertible = fMatrix.invert(&fInverse);
30 }
bool invert(SkMatrix *inverse) const
Definition: SkMatrix.h:1206

Member Function Documentation

◆ begin()

virtual void Sk2DPathEffect::begin ( const SkIRect uvBounds,
SkPath dst 
) const
inlineprotectedvirtual

New virtual, to be overridden by subclasses. This is called once from filterPath, and provides the uv parameter bounds for the path. Subsequent calls to next() will receive u and v values within these bounds, and then a call to end() will signal the end of processing.

Definition at line 39 of file Sk2DPathEffect.cpp.

39{}

◆ end()

virtual void Sk2DPathEffect::end ( SkPath dst) const
inlineprotectedvirtual

Definition at line 41 of file Sk2DPathEffect.cpp.

41{}

◆ flatten()

void Sk2DPathEffect::flatten ( SkWriteBuffer ) const
inlineoverrideprotectedvirtual

Override this if your subclass needs to record data that it will need to recreate itself from its CreateProc (returned by getFactory()).

DEPRECATED public : will move to protected ... use serialize() instead

Reimplemented from SkFlattenable.

Reimplemented in SkLine2DPathEffectImpl, and SkPath2DPathEffectImpl.

Definition at line 70 of file Sk2DPathEffect.cpp.

70 {
71 buffer.writeMatrix(fMatrix);
72 }
DEF_SWITCHES_START aot vmservice shared library Name of the *so containing AOT compiled Dart assets for launching the service isolate vm snapshot The VM snapshot data that will be memory mapped as read only SnapshotAssetPath must be present isolate snapshot The isolate snapshot data that will be memory mapped as read only SnapshotAssetPath must be present cache dir Path to the cache directory This is different from the persistent_cache_path in embedder which is used for Skia shader cache icu native lib Path to the library file that exports the ICU data vm service The hostname IP address on which the Dart VM Service should be served If not defaults to or::depending on whether ipv6 is specified vm service A custom Dart VM Service port The default is to pick a randomly available open port disable vm Disable the Dart VM Service The Dart VM Service is never available in release mode disable vm service Disable mDNS Dart VM Service publication Bind to the IPv6 localhost address for the Dart VM Service Ignored if vm service host is set endless trace buffer
Definition: switches.h:126

◆ getMatrix()

const SkMatrix & Sk2DPathEffect::getMatrix ( ) const
inlineprotected

Definition at line 68 of file Sk2DPathEffect.cpp.

68{ return fMatrix; }

◆ next()

virtual void Sk2DPathEffect::next ( const SkPoint loc,
int  u,
int  v,
SkPath dst 
) const
inlineprotectedvirtual

Reimplemented in SkPath2DPathEffectImpl.

Definition at line 40 of file Sk2DPathEffect.cpp.

40{}

◆ nextSpan()

virtual void Sk2DPathEffect::nextSpan ( int  x,
int  y,
int  ucount,
SkPath path 
) const
inlineprotectedvirtual

Low-level virtual called per span of locations in the u-direction. The default implementation calls next() repeatedly with each location.

Reimplemented in SkLine2DPathEffectImpl.

Definition at line 47 of file Sk2DPathEffect.cpp.

47 {
48 if (!fMatrixIsInvertible) {
49 return;
50 }
51 #if defined(SK_BUILD_FOR_FUZZER)
52 if (ucount > 100) {
53 return;
54 }
55 #endif
56
57 const SkMatrix& mat = this->getMatrix();
59
61 do {
62 mat.mapPoints(&dst, &src, 1);
63 this->next(dst, x++, y, path);
64 src.fX += SK_Scalar1;
65 } while (--ucount > 0);
66 }
#define SK_Scalar1
Definition: SkScalar.h:18
#define SK_ScalarHalf
Definition: SkScalar.h:19
#define SkIntToScalar(x)
Definition: SkScalar.h:57
virtual void next(const SkPoint &loc, int u, int v, SkPath *dst) const
const SkMatrix & getMatrix() const
void mapPoints(SkPoint dst[], const SkPoint src[], int count) const
Definition: SkMatrix.cpp:770
double y
double x
DEF_SWITCHES_START aot vmservice shared library Name of the *so containing AOT compiled Dart assets for launching the service isolate vm snapshot The VM snapshot data that will be memory mapped as read only SnapshotAssetPath must be present isolate snapshot The isolate snapshot data that will be memory mapped as read only SnapshotAssetPath must be present cache dir path
Definition: switches.h:57
dst
Definition: cp.py:12

◆ onFilterPath()

bool Sk2DPathEffect::onFilterPath ( SkPath ,
const SkPath ,
SkStrokeRec ,
const SkRect ,
const SkMatrix  
) const
inlineoverrideprotectedvirtual

Filter the input path.

The CTM parameter is provided for path effects that can use the information. The output of path effects must always be in the original (input) coordinate system, regardless of whether the path effect uses the CTM or not.

Implements SkPathEffectBase.

Reimplemented in SkLine2DPathEffectImpl.

Definition at line 74 of file Sk2DPathEffect.cpp.

75 {
76 if (!fMatrixIsInvertible) {
77 return false;
78 }
79
80 SkPath tmp;
81 SkIRect ir;
82
83 src.transform(fInverse, &tmp);
84 tmp.getBounds().round(&ir);
85 if (!ir.isEmpty()) {
86 this->begin(ir, dst);
87
88 SkRegion rgn;
89 rgn.setPath(tmp, SkRegion(ir));
90 SkRegion::Iterator iter(rgn);
91 for (; !iter.done(); iter.next()) {
92 const SkIRect& rect = iter.rect();
93#if defined(SK_BUILD_FOR_FUZZER)
94 if (rect.height() > 100) {
95 continue;
96 }
97#endif
98 for (int y = rect.fTop; y < rect.fBottom; ++y) {
99 this->nextSpan(rect.fLeft, y, rect.width(), dst);
100 }
101 }
102
103 this->end(dst);
104 }
105 return true;
106 }
virtual void end(SkPath *dst) const
virtual void begin(const SkIRect &uvBounds, SkPath *dst) const
virtual void nextSpan(int x, int y, int ucount, SkPath *path) const
Definition: SkPath.h:59
const SkRect & getBounds() const
Definition: SkPath.cpp:430
bool setPath(const SkPath &path, const SkRegion &clip)
sk_sp< SkBlender > blender SkRect rect
Definition: SkRecords.h:350
Definition: SkRect.h:32
bool isEmpty() const
Definition: SkRect.h:202
int32_t fLeft
smaller x-axis bounds
Definition: SkRect.h:33
void round(SkIRect *dst) const
Definition: SkRect.h:1228

Friends And Related Function Documentation

◆ Sk2DPathEffectBlitter

friend class Sk2DPathEffectBlitter
friend

Definition at line 115 of file Sk2DPathEffect.cpp.


The documentation for this class was generated from the following file: