Move convexity enum out of public
Also, move first-direction into SkPathRef.h so it can be referenced by name in SkPath (instead of using uint8_t) No functional change expected. Change-Id: Ica4a8357a8156fd9a516118f23599a965b0fdd47 Reviewed-on: https://skia-review.googlesource.com/c/skia/+/313980 Reviewed-by: Mike Reed <reed@google.com> Commit-Queue: Mike Reed <reed@google.com>
This commit is contained in:
parent
d5961b33e8
commit
3872c98951
@ -1243,7 +1243,7 @@ public:
|
|||||||
fPath.addRRect(SkRRect::MakeRectXY(r, w/8.0f, h/8.0f));
|
fPath.addRRect(SkRRect::MakeRectXY(r, w/8.0f, h/8.0f));
|
||||||
|
|
||||||
if (forceConcave) {
|
if (forceConcave) {
|
||||||
SkPathPriv::SetConvexityType(fPath, SkPathConvexityType::kConcave);
|
SkPathPriv::SetConvexity(fPath, SkPathConvexity::kConcave);
|
||||||
SkASSERT(!fPath.isConvex());
|
SkASSERT(!fPath.isConvex());
|
||||||
} else {
|
} else {
|
||||||
SkASSERT(fPath.isConvex());
|
SkASSERT(fPath.isConvex());
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
#include "include/core/SkPathBuilder.h"
|
#include "include/core/SkPathBuilder.h"
|
||||||
#include "include/core/SkScalar.h"
|
#include "include/core/SkScalar.h"
|
||||||
#include "include/private/SkFloatBits.h"
|
#include "include/private/SkFloatBits.h"
|
||||||
|
#include "include/private/SkPathRef.h"
|
||||||
#include "src/core/SkPathPriv.h"
|
#include "src/core/SkPathPriv.h"
|
||||||
|
|
||||||
#define W 800
|
#define W 800
|
||||||
@ -64,7 +65,7 @@ DEF_SIMPLE_GM(analytic_antialias_convex, canvas, W, H) {
|
|||||||
SkBits2Float(0x4344f079), SkBits2Float(0x4397e900), SkBits2Float(0x3f3504f3));
|
SkBits2Float(0x4344f079), SkBits2Float(0x4397e900), SkBits2Float(0x3f3504f3));
|
||||||
path.close();
|
path.close();
|
||||||
// Manually setting convexity is required. Otherwise, this path will be considered concave.
|
// Manually setting convexity is required. Otherwise, this path will be considered concave.
|
||||||
SkPathPriv::SetConvexityType(&path, SkPathConvexityType::kConvex);
|
SkPathPriv::SetConvexity(&path, SkPathConvexity::kConvex);
|
||||||
canvas->drawPath(path.detach(), p);
|
canvas->drawPath(path.detach(), p);
|
||||||
|
|
||||||
// skbug.com/7573
|
// skbug.com/7573
|
||||||
|
@ -258,7 +258,7 @@ protected:
|
|||||||
// of the GMs rows.
|
// of the GMs rows.
|
||||||
SkASSERT(path.isConvex());
|
SkASSERT(path.isConvex());
|
||||||
SkASSERT(SkPath::kLine_SegmentMask == path.getSegmentMasks());
|
SkASSERT(SkPath::kLine_SegmentMask == path.getSegmentMasks());
|
||||||
SkPathPriv::FirstDirection actualDir;
|
SkPathFirstDirection actualDir;
|
||||||
SkASSERT(SkPathPriv::CheapComputeFirstDirection(path, &actualDir));
|
SkASSERT(SkPathPriv::CheapComputeFirstDirection(path, &actualDir));
|
||||||
SkASSERT(SkPathPriv::AsFirstDirection(dir) == actualDir);
|
SkASSERT(SkPathPriv::AsFirstDirection(dir) == actualDir);
|
||||||
SkRect bounds = path.getBounds();
|
SkRect bounds = path.getBounds();
|
||||||
|
@ -303,12 +303,12 @@ DEF_SIMPLE_GM_BG_NAME(strokefill, canvas, 640, 480, SK_ColorWHITE,
|
|||||||
path2.reset();
|
path2.reset();
|
||||||
path2.addCircle(x + SkIntToScalar(240), y + SkIntToScalar(200), SkIntToScalar(50), SkPathDirection::kCCW);
|
path2.addCircle(x + SkIntToScalar(240), y + SkIntToScalar(200), SkIntToScalar(50), SkPathDirection::kCCW);
|
||||||
canvas->drawPath(path2, paint);
|
canvas->drawPath(path2, paint);
|
||||||
SkASSERT(SkPathPriv::CheapIsFirstDirection(path2, SkPathPriv::kCCW_FirstDirection));
|
SkASSERT(SkPathPriv::CheapIsFirstDirection(path2, SkPathFirstDirection::kCCW));
|
||||||
|
|
||||||
path2.reset();
|
path2.reset();
|
||||||
SkASSERT(!SkPathPriv::CheapComputeFirstDirection(path2, nullptr));
|
SkASSERT(!SkPathPriv::CheapComputeFirstDirection(path2, nullptr));
|
||||||
path2.addCircle(x + SkIntToScalar(360), y + SkIntToScalar(200), SkIntToScalar(50), SkPathDirection::kCW);
|
path2.addCircle(x + SkIntToScalar(360), y + SkIntToScalar(200), SkIntToScalar(50), SkPathDirection::kCW);
|
||||||
SkASSERT(SkPathPriv::CheapIsFirstDirection(path2, SkPathPriv::kCW_FirstDirection));
|
SkASSERT(SkPathPriv::CheapIsFirstDirection(path2, SkPathFirstDirection::kCW));
|
||||||
canvas->drawPath(path2, paint);
|
canvas->drawPath(path2, paint);
|
||||||
|
|
||||||
SkRect r = SkRect::MakeXYWH(x - SkIntToScalar(50), y + SkIntToScalar(280),
|
SkRect r = SkRect::MakeXYWH(x - SkIntToScalar(50), y + SkIntToScalar(280),
|
||||||
@ -334,7 +334,7 @@ DEF_SIMPLE_GM_BG_NAME(strokefill, canvas, 640, 480, SK_ColorWHITE,
|
|||||||
path4.reset();
|
path4.reset();
|
||||||
SkASSERT(!SkPathPriv::CheapComputeFirstDirection(path4, nullptr));
|
SkASSERT(!SkPathPriv::CheapComputeFirstDirection(path4, nullptr));
|
||||||
path4.addRect(r, SkPathDirection::kCCW);
|
path4.addRect(r, SkPathDirection::kCCW);
|
||||||
SkASSERT(SkPathPriv::CheapIsFirstDirection(path4, SkPathPriv::kCCW_FirstDirection));
|
SkASSERT(SkPathPriv::CheapIsFirstDirection(path4, SkPathFirstDirection::kCCW));
|
||||||
path4.moveTo(0, 0); // test for crbug.com/247770
|
path4.moveTo(0, 0); // test for crbug.com/247770
|
||||||
canvas->drawPath(path4, paint);
|
canvas->drawPath(path4, paint);
|
||||||
|
|
||||||
@ -343,7 +343,7 @@ DEF_SIMPLE_GM_BG_NAME(strokefill, canvas, 640, 480, SK_ColorWHITE,
|
|||||||
path4.reset();
|
path4.reset();
|
||||||
SkASSERT(!SkPathPriv::CheapComputeFirstDirection(path4, nullptr));
|
SkASSERT(!SkPathPriv::CheapComputeFirstDirection(path4, nullptr));
|
||||||
path4.addRect(r, SkPathDirection::kCW);
|
path4.addRect(r, SkPathDirection::kCW);
|
||||||
SkASSERT(SkPathPriv::CheapIsFirstDirection(path4, SkPathPriv::kCW_FirstDirection));
|
SkASSERT(SkPathPriv::CheapIsFirstDirection(path4, SkPathFirstDirection::kCW));
|
||||||
path4.moveTo(0, 0); // test for crbug.com/247770
|
path4.moveTo(0, 0); // test for crbug.com/247770
|
||||||
canvas->drawPath(path4, paint);
|
canvas->drawPath(path4, paint);
|
||||||
}
|
}
|
||||||
|
@ -227,7 +227,7 @@ public:
|
|||||||
/** Returns true if the path is convex. If necessary, it will first compute the convexity.
|
/** Returns true if the path is convex. If necessary, it will first compute the convexity.
|
||||||
*/
|
*/
|
||||||
bool isConvex() const {
|
bool isConvex() const {
|
||||||
return SkPathConvexityType::kConvex == this->getConvexityType();
|
return SkPathConvexity::kConvex == this->getConvexity();
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Returns true if this path is recognized as an oval or circle.
|
/** Returns true if this path is recognized as an oval or circle.
|
||||||
@ -1800,13 +1800,13 @@ public:
|
|||||||
bool isValid() const { return this->isValidImpl() && fPathRef->isValid(); }
|
bool isValid() const { return this->isValidImpl() && fPathRef->isValid(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SkPath(sk_sp<SkPathRef>, SkPathFillType, bool isVolatile, SkPathConvexityType,
|
SkPath(sk_sp<SkPathRef>, SkPathFillType, bool isVolatile, SkPathConvexity,
|
||||||
uint8_t firstDirection);
|
SkPathFirstDirection firstDirection);
|
||||||
|
|
||||||
sk_sp<SkPathRef> fPathRef;
|
sk_sp<SkPathRef> fPathRef;
|
||||||
int fLastMoveToIndex;
|
int fLastMoveToIndex;
|
||||||
mutable std::atomic<uint8_t> fConvexity; // SkPathConvexityType
|
mutable std::atomic<uint8_t> fConvexity; // SkPathConvexity
|
||||||
mutable std::atomic<uint8_t> fFirstDirection; // really an SkPathPriv::FirstDirection
|
mutable std::atomic<uint8_t> fFirstDirection; // SkPathFirstDirection
|
||||||
uint8_t fFillType : 2;
|
uint8_t fFillType : 2;
|
||||||
uint8_t fIsVolatile : 1;
|
uint8_t fIsVolatile : 1;
|
||||||
|
|
||||||
@ -1846,7 +1846,7 @@ private:
|
|||||||
|
|
||||||
inline bool hasOnlyMoveTos() const;
|
inline bool hasOnlyMoveTos() const;
|
||||||
|
|
||||||
SkPathConvexityType computeConvexity() const;
|
SkPathConvexity computeConvexity() const;
|
||||||
|
|
||||||
/** Asserts if SkPath data is inconsistent.
|
/** Asserts if SkPath data is inconsistent.
|
||||||
Debugging check intended for internal use only.
|
Debugging check intended for internal use only.
|
||||||
@ -1880,31 +1880,32 @@ private:
|
|||||||
|
|
||||||
// Bottlenecks for working with fConvexity and fFirstDirection.
|
// Bottlenecks for working with fConvexity and fFirstDirection.
|
||||||
// Notice the setters are const... these are mutable atomic fields.
|
// Notice the setters are const... these are mutable atomic fields.
|
||||||
void setConvexityType(SkPathConvexityType) const;
|
void setConvexity(SkPathConvexity) const;
|
||||||
void setFirstDirection(uint8_t) const;
|
|
||||||
uint8_t getFirstDirection() const;
|
void setFirstDirection(SkPathFirstDirection) const;
|
||||||
|
SkPathFirstDirection getFirstDirection() const;
|
||||||
|
|
||||||
/** Returns the comvexity type, computing if needed. Never returns kUnknown.
|
/** Returns the comvexity type, computing if needed. Never returns kUnknown.
|
||||||
@return path's convexity type (convex or concave)
|
@return path's convexity type (convex or concave)
|
||||||
*/
|
*/
|
||||||
SkPathConvexityType getConvexityType() const {
|
SkPathConvexity getConvexity() const {
|
||||||
SkPathConvexityType convexity = this->getConvexityTypeOrUnknown();
|
SkPathConvexity convexity = this->getConvexityOrUnknown();
|
||||||
if (convexity == SkPathConvexityType::kUnknown) {
|
if (convexity == SkPathConvexity::kUnknown) {
|
||||||
convexity = this->computeConvexity();
|
convexity = this->computeConvexity();
|
||||||
}
|
}
|
||||||
SkASSERT(convexity != SkPathConvexityType::kUnknown);
|
SkASSERT(convexity != SkPathConvexity::kUnknown);
|
||||||
return convexity;
|
return convexity;
|
||||||
}
|
}
|
||||||
SkPathConvexityType getConvexityTypeOrUnknown() const {
|
SkPathConvexity getConvexityOrUnknown() const {
|
||||||
return (SkPathConvexityType)fConvexity.load(std::memory_order_relaxed);
|
return (SkPathConvexity)fConvexity.load(std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
/** Stores a convexity type for this path. This is what will be returned if
|
/** Stores a convexity type for this path. This is what will be returned if
|
||||||
* getConvexityTypeOrUnknown() is called. If you pass kUnknown, then if getContexityType()
|
* getConvexityOrUnknown() is called. If you pass kUnknown, then if getContexityType()
|
||||||
* is called, the real convexity will be computed.
|
* is called, the real convexity will be computed.
|
||||||
*
|
*
|
||||||
* example: https://fiddle.skia.org/c/@Path_setConvexity
|
* example: https://fiddle.skia.org/c/@Path_setConvexity
|
||||||
*/
|
*/
|
||||||
void setConvexityType(SkPathConvexityType convexity);
|
void setConvexity(SkPathConvexity convexity);
|
||||||
|
|
||||||
friend class SkAutoPathBoundsUpdate;
|
friend class SkAutoPathBoundsUpdate;
|
||||||
friend class SkAutoDisableOvalCheck;
|
friend class SkAutoDisableOvalCheck;
|
||||||
|
@ -230,7 +230,7 @@ private:
|
|||||||
bool fIsACCW = false; // tracks direction iff fIsA is not unknown
|
bool fIsACCW = false; // tracks direction iff fIsA is not unknown
|
||||||
|
|
||||||
// for testing
|
// for testing
|
||||||
SkPathConvexityType fOverrideConvexity = SkPathConvexityType::kUnknown;
|
SkPathConvexity fOverrideConvexity = SkPathConvexity::kUnknown;
|
||||||
|
|
||||||
int countVerbs() const { return fVerbs.count(); }
|
int countVerbs() const { return fVerbs.count(); }
|
||||||
|
|
||||||
@ -247,7 +247,7 @@ private:
|
|||||||
SkPathBuilder& privateReverseAddPath(const SkPath&);
|
SkPathBuilder& privateReverseAddPath(const SkPath&);
|
||||||
|
|
||||||
// For testing
|
// For testing
|
||||||
void privateSetConvexityType(SkPathConvexityType c) { fOverrideConvexity = c; }
|
void privateSetConvexity(SkPathConvexity c) { fOverrideConvexity = c; }
|
||||||
|
|
||||||
friend class SkPathPriv;
|
friend class SkPathPriv;
|
||||||
};
|
};
|
||||||
|
@ -33,12 +33,6 @@ static inline SkPathFillType SkPathFillType_ConvertToNonInverse(SkPathFillType f
|
|||||||
return static_cast<SkPathFillType>(static_cast<int>(ft) & 1);
|
return static_cast<SkPathFillType>(static_cast<int>(ft) & 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
enum class SkPathConvexityType {
|
|
||||||
kUnknown,
|
|
||||||
kConvex,
|
|
||||||
kConcave
|
|
||||||
};
|
|
||||||
|
|
||||||
enum class SkPathDirection {
|
enum class SkPathDirection {
|
||||||
/** clockwise direction for adding closed contours */
|
/** clockwise direction for adding closed contours */
|
||||||
kCW,
|
kCW,
|
||||||
|
@ -28,6 +28,18 @@ struct SkPathView;
|
|||||||
class SkRBuffer;
|
class SkRBuffer;
|
||||||
class SkWBuffer;
|
class SkWBuffer;
|
||||||
|
|
||||||
|
enum class SkPathConvexity {
|
||||||
|
kConvex,
|
||||||
|
kConcave,
|
||||||
|
kUnknown,
|
||||||
|
};
|
||||||
|
|
||||||
|
enum class SkPathFirstDirection {
|
||||||
|
kCW, // == SkPathDirection::kCW
|
||||||
|
kCCW, // == SkPathDirection::kCCW
|
||||||
|
kUnknown,
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Holds the path verbs and points. It is versioned by a generation ID. None of its public methods
|
* Holds the path verbs and points. It is versioned by a generation ID. None of its public methods
|
||||||
* modify the contents. To modify or append to the verbs/points wrap the SkPathRef in an
|
* modify the contents. To modify or append to the verbs/points wrap the SkPathRef in an
|
||||||
@ -338,7 +350,7 @@ public:
|
|||||||
bool isValid() const;
|
bool isValid() const;
|
||||||
SkDEBUGCODE(void validate() const { SkASSERT(this->isValid()); } )
|
SkDEBUGCODE(void validate() const { SkASSERT(this->isValid()); } )
|
||||||
|
|
||||||
SkPathView view(SkPathFillType, SkPathConvexityType) const;
|
SkPathView view(SkPathFillType, SkPathConvexity) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
enum SerializationOffsets {
|
enum SerializationOffsets {
|
||||||
|
@ -67,7 +67,7 @@ static bool is_degenerate(const SkPath& path) {
|
|||||||
class SkAutoDisableDirectionCheck {
|
class SkAutoDisableDirectionCheck {
|
||||||
public:
|
public:
|
||||||
SkAutoDisableDirectionCheck(SkPath* path) : fPath(path) {
|
SkAutoDisableDirectionCheck(SkPath* path) : fPath(path) {
|
||||||
fSaved = static_cast<SkPathPriv::FirstDirection>(fPath->getFirstDirection());
|
fSaved = static_cast<SkPathFirstDirection>(fPath->getFirstDirection());
|
||||||
}
|
}
|
||||||
|
|
||||||
~SkAutoDisableDirectionCheck() {
|
~SkAutoDisableDirectionCheck() {
|
||||||
@ -75,8 +75,8 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
SkPath* fPath;
|
SkPath* fPath;
|
||||||
SkPathPriv::FirstDirection fSaved;
|
SkPathFirstDirection fSaved;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* This class's constructor/destructor bracket a path editing operation. It is
|
/* This class's constructor/destructor bracket a path editing operation. It is
|
||||||
@ -107,8 +107,8 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
~SkAutoPathBoundsUpdate() {
|
~SkAutoPathBoundsUpdate() {
|
||||||
fPath->setConvexityType(fDegenerate ? SkPathConvexityType::kConvex
|
fPath->setConvexity(fDegenerate ? SkPathConvexity::kConvex
|
||||||
: SkPathConvexityType::kUnknown);
|
: SkPathConvexity::kUnknown);
|
||||||
if ((fEmpty || fHasValidBounds) && fRect.isFinite()) {
|
if ((fEmpty || fHasValidBounds) && fRect.isFinite()) {
|
||||||
fPath->setBounds(fRect);
|
fPath->setBounds(fRect);
|
||||||
}
|
}
|
||||||
@ -147,12 +147,12 @@ SkPath::SkPath()
|
|||||||
fIsVolatile = false;
|
fIsVolatile = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
SkPath::SkPath(sk_sp<SkPathRef> pr, SkPathFillType ft, bool isVolatile, SkPathConvexityType ct,
|
SkPath::SkPath(sk_sp<SkPathRef> pr, SkPathFillType ft, bool isVolatile, SkPathConvexity ct,
|
||||||
uint8_t firstDirection)
|
SkPathFirstDirection firstDirection)
|
||||||
: fPathRef(std::move(pr))
|
: fPathRef(std::move(pr))
|
||||||
, fLastMoveToIndex(INITIAL_LASTMOVETOINDEX_VALUE)
|
, fLastMoveToIndex(INITIAL_LASTMOVETOINDEX_VALUE)
|
||||||
, fConvexity((uint8_t)ct)
|
, fConvexity((uint8_t)ct)
|
||||||
, fFirstDirection(firstDirection)
|
, fFirstDirection((uint8_t)firstDirection)
|
||||||
, fFillType((unsigned)ft)
|
, fFillType((unsigned)ft)
|
||||||
, fIsVolatile(isVolatile)
|
, fIsVolatile(isVolatile)
|
||||||
{}
|
{}
|
||||||
@ -161,8 +161,8 @@ void SkPath::resetFields() {
|
|||||||
//fPathRef is assumed to have been emptied by the caller.
|
//fPathRef is assumed to have been emptied by the caller.
|
||||||
fLastMoveToIndex = INITIAL_LASTMOVETOINDEX_VALUE;
|
fLastMoveToIndex = INITIAL_LASTMOVETOINDEX_VALUE;
|
||||||
fFillType = SkToU8(SkPathFillType::kWinding);
|
fFillType = SkToU8(SkPathFillType::kWinding);
|
||||||
this->setConvexityType(SkPathConvexityType::kUnknown);
|
this->setConvexity(SkPathConvexity::kUnknown);
|
||||||
this->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
this->setFirstDirection(SkPathFirstDirection::kUnknown);
|
||||||
|
|
||||||
// We don't touch Android's fSourcePath. It's used to track texture garbage collection, so we
|
// We don't touch Android's fSourcePath. It's used to track texture garbage collection, so we
|
||||||
// don't want to muck with it if it's been set to something non-nullptr.
|
// don't want to muck with it if it's been set to something non-nullptr.
|
||||||
@ -196,7 +196,7 @@ void SkPath::copyFields(const SkPath& that) {
|
|||||||
fIsVolatile = that.fIsVolatile;
|
fIsVolatile = that.fIsVolatile;
|
||||||
|
|
||||||
// Non-atomic assignment of atomic values.
|
// Non-atomic assignment of atomic values.
|
||||||
this->setConvexityType(that.getConvexityTypeOrUnknown());
|
this->setConvexity(that.getConvexityOrUnknown());
|
||||||
this->setFirstDirection(that.getFirstDirection());
|
this->setFirstDirection(that.getFirstDirection());
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -221,18 +221,18 @@ void SkPath::swap(SkPath& that) {
|
|||||||
that.fIsVolatile = iv;
|
that.fIsVolatile = iv;
|
||||||
|
|
||||||
// Non-atomic swaps of atomic values.
|
// Non-atomic swaps of atomic values.
|
||||||
SkPathConvexityType c = this->getConvexityTypeOrUnknown();
|
SkPathConvexity c = this->getConvexityOrUnknown();
|
||||||
this->setConvexityType(that.getConvexityTypeOrUnknown());
|
this->setConvexity(that.getConvexityOrUnknown());
|
||||||
that.setConvexityType(c);
|
that.setConvexity(c);
|
||||||
|
|
||||||
uint8_t fd = this->getFirstDirection();
|
SkPathFirstDirection fd = this->getFirstDirection();
|
||||||
this->setFirstDirection(that.getFirstDirection());
|
this->setFirstDirection(that.getFirstDirection());
|
||||||
that.setFirstDirection(fd);
|
that.setFirstDirection(fd);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SkPathView SkPath::view() const {
|
SkPathView SkPath::view() const {
|
||||||
return fPathRef->view(this->getFillType(), this->getConvexityType());
|
return fPathRef->view(this->getFillType(), this->getConvexity());
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
@ -261,10 +261,10 @@ bool SkPath::interpolate(const SkPath& ending, SkScalar weight, SkPath* out) con
|
|||||||
static inline bool check_edge_against_rect(const SkPoint& p0,
|
static inline bool check_edge_against_rect(const SkPoint& p0,
|
||||||
const SkPoint& p1,
|
const SkPoint& p1,
|
||||||
const SkRect& rect,
|
const SkRect& rect,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
const SkPoint* edgeBegin;
|
const SkPoint* edgeBegin;
|
||||||
SkVector v;
|
SkVector v;
|
||||||
if (SkPathPriv::kCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCW == dir) {
|
||||||
v = p1 - p0;
|
v = p1 - p0;
|
||||||
edgeBegin = &p0;
|
edgeBegin = &p0;
|
||||||
} else {
|
} else {
|
||||||
@ -290,7 +290,7 @@ bool SkPath::conservativelyContainsRect(const SkRect& rect) const {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
SkPathPriv::FirstDirection direction;
|
SkPathFirstDirection direction;
|
||||||
if (!SkPathPriv::CheapComputeFirstDirection(*this, &direction)) {
|
if (!SkPathPriv::CheapComputeFirstDirection(*this, &direction)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -574,27 +574,27 @@ void SkPath::setLastPt(SkScalar x, SkScalar y) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// This is the public-facing non-const setConvexity().
|
// This is the public-facing non-const setConvexity().
|
||||||
void SkPath::setConvexityType(SkPathConvexityType c) {
|
void SkPath::setConvexity(SkPathConvexity c) {
|
||||||
fConvexity.store((uint8_t)c, std::memory_order_relaxed);
|
fConvexity.store((uint8_t)c, std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Const hooks for working with fConvexity and fFirstDirection from const methods.
|
// Const hooks for working with fConvexity and fFirstDirection from const methods.
|
||||||
void SkPath::setConvexityType(SkPathConvexityType c) const {
|
void SkPath::setConvexity(SkPathConvexity c) const {
|
||||||
fConvexity.store((uint8_t)c, std::memory_order_relaxed);
|
fConvexity.store((uint8_t)c, std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
void SkPath::setFirstDirection(uint8_t d) const {
|
void SkPath::setFirstDirection(SkPathFirstDirection d) const {
|
||||||
fFirstDirection.store(d, std::memory_order_relaxed);
|
fFirstDirection.store((uint8_t)d, std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
uint8_t SkPath::getFirstDirection() const {
|
SkPathFirstDirection SkPath::getFirstDirection() const {
|
||||||
return fFirstDirection.load(std::memory_order_relaxed);
|
return (SkPathFirstDirection)fFirstDirection.load(std::memory_order_relaxed);
|
||||||
}
|
}
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////////
|
||||||
// Construction methods
|
// Construction methods
|
||||||
|
|
||||||
SkPath& SkPath::dirtyAfterEdit() {
|
SkPath& SkPath::dirtyAfterEdit() {
|
||||||
this->setConvexityType(SkPathConvexityType::kUnknown);
|
this->setConvexity(SkPathConvexity::kUnknown);
|
||||||
this->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
this->setFirstDirection(SkPathFirstDirection::kUnknown);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -786,8 +786,8 @@ SkPath& SkPath::addRect(SkScalar left, SkScalar top, SkScalar right,
|
|||||||
|
|
||||||
SkPath& SkPath::addRect(const SkRect &rect, SkPathDirection dir, unsigned startIndex) {
|
SkPath& SkPath::addRect(const SkRect &rect, SkPathDirection dir, unsigned startIndex) {
|
||||||
assert_known_direction(dir);
|
assert_known_direction(dir);
|
||||||
this->setFirstDirection(this->hasOnlyMoveTos() ? (SkPathPriv::FirstDirection)dir
|
this->setFirstDirection(this->hasOnlyMoveTos() ? (SkPathFirstDirection)dir
|
||||||
: SkPathPriv::kUnknown_FirstDirection);
|
: SkPathFirstDirection::kUnknown);
|
||||||
SkAutoDisableDirectionCheck addc(this);
|
SkAutoDisableDirectionCheck addc(this);
|
||||||
SkAutoPathBoundsUpdate apbu(this, rect);
|
SkAutoPathBoundsUpdate apbu(this, rect);
|
||||||
|
|
||||||
@ -938,8 +938,8 @@ SkPath& SkPath::addRRect(const SkRRect &rrect, SkPathDirection dir, unsigned sta
|
|||||||
// degenerate(oval) => line points are collapsing
|
// degenerate(oval) => line points are collapsing
|
||||||
this->addOval(bounds, dir, startIndex / 2);
|
this->addOval(bounds, dir, startIndex / 2);
|
||||||
} else {
|
} else {
|
||||||
this->setFirstDirection(this->hasOnlyMoveTos() ? (SkPathPriv::FirstDirection)dir
|
this->setFirstDirection(this->hasOnlyMoveTos() ? (SkPathFirstDirection)dir
|
||||||
: SkPathPriv::kUnknown_FirstDirection);
|
: SkPathFirstDirection::kUnknown);
|
||||||
|
|
||||||
SkAutoPathBoundsUpdate apbu(this, bounds);
|
SkAutoPathBoundsUpdate apbu(this, bounds);
|
||||||
SkAutoDisableDirectionCheck addc(this);
|
SkAutoDisableDirectionCheck addc(this);
|
||||||
@ -1045,9 +1045,9 @@ SkPath& SkPath::addOval(const SkRect &oval, SkPathDirection dir, unsigned startP
|
|||||||
*/
|
*/
|
||||||
bool isOval = hasOnlyMoveTos();
|
bool isOval = hasOnlyMoveTos();
|
||||||
if (isOval) {
|
if (isOval) {
|
||||||
this->setFirstDirection((SkPathPriv::FirstDirection)dir);
|
this->setFirstDirection((SkPathFirstDirection)dir);
|
||||||
} else {
|
} else {
|
||||||
this->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
this->setFirstDirection(SkPathFirstDirection::kUnknown);
|
||||||
}
|
}
|
||||||
|
|
||||||
SkAutoDisableDirectionCheck addc(this);
|
SkAutoDisableDirectionCheck addc(this);
|
||||||
@ -1617,9 +1617,9 @@ void SkPath::transform(const SkMatrix& matrix, SkPath* dst, SkApplyPerspectiveCl
|
|||||||
dst->swap(tmp);
|
dst->swap(tmp);
|
||||||
SkPathRef::Editor ed(&dst->fPathRef);
|
SkPathRef::Editor ed(&dst->fPathRef);
|
||||||
matrix.mapPoints(ed.writablePoints(), ed.pathRef()->countPoints());
|
matrix.mapPoints(ed.writablePoints(), ed.pathRef()->countPoints());
|
||||||
dst->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
dst->setFirstDirection(SkPathFirstDirection::kUnknown);
|
||||||
} else {
|
} else {
|
||||||
SkPathConvexityType convexity = this->getConvexityTypeOrUnknown();
|
SkPathConvexity convexity = this->getConvexityOrUnknown();
|
||||||
|
|
||||||
SkPathRef::CreateTransformedCopy(&dst->fPathRef, *fPathRef, matrix);
|
SkPathRef::CreateTransformedCopy(&dst->fPathRef, *fPathRef, matrix);
|
||||||
|
|
||||||
@ -1639,13 +1639,13 @@ void SkPath::transform(const SkMatrix& matrix, SkPath* dst, SkApplyPerspectiveCl
|
|||||||
// check, and keep convex paths marked as such after a general transform...
|
// check, and keep convex paths marked as such after a general transform...
|
||||||
//
|
//
|
||||||
if (matrix.isScaleTranslate() && SkPathPriv::IsAxisAligned(*this)) {
|
if (matrix.isScaleTranslate() && SkPathPriv::IsAxisAligned(*this)) {
|
||||||
dst->setConvexityType(convexity);
|
dst->setConvexity(convexity);
|
||||||
} else {
|
} else {
|
||||||
dst->setConvexityType(SkPathConvexityType::kUnknown);
|
dst->setConvexity(SkPathConvexity::kUnknown);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this->getFirstDirection() == SkPathPriv::kUnknown_FirstDirection) {
|
if (this->getFirstDirection() == SkPathFirstDirection::kUnknown) {
|
||||||
dst->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
dst->setFirstDirection(SkPathFirstDirection::kUnknown);
|
||||||
} else {
|
} else {
|
||||||
SkScalar det2x2 =
|
SkScalar det2x2 =
|
||||||
matrix.get(SkMatrix::kMScaleX) * matrix.get(SkMatrix::kMScaleY) -
|
matrix.get(SkMatrix::kMScaleX) * matrix.get(SkMatrix::kMScaleY) -
|
||||||
@ -1653,11 +1653,11 @@ void SkPath::transform(const SkMatrix& matrix, SkPath* dst, SkApplyPerspectiveCl
|
|||||||
if (det2x2 < 0) {
|
if (det2x2 < 0) {
|
||||||
dst->setFirstDirection(
|
dst->setFirstDirection(
|
||||||
SkPathPriv::OppositeFirstDirection(
|
SkPathPriv::OppositeFirstDirection(
|
||||||
(SkPathPriv::FirstDirection)this->getFirstDirection()));
|
(SkPathFirstDirection)this->getFirstDirection()));
|
||||||
} else if (det2x2 > 0) {
|
} else if (det2x2 > 0) {
|
||||||
dst->setFirstDirection(this->getFirstDirection());
|
dst->setFirstDirection(this->getFirstDirection());
|
||||||
} else {
|
} else {
|
||||||
dst->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
dst->setFirstDirection(SkPathFirstDirection::kUnknown);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2040,7 +2040,7 @@ static bool almost_equal(SkScalar compA, SkScalar compB) {
|
|||||||
struct Convexicator {
|
struct Convexicator {
|
||||||
|
|
||||||
/** The direction returned is only valid if the path is determined convex */
|
/** The direction returned is only valid if the path is determined convex */
|
||||||
SkPathPriv::FirstDirection getFirstDirection() const { return fFirstDirection; }
|
SkPathFirstDirection getFirstDirection() const { return fFirstDirection; }
|
||||||
|
|
||||||
void setMovePt(const SkPoint& pt) {
|
void setMovePt(const SkPoint& pt) {
|
||||||
fPriorPt = fLastPt = fCurrPt = pt;
|
fPriorPt = fLastPt = fCurrPt = pt;
|
||||||
@ -2062,7 +2062,7 @@ struct Convexicator {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static SkPathConvexityType BySign(const SkPoint points[], int count) {
|
static SkPathConvexity BySign(const SkPoint points[], int count) {
|
||||||
const SkPoint* last = points + count;
|
const SkPoint* last = points + count;
|
||||||
SkPoint currPt = *points++;
|
SkPoint currPt = *points++;
|
||||||
SkPoint firstPt = currPt;
|
SkPoint firstPt = currPt;
|
||||||
@ -2076,14 +2076,14 @@ struct Convexicator {
|
|||||||
if (!vec.isZero()) {
|
if (!vec.isZero()) {
|
||||||
// give up if vector construction failed
|
// give up if vector construction failed
|
||||||
if (!vec.isFinite()) {
|
if (!vec.isFinite()) {
|
||||||
return SkPathConvexityType::kUnknown;
|
return SkPathConvexity::kUnknown;
|
||||||
}
|
}
|
||||||
int sx = sign(vec.fX);
|
int sx = sign(vec.fX);
|
||||||
int sy = sign(vec.fY);
|
int sy = sign(vec.fY);
|
||||||
dxes += (sx != lastSx);
|
dxes += (sx != lastSx);
|
||||||
dyes += (sy != lastSy);
|
dyes += (sy != lastSy);
|
||||||
if (dxes > 3 || dyes > 3) {
|
if (dxes > 3 || dyes > 3) {
|
||||||
return SkPathConvexityType::kConcave;
|
return SkPathConvexity::kConcave;
|
||||||
}
|
}
|
||||||
lastSx = sx;
|
lastSx = sx;
|
||||||
lastSy = sy;
|
lastSy = sy;
|
||||||
@ -2095,7 +2095,7 @@ struct Convexicator {
|
|||||||
}
|
}
|
||||||
points = &firstPt;
|
points = &firstPt;
|
||||||
}
|
}
|
||||||
return SkPathConvexityType::kConvex; // that is, it may be convex, don't know yet
|
return SkPathConvexity::kConvex; // that is, it may be convex, don't know yet
|
||||||
}
|
}
|
||||||
|
|
||||||
bool close() {
|
bool close() {
|
||||||
@ -2138,10 +2138,10 @@ private:
|
|||||||
case kRight_DirChange:
|
case kRight_DirChange:
|
||||||
if (kInvalid_DirChange == fExpectedDir) {
|
if (kInvalid_DirChange == fExpectedDir) {
|
||||||
fExpectedDir = dir;
|
fExpectedDir = dir;
|
||||||
fFirstDirection = (kRight_DirChange == dir) ? SkPathPriv::kCW_FirstDirection
|
fFirstDirection = (kRight_DirChange == dir) ? SkPathFirstDirection::kCW
|
||||||
: SkPathPriv::kCCW_FirstDirection;
|
: SkPathFirstDirection::kCCW;
|
||||||
} else if (dir != fExpectedDir) {
|
} else if (dir != fExpectedDir) {
|
||||||
fFirstDirection = SkPathPriv::kUnknown_FirstDirection;
|
fFirstDirection = SkPathFirstDirection::kUnknown;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
fLastVec = curVec;
|
fLastVec = curVec;
|
||||||
@ -2170,24 +2170,24 @@ private:
|
|||||||
SkPoint fCurrPt {0, 0};
|
SkPoint fCurrPt {0, 0};
|
||||||
SkVector fLastVec {0, 0};
|
SkVector fLastVec {0, 0};
|
||||||
DirChange fExpectedDir { kInvalid_DirChange };
|
DirChange fExpectedDir { kInvalid_DirChange };
|
||||||
SkPathPriv::FirstDirection fFirstDirection { SkPathPriv::kUnknown_FirstDirection };
|
SkPathFirstDirection fFirstDirection { SkPathFirstDirection::kUnknown };
|
||||||
int fReversals { 0 };
|
int fReversals { 0 };
|
||||||
bool fIsFinite { true };
|
bool fIsFinite { true };
|
||||||
};
|
};
|
||||||
|
|
||||||
SkPathConvexityType SkPath::computeConvexity() const {
|
SkPathConvexity SkPath::computeConvexity() const {
|
||||||
SkPoint pts[4];
|
SkPoint pts[4];
|
||||||
SkPath::Verb verb;
|
SkPath::Verb verb;
|
||||||
SkPath::Iter iter(*this, true);
|
SkPath::Iter iter(*this, true);
|
||||||
|
|
||||||
auto setComputedConvexity = [=](SkPathConvexityType convexity){
|
auto setComputedConvexity = [=](SkPathConvexity convexity){
|
||||||
SkASSERT(SkPathConvexityType::kUnknown != convexity);
|
SkASSERT(SkPathConvexity::kUnknown != convexity);
|
||||||
this->setConvexityType(convexity);
|
this->setConvexity(convexity);
|
||||||
return convexity;
|
return convexity;
|
||||||
};
|
};
|
||||||
|
|
||||||
auto setFail = [=](){
|
auto setFail = [=](){
|
||||||
return setComputedConvexity(SkPathConvexityType::kConcave);
|
return setComputedConvexity(SkPathConvexity::kConcave);
|
||||||
};
|
};
|
||||||
|
|
||||||
// Check to see if path changes direction more than three times as quick concave test
|
// Check to see if path changes direction more than three times as quick concave test
|
||||||
@ -2204,9 +2204,9 @@ SkPathConvexityType SkPath::computeConvexity() const {
|
|||||||
++points;
|
++points;
|
||||||
}
|
}
|
||||||
--points;
|
--points;
|
||||||
SkPathConvexityType convexity = Convexicator::BySign(points, (int) (last - points));
|
SkPathConvexity convexity = Convexicator::BySign(points, (int) (last - points));
|
||||||
if (SkPathConvexityType::kConvex != convexity) {
|
if (SkPathConvexity::kConvex != convexity) {
|
||||||
return setComputedConvexity(SkPathConvexityType::kConcave);
|
return setComputedConvexity(SkPathConvexity::kConcave);
|
||||||
}
|
}
|
||||||
iter.setPath(*this, true);
|
iter.setPath(*this, true);
|
||||||
} else if (!this->isFinite()) {
|
} else if (!this->isFinite()) {
|
||||||
@ -2221,7 +2221,7 @@ SkPathConvexityType SkPath::computeConvexity() const {
|
|||||||
switch (verb) {
|
switch (verb) {
|
||||||
case kMove_Verb:
|
case kMove_Verb:
|
||||||
if (++contourCount > 1) {
|
if (++contourCount > 1) {
|
||||||
return setComputedConvexity(SkPathConvexityType::kConcave);
|
return setComputedConvexity(SkPathConvexity::kConcave);
|
||||||
}
|
}
|
||||||
state.setMovePt(pts[0]);
|
state.setMovePt(pts[0]);
|
||||||
count = 0;
|
count = 0;
|
||||||
@ -2245,7 +2245,7 @@ SkPathConvexityType SkPath::computeConvexity() const {
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
SkDEBUGFAIL("bad verb");
|
SkDEBUGFAIL("bad verb");
|
||||||
return setComputedConvexity(SkPathConvexityType::kConcave);
|
return setComputedConvexity(SkPathConvexity::kConcave);
|
||||||
}
|
}
|
||||||
for (int i = 1; i <= count; i++) {
|
for (int i = 1; i <= count; i++) {
|
||||||
if (!state.addPt(pts[i])) {
|
if (!state.addPt(pts[i])) {
|
||||||
@ -2254,20 +2254,20 @@ SkPathConvexityType SkPath::computeConvexity() const {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this->getFirstDirection() == SkPathPriv::kUnknown_FirstDirection) {
|
if (this->getFirstDirection() == SkPathFirstDirection::kUnknown) {
|
||||||
if (state.getFirstDirection() == SkPathPriv::kUnknown_FirstDirection
|
if (state.getFirstDirection() == SkPathFirstDirection::kUnknown
|
||||||
&& !this->getBounds().isEmpty()) {
|
&& !this->getBounds().isEmpty()) {
|
||||||
return setComputedConvexity(state.reversals() < 3 ?
|
return setComputedConvexity(state.reversals() < 3 ?
|
||||||
SkPathConvexityType::kConvex : SkPathConvexityType::kConcave);
|
SkPathConvexity::kConvex : SkPathConvexity::kConcave);
|
||||||
}
|
}
|
||||||
this->setFirstDirection(state.getFirstDirection());
|
this->setFirstDirection(state.getFirstDirection());
|
||||||
}
|
}
|
||||||
return setComputedConvexity(SkPathConvexityType::kConvex);
|
return setComputedConvexity(SkPathConvexity::kConvex);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkPathPriv::IsConvex(const SkPoint points[], int count) {
|
bool SkPathPriv::IsConvex(const SkPoint points[], int count) {
|
||||||
SkPathConvexityType convexity = Convexicator::BySign(points, count);
|
SkPathConvexity convexity = Convexicator::BySign(points, count);
|
||||||
if (SkPathConvexityType::kConvex != convexity) {
|
if (SkPathConvexity::kConvex != convexity) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
Convexicator state;
|
Convexicator state;
|
||||||
@ -2283,7 +2283,7 @@ bool SkPathPriv::IsConvex(const SkPoint points[], int count) {
|
|||||||
if (!state.close()) {
|
if (!state.close()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return state.getFirstDirection() != SkPathPriv::kUnknown_FirstDirection
|
return state.getFirstDirection() != SkPathFirstDirection::kUnknown
|
||||||
|| state.reversals() < 3;
|
|| state.reversals() < 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2443,8 +2443,8 @@ static int find_min_max_x_at_y(const SkPoint pts[], int index, int n,
|
|||||||
return minIndex;
|
return minIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void crossToDir(SkScalar cross, SkPathPriv::FirstDirection* dir) {
|
static void crossToDir(SkScalar cross, SkPathFirstDirection* dir) {
|
||||||
*dir = cross > 0 ? SkPathPriv::kCW_FirstDirection : SkPathPriv::kCCW_FirstDirection;
|
*dir = cross > 0 ? SkPathFirstDirection::kCW : SkPathFirstDirection::kCCW;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2455,18 +2455,18 @@ static void crossToDir(SkScalar cross, SkPathPriv::FirstDirection* dir) {
|
|||||||
* that is outer most (or at least has the global y-max) before we can consider
|
* that is outer most (or at least has the global y-max) before we can consider
|
||||||
* its cross product.
|
* its cross product.
|
||||||
*/
|
*/
|
||||||
bool SkPathPriv::CheapComputeFirstDirection(const SkPath& path, FirstDirection* dir) {
|
bool SkPathPriv::CheapComputeFirstDirection(const SkPath& path, SkPathFirstDirection* dir) {
|
||||||
auto d = path.getFirstDirection();
|
auto d = path.getFirstDirection();
|
||||||
if (d != kUnknown_FirstDirection) {
|
if (d != SkPathFirstDirection::kUnknown) {
|
||||||
*dir = static_cast<FirstDirection>(d);
|
*dir = d;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// We don't want to pay the cost for computing convexity if it is unknown,
|
// We don't want to pay the cost for computing convexity if it is unknown,
|
||||||
// so we call getConvexityOrUnknown() instead of isConvex().
|
// so we call getConvexityOrUnknown() instead of isConvex().
|
||||||
if (path.getConvexityTypeOrUnknown() == SkPathConvexityType::kConvex) {
|
if (path.getConvexityOrUnknown() == SkPathConvexity::kConvex) {
|
||||||
SkASSERT(path.getFirstDirection() == kUnknown_FirstDirection);
|
SkASSERT(path.getFirstDirection() == SkPathFirstDirection::kUnknown);
|
||||||
*dir = static_cast<FirstDirection>(path.getFirstDirection());
|
*dir = path.getFirstDirection();
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3179,7 +3179,7 @@ void SkPathPriv::CreateDrawArcPath(SkPath* path, const SkRect& oval, SkScalar st
|
|||||||
path->moveTo(oval.centerX(), oval.centerY());
|
path->moveTo(oval.centerX(), oval.centerY());
|
||||||
}
|
}
|
||||||
auto firstDir =
|
auto firstDir =
|
||||||
sweepAngle > 0 ? SkPathPriv::kCW_FirstDirection : SkPathPriv::kCCW_FirstDirection;
|
sweepAngle > 0 ? SkPathFirstDirection::kCW : SkPathFirstDirection::kCCW;
|
||||||
bool convex = DrawArcIsConvex(sweepAngle, useCenter, isFillNoPathEffect);
|
bool convex = DrawArcIsConvex(sweepAngle, useCenter, isFillNoPathEffect);
|
||||||
// Arc to mods at 360 and drawArc is not supposed to.
|
// Arc to mods at 360 and drawArc is not supposed to.
|
||||||
bool forceMoveTo = !useCenter;
|
bool forceMoveTo = !useCenter;
|
||||||
@ -3203,7 +3203,7 @@ void SkPathPriv::CreateDrawArcPath(SkPath* path, const SkRect& oval, SkScalar st
|
|||||||
if (useCenter) {
|
if (useCenter) {
|
||||||
path->close();
|
path->close();
|
||||||
}
|
}
|
||||||
path->setConvexityType(convex ? SkPathConvexityType::kConvex : SkPathConvexityType::kConcave);
|
path->setConvexity(convex ? SkPathConvexity::kConvex : SkPathConvexity::kConcave);
|
||||||
path->setFirstDirection(firstDir);
|
path->setFirstDirection(firstDir);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3385,7 +3385,7 @@ SkPath SkPath::Make(const SkPoint pts[], int pointCount,
|
|||||||
SkTDArray<uint8_t>(vbs, verbCount),
|
SkTDArray<uint8_t>(vbs, verbCount),
|
||||||
SkTDArray<SkScalar>(ws, info.weights),
|
SkTDArray<SkScalar>(ws, info.weights),
|
||||||
info.segmentMask)),
|
info.segmentMask)),
|
||||||
ft, isVolatile, SkPathConvexityType::kUnknown, SkPathPriv::kUnknown_FirstDirection);
|
ft, isVolatile, SkPathConvexity::kUnknown, SkPathFirstDirection::kUnknown);
|
||||||
}
|
}
|
||||||
|
|
||||||
SkPath SkPath::Rect(const SkRect& r, SkPathDirection dir, unsigned startIndex) {
|
SkPath SkPath::Rect(const SkRect& r, SkPathDirection dir, unsigned startIndex) {
|
||||||
|
@ -35,7 +35,7 @@ SkPathBuilder& SkPathBuilder::reset() {
|
|||||||
fNeedsMoveVerb = true;
|
fNeedsMoveVerb = true;
|
||||||
|
|
||||||
// testing
|
// testing
|
||||||
fOverrideConvexity = SkPathConvexityType::kUnknown;
|
fOverrideConvexity = SkPathConvexity::kUnknown;
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
@ -49,7 +49,7 @@ void SkPathBuilder::incReserve(int extraPtCount, int extraVbCount) {
|
|||||||
* Some old behavior in SkPath -- should we keep it?
|
* Some old behavior in SkPath -- should we keep it?
|
||||||
*
|
*
|
||||||
* After each edit (i.e. adding a verb)
|
* After each edit (i.e. adding a verb)
|
||||||
this->setConvexityType(SkPathConvexityType::kUnknown);
|
this->setConvexityType(SkPathConvexity::kUnknown);
|
||||||
this->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
this->setFirstDirection(SkPathPriv::kUnknown_FirstDirection);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -150,24 +150,24 @@ SkPathBuilder& SkPathBuilder::rCubicTo(SkPoint p1, SkPoint p2, SkPoint p3) {
|
|||||||
///////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
SkPath SkPathBuilder::make(sk_sp<SkPathRef> pr) const {
|
SkPath SkPathBuilder::make(sk_sp<SkPathRef> pr) const {
|
||||||
auto convexity = SkPathConvexityType::kUnknown;
|
auto convexity = SkPathConvexity::kUnknown;
|
||||||
SkPathPriv::FirstDirection dir = SkPathPriv::kUnknown_FirstDirection;
|
SkPathFirstDirection dir = SkPathFirstDirection::kUnknown;
|
||||||
|
|
||||||
switch (fIsA) {
|
switch (fIsA) {
|
||||||
case kIsA_Oval:
|
case kIsA_Oval:
|
||||||
pr->setIsOval( true, fIsACCW, fIsAStart);
|
pr->setIsOval( true, fIsACCW, fIsAStart);
|
||||||
convexity = SkPathConvexityType::kConvex;
|
convexity = SkPathConvexity::kConvex;
|
||||||
dir = fIsACCW ? SkPathPriv::kCCW_FirstDirection : SkPathPriv::kCW_FirstDirection;
|
dir = fIsACCW ? SkPathFirstDirection::kCCW : SkPathFirstDirection::kCW;
|
||||||
break;
|
break;
|
||||||
case kIsA_RRect:
|
case kIsA_RRect:
|
||||||
pr->setIsRRect(true, fIsACCW, fIsAStart);
|
pr->setIsRRect(true, fIsACCW, fIsAStart);
|
||||||
convexity = SkPathConvexityType::kConvex;
|
convexity = SkPathConvexity::kConvex;
|
||||||
dir = fIsACCW ? SkPathPriv::kCCW_FirstDirection : SkPathPriv::kCW_FirstDirection;
|
dir = fIsACCW ? SkPathFirstDirection::kCCW : SkPathFirstDirection::kCW;
|
||||||
break;
|
break;
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fOverrideConvexity != SkPathConvexityType::kUnknown) {
|
if (fOverrideConvexity != SkPathConvexity::kUnknown) {
|
||||||
convexity = fOverrideConvexity;
|
convexity = fOverrideConvexity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -27,26 +27,20 @@ public:
|
|||||||
|
|
||||||
static constexpr SkScalar kW0PlaneDistance = 0.05f;
|
static constexpr SkScalar kW0PlaneDistance = 0.05f;
|
||||||
|
|
||||||
enum FirstDirection : int {
|
static SkPathFirstDirection AsFirstDirection(SkPathDirection dir) {
|
||||||
kCW_FirstDirection, // == SkPathDirection::kCW
|
|
||||||
kCCW_FirstDirection, // == SkPathDirection::kCCW
|
|
||||||
kUnknown_FirstDirection,
|
|
||||||
};
|
|
||||||
|
|
||||||
static FirstDirection AsFirstDirection(SkPathDirection dir) {
|
|
||||||
// since we agree numerically for the values in Direction, we can just cast.
|
// since we agree numerically for the values in Direction, we can just cast.
|
||||||
return (FirstDirection)dir;
|
return (SkPathFirstDirection)dir;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the opposite of the specified direction. kUnknown is its own
|
* Return the opposite of the specified direction. kUnknown is its own
|
||||||
* opposite.
|
* opposite.
|
||||||
*/
|
*/
|
||||||
static FirstDirection OppositeFirstDirection(FirstDirection dir) {
|
static SkPathFirstDirection OppositeFirstDirection(SkPathFirstDirection dir) {
|
||||||
static const FirstDirection gOppositeDir[] = {
|
static const SkPathFirstDirection gOppositeDir[] = {
|
||||||
kCCW_FirstDirection, kCW_FirstDirection, kUnknown_FirstDirection,
|
SkPathFirstDirection::kCCW, SkPathFirstDirection::kCW, SkPathFirstDirection::kUnknown,
|
||||||
};
|
};
|
||||||
return gOppositeDir[dir];
|
return gOppositeDir[(unsigned)dir];
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -56,7 +50,7 @@ public:
|
|||||||
* the dir parameter. If the direction was determined, it is cached to make
|
* the dir parameter. If the direction was determined, it is cached to make
|
||||||
* subsequent calls return quickly.
|
* subsequent calls return quickly.
|
||||||
*/
|
*/
|
||||||
static bool CheapComputeFirstDirection(const SkPath&, FirstDirection* dir);
|
static bool CheapComputeFirstDirection(const SkPath&, SkPathFirstDirection* dir);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns true if the path's direction can be computed via
|
* Returns true if the path's direction can be computed via
|
||||||
@ -64,8 +58,8 @@ public:
|
|||||||
* specified direction. If dir is kUnknown, returns true if the direction
|
* specified direction. If dir is kUnknown, returns true if the direction
|
||||||
* cannot be computed.
|
* cannot be computed.
|
||||||
*/
|
*/
|
||||||
static bool CheapIsFirstDirection(const SkPath& path, FirstDirection dir) {
|
static bool CheapIsFirstDirection(const SkPath& path, SkPathFirstDirection dir) {
|
||||||
FirstDirection computedDir = kUnknown_FirstDirection;
|
SkPathFirstDirection computedDir = SkPathFirstDirection::kUnknown;
|
||||||
(void)CheapComputeFirstDirection(path, &computedDir);
|
(void)CheapComputeFirstDirection(path, &computedDir);
|
||||||
return computedDir == dir;
|
return computedDir == dir;
|
||||||
}
|
}
|
||||||
@ -415,20 +409,20 @@ public:
|
|||||||
path->dirtyAfterEdit();
|
path->dirtyAfterEdit();
|
||||||
}
|
}
|
||||||
|
|
||||||
static SkPathConvexityType GetConvexityType(const SkPath& path) {
|
static SkPathConvexity GetConvexity(const SkPath& path) {
|
||||||
return path.getConvexityType();
|
return path.getConvexity();
|
||||||
}
|
}
|
||||||
static SkPathConvexityType GetConvexityTypeOrUnknown(const SkPath& path) {
|
static SkPathConvexity GetConvexityOrUnknown(const SkPath& path) {
|
||||||
return path.getConvexityTypeOrUnknown();
|
return path.getConvexityOrUnknown();
|
||||||
}
|
}
|
||||||
static void SetConvexityType(const SkPath& path, SkPathConvexityType c) {
|
static void SetConvexity(const SkPath& path, SkPathConvexity c) {
|
||||||
path.setConvexityType(c);
|
path.setConvexity(c);
|
||||||
}
|
}
|
||||||
static void SetConvexityType(SkPathBuilder* builder, SkPathConvexityType c) {
|
static void SetConvexity(SkPathBuilder* builder, SkPathConvexity c) {
|
||||||
builder->privateSetConvexityType(c);
|
builder->privateSetConvexity(c);
|
||||||
}
|
}
|
||||||
static void ForceComputeConvexity(const SkPath& path) {
|
static void ForceComputeConvexity(const SkPath& path) {
|
||||||
path.setConvexityType(SkPathConvexityType::kUnknown);
|
path.setConvexity(SkPathConvexity::kUnknown);
|
||||||
(void)path.isConvex();
|
(void)path.isConvex();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -686,7 +686,7 @@ bool SkPathRef::isValid() const {
|
|||||||
|
|
||||||
#include "src/core/SkPathView.h"
|
#include "src/core/SkPathView.h"
|
||||||
|
|
||||||
SkPathView SkPathRef::view(SkPathFillType ft, SkPathConvexityType ct) const {
|
SkPathView SkPathRef::view(SkPathFillType ft, SkPathConvexity ct) const {
|
||||||
return {
|
return {
|
||||||
{ fPoints.begin(), fPoints.size() },
|
{ fPoints.begin(), fPoints.size() },
|
||||||
{ fVerbs.begin(), fVerbs.size() },
|
{ fVerbs.begin(), fVerbs.size() },
|
||||||
|
@ -10,12 +10,13 @@
|
|||||||
#include "include/core/SkPathTypes.h"
|
#include "include/core/SkPathTypes.h"
|
||||||
#include "include/core/SkPoint.h"
|
#include "include/core/SkPoint.h"
|
||||||
#include "include/core/SkRect.h"
|
#include "include/core/SkRect.h"
|
||||||
|
#include "include/private/SkPathRef.h"
|
||||||
#include "src/core/SkSpan.h"
|
#include "src/core/SkSpan.h"
|
||||||
|
|
||||||
struct SkPathView {
|
struct SkPathView {
|
||||||
SkPathView(SkSpan<const SkPoint> points, SkSpan<const uint8_t> verbs, SkSpan<const float> weights,
|
SkPathView(SkSpan<const SkPoint> points, SkSpan<const uint8_t> verbs, SkSpan<const float> weights,
|
||||||
SkPathFillType ft, SkPathConvexityType ct, const SkRect& bounds, unsigned segmentMask,
|
SkPathFillType ft, SkPathConvexity ct, const SkRect& bounds, unsigned segmentMask,
|
||||||
bool isFinite)
|
bool isFinite)
|
||||||
: fPoints(points)
|
: fPoints(points)
|
||||||
, fVerbs(verbs)
|
, fVerbs(verbs)
|
||||||
, fWeights(weights)
|
, fWeights(weights)
|
||||||
@ -29,7 +30,7 @@ struct SkPathView {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool isInverseFillType() const { return SkPathFillType_IsInverse(fFillType); }
|
bool isInverseFillType() const { return SkPathFillType_IsInverse(fFillType); }
|
||||||
bool isConvex() const { return fConvexity == SkPathConvexityType::kConvex; }
|
bool isConvex() const { return fConvexity == SkPathConvexity::kConvex; }
|
||||||
|
|
||||||
bool isEmpty() const { return fPoints.size() == 0; }
|
bool isEmpty() const { return fPoints.size() == 0; }
|
||||||
|
|
||||||
@ -42,10 +43,10 @@ struct SkPathView {
|
|||||||
|
|
||||||
SkRect fBounds;
|
SkRect fBounds;
|
||||||
|
|
||||||
SkPathFillType fFillType;
|
SkPathFillType fFillType;
|
||||||
SkPathConvexityType fConvexity;
|
SkPathConvexity fConvexity;
|
||||||
uint8_t fSegmentMask;
|
uint8_t fSegmentMask;
|
||||||
bool fIsFinite;
|
bool fIsFinite;
|
||||||
|
|
||||||
#ifdef SK_DEBUG
|
#ifdef SK_DEBUG
|
||||||
void validate() const;
|
void validate() const;
|
||||||
@ -61,7 +62,7 @@ static inline SkPathView SkPathView_triangle(const SkPoint pts[3], const SkRect&
|
|||||||
(uint8_t)SkPathVerb::kLine,
|
(uint8_t)SkPathVerb::kLine,
|
||||||
};
|
};
|
||||||
return SkPathView({pts, 3}, SkMakeSpan(verbs), {},
|
return SkPathView({pts, 3}, SkMakeSpan(verbs), {},
|
||||||
SkPathFillType::kWinding, SkPathConvexityType::kConvex,
|
SkPathFillType::kWinding, SkPathConvexity::kConvex,
|
||||||
bounds, kLine_SkPathSegmentMask, true);
|
bounds, kLine_SkPathSegmentMask, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -73,6 +74,6 @@ static inline SkPathView SkPathView_quad(const SkPoint pts[4], const SkRect& bou
|
|||||||
(uint8_t)SkPathVerb::kLine,
|
(uint8_t)SkPathVerb::kLine,
|
||||||
};
|
};
|
||||||
return SkPathView({pts, 4}, SkMakeSpan(verbs), {},
|
return SkPathView({pts, 4}, SkMakeSpan(verbs), {},
|
||||||
SkPathFillType::kWinding, SkPathConvexityType::kConvex,
|
SkPathFillType::kWinding, SkPathConvexity::kConvex,
|
||||||
bounds, kLine_SkPathSegmentMask, true);
|
bounds, kLine_SkPathSegmentMask, true);
|
||||||
};
|
};
|
||||||
|
@ -73,7 +73,7 @@ size_t SkPath::writeToMemoryAsRRect(void* storage) const {
|
|||||||
return sizeNeeded;
|
return sizeNeeded;
|
||||||
}
|
}
|
||||||
|
|
||||||
int firstDir = isCCW ? SkPathPriv::kCCW_FirstDirection : SkPathPriv::kCW_FirstDirection;
|
int firstDir = isCCW ? (int)SkPathFirstDirection::kCCW : (int)SkPathFirstDirection::kCW;
|
||||||
int32_t packed = (fFillType << kFillType_SerializationShift) |
|
int32_t packed = (fFillType << kFillType_SerializationShift) |
|
||||||
(firstDir << kDirection_SerializationShift) |
|
(firstDir << kDirection_SerializationShift) |
|
||||||
(SerializationType::kRRect << kType_SerializationShift) |
|
(SerializationType::kRRect << kType_SerializationShift) |
|
||||||
@ -173,10 +173,10 @@ size_t SkPath::readAsRRect(const void* storage, size_t length) {
|
|||||||
SkRRect rrect;
|
SkRRect rrect;
|
||||||
int32_t start;
|
int32_t start;
|
||||||
switch (dir) {
|
switch (dir) {
|
||||||
case SkPathPriv::kCW_FirstDirection:
|
case (int)SkPathFirstDirection::kCW:
|
||||||
rrectDir = SkPathDirection::kCW;
|
rrectDir = SkPathDirection::kCW;
|
||||||
break;
|
break;
|
||||||
case SkPathPriv::kCCW_FirstDirection:
|
case (int)SkPathFirstDirection::kCCW:
|
||||||
rrectDir = SkPathDirection::kCCW;
|
rrectDir = SkPathDirection::kCCW;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -1504,7 +1504,7 @@ DONE:
|
|||||||
stroker.done(dst, lastSegment == SkPath::kLine_Verb);
|
stroker.done(dst, lastSegment == SkPath::kLine_Verb);
|
||||||
|
|
||||||
if (fDoFill && !ignoreCenter) {
|
if (fDoFill && !ignoreCenter) {
|
||||||
if (SkPathPriv::CheapIsFirstDirection(src, SkPathPriv::kCCW_FirstDirection)) {
|
if (SkPathPriv::CheapIsFirstDirection(src, SkPathFirstDirection::kCCW)) {
|
||||||
dst->reverseAddPath(src);
|
dst->reverseAddPath(src);
|
||||||
} else {
|
} else {
|
||||||
dst->addPath(src);
|
dst->addPath(src);
|
||||||
|
@ -134,16 +134,16 @@ sk_sp<SkPathEffect> SkStrokeAndFillPathEffect::Make() {
|
|||||||
void SkStrokeAndFillPE::flatten(SkWriteBuffer&) const {}
|
void SkStrokeAndFillPE::flatten(SkWriteBuffer&) const {}
|
||||||
|
|
||||||
static bool known_to_be_opposite_directions(const SkPath& a, const SkPath& b) {
|
static bool known_to_be_opposite_directions(const SkPath& a, const SkPath& b) {
|
||||||
auto a_dir = SkPathPriv::kUnknown_FirstDirection,
|
auto a_dir = SkPathFirstDirection::kUnknown,
|
||||||
b_dir = SkPathPriv::kUnknown_FirstDirection;
|
b_dir = SkPathFirstDirection::kUnknown;
|
||||||
(void)SkPathPriv::CheapComputeFirstDirection(a, &a_dir);
|
(void)SkPathPriv::CheapComputeFirstDirection(a, &a_dir);
|
||||||
(void)SkPathPriv::CheapComputeFirstDirection(b, &b_dir);
|
(void)SkPathPriv::CheapComputeFirstDirection(b, &b_dir);
|
||||||
|
|
||||||
return (a_dir == SkPathPriv::kCCW_FirstDirection &&
|
return (a_dir == SkPathFirstDirection::kCCW &&
|
||||||
b_dir == SkPathPriv::kCW_FirstDirection)
|
b_dir == SkPathFirstDirection::kCW)
|
||||||
||
|
||
|
||||||
(a_dir == SkPathPriv::kCW_FirstDirection &&
|
(a_dir == SkPathFirstDirection::kCW &&
|
||||||
b_dir == SkPathPriv::kCCW_FirstDirection);
|
b_dir == SkPathFirstDirection::kCCW);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SkStrokeAndFillPE::onFilterPath(SkPath* dst, const SkPath& src, SkStrokeRec* rec,
|
bool SkStrokeAndFillPE::onFilterPath(SkPath* dst, const SkPath& src, SkStrokeRec* rec,
|
||||||
|
@ -97,7 +97,7 @@ GrFPResult GrConvexPolyEffect::Make(std::unique_ptr<GrFragmentProcessor> inputFP
|
|||||||
return GrFPFailure(std::move(inputFP));
|
return GrFPFailure(std::move(inputFP));
|
||||||
}
|
}
|
||||||
|
|
||||||
SkPathPriv::FirstDirection dir;
|
SkPathFirstDirection dir;
|
||||||
// The only way this should fail is if the clip is effectively a infinitely thin line. In that
|
// The only way this should fail is if the clip is effectively a infinitely thin line. In that
|
||||||
// case nothing is inside the clip. It'd be nice to detect this at a higher level and either
|
// case nothing is inside the clip. It'd be nice to detect this at a higher level and either
|
||||||
// skip the draw or omit the clip element.
|
// skip the draw or omit the clip element.
|
||||||
@ -138,7 +138,7 @@ GrFPResult GrConvexPolyEffect::Make(std::unique_ptr<GrFragmentProcessor> inputFP
|
|||||||
if (pts[0] != pts[1]) {
|
if (pts[0] != pts[1]) {
|
||||||
SkVector v = pts[1] - pts[0];
|
SkVector v = pts[1] - pts[0];
|
||||||
v.normalize();
|
v.normalize();
|
||||||
if (SkPathPriv::kCCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCCW == dir) {
|
||||||
edges[3 * n] = v.fY;
|
edges[3 * n] = v.fY;
|
||||||
edges[3 * n + 1] = -v.fX;
|
edges[3 * n + 1] = -v.fX;
|
||||||
} else {
|
} else {
|
||||||
|
@ -366,16 +366,16 @@ bool is_point_within_cubic_tangents(const SkPoint& a,
|
|||||||
const SkVector& ab,
|
const SkVector& ab,
|
||||||
const SkVector& dc,
|
const SkVector& dc,
|
||||||
const SkPoint& d,
|
const SkPoint& d,
|
||||||
SkPathPriv::FirstDirection dir,
|
SkPathFirstDirection dir,
|
||||||
const SkPoint p) {
|
const SkPoint p) {
|
||||||
SkVector ap = p - a;
|
SkVector ap = p - a;
|
||||||
SkScalar apXab = ap.cross(ab);
|
SkScalar apXab = ap.cross(ab);
|
||||||
if (SkPathPriv::kCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCW == dir) {
|
||||||
if (apXab > 0) {
|
if (apXab > 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
SkASSERT(SkPathPriv::kCCW_FirstDirection == dir);
|
SkASSERT(SkPathFirstDirection::kCCW == dir);
|
||||||
if (apXab < 0) {
|
if (apXab < 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -383,12 +383,12 @@ bool is_point_within_cubic_tangents(const SkPoint& a,
|
|||||||
|
|
||||||
SkVector dp = p - d;
|
SkVector dp = p - d;
|
||||||
SkScalar dpXdc = dp.cross(dc);
|
SkScalar dpXdc = dp.cross(dc);
|
||||||
if (SkPathPriv::kCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCW == dir) {
|
||||||
if (dpXdc < 0) {
|
if (dpXdc < 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
SkASSERT(SkPathPriv::kCCW_FirstDirection == dir);
|
SkASSERT(SkPathFirstDirection::kCCW == dir);
|
||||||
if (dpXdc > 0) {
|
if (dpXdc > 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -463,7 +463,7 @@ void convert_noninflect_cubic_to_quads(const SkPoint p[4],
|
|||||||
|
|
||||||
void convert_noninflect_cubic_to_quads_with_constraint(const SkPoint p[4],
|
void convert_noninflect_cubic_to_quads_with_constraint(const SkPoint p[4],
|
||||||
SkScalar toleranceSqd,
|
SkScalar toleranceSqd,
|
||||||
SkPathPriv::FirstDirection dir,
|
SkPathFirstDirection dir,
|
||||||
SkTArray<SkPoint, true>* quads,
|
SkTArray<SkPoint, true>* quads,
|
||||||
int sublevel = 0) {
|
int sublevel = 0) {
|
||||||
// Notation: Point a is always p[0]. Point b is p[1] unless p[1] == p[0], in which case it is
|
// Notation: Point a is always p[0]. Point b is p[1] unless p[1] == p[0], in which case it is
|
||||||
@ -613,7 +613,7 @@ void GrPathUtils::convertCubicToQuads(const SkPoint p[4],
|
|||||||
|
|
||||||
void GrPathUtils::convertCubicToQuadsConstrainToTangents(const SkPoint p[4],
|
void GrPathUtils::convertCubicToQuadsConstrainToTangents(const SkPoint p[4],
|
||||||
SkScalar tolScale,
|
SkScalar tolScale,
|
||||||
SkPathPriv::FirstDirection dir,
|
SkPathFirstDirection dir,
|
||||||
SkTArray<SkPoint, true>* quads) {
|
SkTArray<SkPoint, true>* quads) {
|
||||||
if (!p[0].isFinite() || !p[1].isFinite() || !p[2].isFinite() || !p[3].isFinite()) {
|
if (!p[0].isFinite() || !p[1].isFinite() || !p[2].isFinite() || !p[3].isFinite()) {
|
||||||
return;
|
return;
|
||||||
|
@ -117,7 +117,7 @@ namespace GrPathUtils {
|
|||||||
// must specify the orientation of the contour containing the cubic.
|
// must specify the orientation of the contour containing the cubic.
|
||||||
void convertCubicToQuadsConstrainToTangents(const SkPoint p[4],
|
void convertCubicToQuadsConstrainToTangents(const SkPoint p[4],
|
||||||
SkScalar tolScale,
|
SkScalar tolScale,
|
||||||
SkPathPriv::FirstDirection dir,
|
SkPathFirstDirection dir,
|
||||||
SkTArray<SkPoint, true>* quads);
|
SkTArray<SkPoint, true>* quads);
|
||||||
|
|
||||||
enum class ExcludedTerm {
|
enum class ExcludedTerm {
|
||||||
|
@ -178,8 +178,7 @@ public:
|
|||||||
// Assuming this is called after knownToBeConvex(), this should just be relying on
|
// Assuming this is called after knownToBeConvex(), this should just be relying on
|
||||||
// cached convexity and direction and will be cheap.
|
// cached convexity and direction and will be cheap.
|
||||||
return !fShape.isPath() ||
|
return !fShape.isPath() ||
|
||||||
!SkPathPriv::CheapIsFirstDirection(fShape.path(),
|
!SkPathPriv::CheapIsFirstDirection(fShape.path(), SkPathFirstDirection::kUnknown);
|
||||||
SkPathPriv::kUnknown_FirstDirection);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Is the pre-styled geometry inverse filled? */
|
/** Is the pre-styled geometry inverse filled? */
|
||||||
|
@ -117,7 +117,7 @@ static bool center_of_mass(const SegmentArray& segments, SkPoint* c) {
|
|||||||
|
|
||||||
static bool compute_vectors(SegmentArray* segments,
|
static bool compute_vectors(SegmentArray* segments,
|
||||||
SkPoint* fanPt,
|
SkPoint* fanPt,
|
||||||
SkPathPriv::FirstDirection dir,
|
SkPathFirstDirection dir,
|
||||||
int* vCount,
|
int* vCount,
|
||||||
int* iCount) {
|
int* iCount) {
|
||||||
if (!center_of_mass(*segments, fanPt)) {
|
if (!center_of_mass(*segments, fanPt)) {
|
||||||
@ -127,7 +127,7 @@ static bool compute_vectors(SegmentArray* segments,
|
|||||||
|
|
||||||
// Make the normals point towards the outside
|
// Make the normals point towards the outside
|
||||||
SkPointPriv::Side normSide;
|
SkPointPriv::Side normSide;
|
||||||
if (dir == SkPathPriv::kCCW_FirstDirection) {
|
if (dir == SkPathFirstDirection::kCCW) {
|
||||||
normSide = SkPointPriv::kRight_Side;
|
normSide = SkPointPriv::kRight_Side;
|
||||||
} else {
|
} else {
|
||||||
normSide = SkPointPriv::kLeft_Side;
|
normSide = SkPointPriv::kLeft_Side;
|
||||||
@ -223,7 +223,7 @@ static void update_degenerate_test(DegenerateTestData* data, const SkPoint& pt)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline bool get_direction(const SkPath& path, const SkMatrix& m,
|
static inline bool get_direction(const SkPath& path, const SkMatrix& m,
|
||||||
SkPathPriv::FirstDirection* dir) {
|
SkPathFirstDirection* dir) {
|
||||||
// At this point, we've already returned true from canDraw(), which checked that the path's
|
// At this point, we've already returned true from canDraw(), which checked that the path's
|
||||||
// direction could be determined, so this should just be fetching the cached direction.
|
// direction could be determined, so this should just be fetching the cached direction.
|
||||||
// However, if perspective is involved, we're operating on a transformed path, which may no
|
// However, if perspective is involved, we're operating on a transformed path, which may no
|
||||||
@ -265,7 +265,7 @@ static inline void add_quad_segment(const SkPoint pts[3],
|
|||||||
}
|
}
|
||||||
|
|
||||||
static inline void add_cubic_segments(const SkPoint pts[4],
|
static inline void add_cubic_segments(const SkPoint pts[4],
|
||||||
SkPathPriv::FirstDirection dir,
|
SkPathFirstDirection dir,
|
||||||
SegmentArray* segments) {
|
SegmentArray* segments) {
|
||||||
SkSTArray<15, SkPoint, true> quads;
|
SkSTArray<15, SkPoint, true> quads;
|
||||||
GrPathUtils::convertCubicToQuadsConstrainToTangents(pts, SK_Scalar1, dir, &quads);
|
GrPathUtils::convertCubicToQuadsConstrainToTangents(pts, SK_Scalar1, dir, &quads);
|
||||||
@ -290,7 +290,7 @@ static bool get_segments(const SkPath& path,
|
|||||||
// line paths. We detect paths that are very close to a line (zero area) and
|
// line paths. We detect paths that are very close to a line (zero area) and
|
||||||
// draw nothing.
|
// draw nothing.
|
||||||
DegenerateTestData degenerateData;
|
DegenerateTestData degenerateData;
|
||||||
SkPathPriv::FirstDirection dir;
|
SkPathFirstDirection dir;
|
||||||
if (!get_direction(path, m, &dir)) {
|
if (!get_direction(path, m, &dir)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -42,9 +42,9 @@ bool SkOpBuilder::FixWinding(SkPath* path) {
|
|||||||
} else if (fillType == SkPathFillType::kEvenOdd) {
|
} else if (fillType == SkPathFillType::kEvenOdd) {
|
||||||
fillType = SkPathFillType::kWinding;
|
fillType = SkPathFillType::kWinding;
|
||||||
}
|
}
|
||||||
SkPathPriv::FirstDirection dir;
|
SkPathFirstDirection dir;
|
||||||
if (one_contour(*path) && SkPathPriv::CheapComputeFirstDirection(*path, &dir)) {
|
if (one_contour(*path) && SkPathPriv::CheapComputeFirstDirection(*path, &dir)) {
|
||||||
if (dir != SkPathPriv::kCCW_FirstDirection) {
|
if (dir != SkPathFirstDirection::kCCW) {
|
||||||
ReversePath(path);
|
ReversePath(path);
|
||||||
}
|
}
|
||||||
path->setFillType(fillType);
|
path->setFillType(fillType);
|
||||||
@ -127,7 +127,7 @@ bool SkOpBuilder::resolve(SkPath* result) {
|
|||||||
SkPath original = *result;
|
SkPath original = *result;
|
||||||
int count = fOps.count();
|
int count = fOps.count();
|
||||||
bool allUnion = true;
|
bool allUnion = true;
|
||||||
SkPathPriv::FirstDirection firstDir = SkPathPriv::kUnknown_FirstDirection;
|
SkPathFirstDirection firstDir = SkPathFirstDirection::kUnknown;
|
||||||
for (int index = 0; index < count; ++index) {
|
for (int index = 0; index < count; ++index) {
|
||||||
SkPath* test = &fPathRefs[index];
|
SkPath* test = &fPathRefs[index];
|
||||||
if (kUnion_SkPathOp != fOps[index] || test->isInverseFillType()) {
|
if (kUnion_SkPathOp != fOps[index] || test->isInverseFillType()) {
|
||||||
@ -136,12 +136,12 @@ bool SkOpBuilder::resolve(SkPath* result) {
|
|||||||
}
|
}
|
||||||
// If all paths are convex, track direction, reversing as needed.
|
// If all paths are convex, track direction, reversing as needed.
|
||||||
if (test->isConvex()) {
|
if (test->isConvex()) {
|
||||||
SkPathPriv::FirstDirection dir;
|
SkPathFirstDirection dir;
|
||||||
if (!SkPathPriv::CheapComputeFirstDirection(*test, &dir)) {
|
if (!SkPathPriv::CheapComputeFirstDirection(*test, &dir)) {
|
||||||
allUnion = false;
|
allUnion = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (firstDir == SkPathPriv::kUnknown_FirstDirection) {
|
if (firstDir == SkPathFirstDirection::kUnknown) {
|
||||||
firstDir = dir;
|
firstDir = dir;
|
||||||
} else if (firstDir != dir) {
|
} else if (firstDir != dir) {
|
||||||
ReversePath(test);
|
ReversePath(test);
|
||||||
|
@ -427,7 +427,7 @@ bool SkDashPath::InternalFilter(SkPath* dst, const SkPath& src, SkStrokeRec* rec
|
|||||||
|
|
||||||
// TODO: do we still need this?
|
// TODO: do we still need this?
|
||||||
if (segCount > 1) {
|
if (segCount > 1) {
|
||||||
SkPathPriv::SetConvexityType(*dst, SkPathConvexityType::kConcave);
|
SkPathPriv::SetConvexity(*dst, SkPathConvexity::kConcave);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -150,8 +150,8 @@ static bool is_eq(const SkPath& a, const SkPath& b) {
|
|||||||
// getConvextity() should be sufficient to test, but internally we sometimes don't want
|
// getConvextity() should be sufficient to test, but internally we sometimes don't want
|
||||||
// to trigger computing it, so this is the stronger test for equality.
|
// to trigger computing it, so this is the stronger test for equality.
|
||||||
{
|
{
|
||||||
SkPathConvexityType ca = SkPathPriv::GetConvexityTypeOrUnknown(a),
|
SkPathConvexity ca = SkPathPriv::GetConvexityOrUnknown(a),
|
||||||
cb = SkPathPriv::GetConvexityTypeOrUnknown(b);
|
cb = SkPathPriv::GetConvexityOrUnknown(b);
|
||||||
if (ca != cb) {
|
if (ca != cb) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -1049,21 +1049,21 @@ static void test_strokerec(skiatest::Reporter* reporter) {
|
|||||||
// Set this for paths that don't have a consistent direction such as a bowtie.
|
// Set this for paths that don't have a consistent direction such as a bowtie.
|
||||||
// (cheapComputeDirection is not expected to catch these.)
|
// (cheapComputeDirection is not expected to catch these.)
|
||||||
// Legal values are CW (0), CCW (1) and Unknown (2), leaving 3 as a convenient sentinel.
|
// Legal values are CW (0), CCW (1) and Unknown (2), leaving 3 as a convenient sentinel.
|
||||||
const SkPathPriv::FirstDirection kDontCheckDir = static_cast<SkPathPriv::FirstDirection>(3);
|
const SkPathFirstDirection kDontCheckDir = static_cast<SkPathFirstDirection>(3);
|
||||||
|
|
||||||
static void check_direction(skiatest::Reporter* reporter, const SkPath& path,
|
static void check_direction(skiatest::Reporter* reporter, const SkPath& path,
|
||||||
SkPathPriv::FirstDirection expected) {
|
SkPathFirstDirection expected) {
|
||||||
if (expected == kDontCheckDir) {
|
if (expected == kDontCheckDir) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// We make a copy so that we don't cache the result on the passed in path.
|
// We make a copy so that we don't cache the result on the passed in path.
|
||||||
SkPath copy(path); // NOLINT(performance-unnecessary-copy-initialization)
|
SkPath copy(path); // NOLINT(performance-unnecessary-copy-initialization)
|
||||||
|
|
||||||
SkPathPriv::FirstDirection dir;
|
SkPathFirstDirection dir;
|
||||||
if (SkPathPriv::CheapComputeFirstDirection(copy, &dir)) {
|
if (SkPathPriv::CheapComputeFirstDirection(copy, &dir)) {
|
||||||
REPORTER_ASSERT(reporter, dir == expected);
|
REPORTER_ASSERT(reporter, dir == expected);
|
||||||
} else {
|
} else {
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::kUnknown_FirstDirection == expected);
|
REPORTER_ASSERT(reporter, SkPathFirstDirection::kUnknown == expected);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1071,9 +1071,9 @@ static void test_direction(skiatest::Reporter* reporter) {
|
|||||||
size_t i;
|
size_t i;
|
||||||
SkPath path;
|
SkPath path;
|
||||||
REPORTER_ASSERT(reporter, !SkPathPriv::CheapComputeFirstDirection(path, nullptr));
|
REPORTER_ASSERT(reporter, !SkPathPriv::CheapComputeFirstDirection(path, nullptr));
|
||||||
REPORTER_ASSERT(reporter, !SkPathPriv::CheapIsFirstDirection(path, SkPathPriv::kCW_FirstDirection));
|
REPORTER_ASSERT(reporter, !SkPathPriv::CheapIsFirstDirection(path, SkPathFirstDirection::kCW));
|
||||||
REPORTER_ASSERT(reporter, !SkPathPriv::CheapIsFirstDirection(path, SkPathPriv::kCCW_FirstDirection));
|
REPORTER_ASSERT(reporter, !SkPathPriv::CheapIsFirstDirection(path, SkPathFirstDirection::kCCW));
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(path, SkPathPriv::kUnknown_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(path, SkPathFirstDirection::kUnknown));
|
||||||
|
|
||||||
static const char* gDegen[] = {
|
static const char* gDegen[] = {
|
||||||
"M 10 10",
|
"M 10 10",
|
||||||
@ -1103,7 +1103,7 @@ static void test_direction(skiatest::Reporter* reporter) {
|
|||||||
path.reset();
|
path.reset();
|
||||||
bool valid = SkParsePath::FromSVGString(gCW[i], &path);
|
bool valid = SkParsePath::FromSVGString(gCW[i], &path);
|
||||||
REPORTER_ASSERT(reporter, valid);
|
REPORTER_ASSERT(reporter, valid);
|
||||||
check_direction(reporter, path, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCW);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char* gCCW[] = {
|
static const char* gCCW[] = {
|
||||||
@ -1119,7 +1119,7 @@ static void test_direction(skiatest::Reporter* reporter) {
|
|||||||
path.reset();
|
path.reset();
|
||||||
bool valid = SkParsePath::FromSVGString(gCCW[i], &path);
|
bool valid = SkParsePath::FromSVGString(gCCW[i], &path);
|
||||||
REPORTER_ASSERT(reporter, valid);
|
REPORTER_ASSERT(reporter, valid);
|
||||||
check_direction(reporter, path, SkPathPriv::kCCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCCW);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Test two donuts, each wound a different direction. Only the outer contour
|
// Test two donuts, each wound a different direction. Only the outer contour
|
||||||
@ -1127,12 +1127,12 @@ static void test_direction(skiatest::Reporter* reporter) {
|
|||||||
path.reset();
|
path.reset();
|
||||||
path.addCircle(0, 0, SkIntToScalar(2), SkPathDirection::kCW);
|
path.addCircle(0, 0, SkIntToScalar(2), SkPathDirection::kCW);
|
||||||
path.addCircle(0, 0, SkIntToScalar(1), SkPathDirection::kCCW);
|
path.addCircle(0, 0, SkIntToScalar(1), SkPathDirection::kCCW);
|
||||||
check_direction(reporter, path, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
path.reset();
|
path.reset();
|
||||||
path.addCircle(0, 0, SkIntToScalar(1), SkPathDirection::kCW);
|
path.addCircle(0, 0, SkIntToScalar(1), SkPathDirection::kCW);
|
||||||
path.addCircle(0, 0, SkIntToScalar(2), SkPathDirection::kCCW);
|
path.addCircle(0, 0, SkIntToScalar(2), SkPathDirection::kCCW);
|
||||||
check_direction(reporter, path, SkPathPriv::kCCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCCW);
|
||||||
|
|
||||||
// triangle with one point really far from the origin.
|
// triangle with one point really far from the origin.
|
||||||
path.reset();
|
path.reset();
|
||||||
@ -1140,19 +1140,19 @@ static void test_direction(skiatest::Reporter* reporter) {
|
|||||||
path.moveTo(SkBits2Float(0x501c7652), SkBits2Float(0x501c7652));
|
path.moveTo(SkBits2Float(0x501c7652), SkBits2Float(0x501c7652));
|
||||||
path.lineTo(110 * SK_Scalar1, -10 * SK_Scalar1);
|
path.lineTo(110 * SK_Scalar1, -10 * SK_Scalar1);
|
||||||
path.lineTo(-10 * SK_Scalar1, 60 * SK_Scalar1);
|
path.lineTo(-10 * SK_Scalar1, 60 * SK_Scalar1);
|
||||||
check_direction(reporter, path, SkPathPriv::kCCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCCW);
|
||||||
|
|
||||||
path.reset();
|
path.reset();
|
||||||
path.conicTo(20, 0, 20, 20, 0.5f);
|
path.conicTo(20, 0, 20, 20, 0.5f);
|
||||||
path.close();
|
path.close();
|
||||||
check_direction(reporter, path, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
path.reset();
|
path.reset();
|
||||||
path.lineTo(1, 1e7f);
|
path.lineTo(1, 1e7f);
|
||||||
path.lineTo(1e7f, 2e7f);
|
path.lineTo(1e7f, 2e7f);
|
||||||
path.close();
|
path.close();
|
||||||
REPORTER_ASSERT(reporter, path.isConvex());
|
REPORTER_ASSERT(reporter, path.isConvex());
|
||||||
check_direction(reporter, path, SkPathPriv::kCCW_FirstDirection);
|
check_direction(reporter, path, SkPathFirstDirection::kCCW);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void add_rect(SkPath* path, const SkRect& r) {
|
static void add_rect(SkPath* path, const SkRect& r) {
|
||||||
@ -1347,7 +1347,7 @@ static void test_path_crbug389050(skiatest::Reporter* reporter) {
|
|||||||
// This is convex, but so small that it fails many of our checks, and the three "backwards"
|
// This is convex, but so small that it fails many of our checks, and the three "backwards"
|
||||||
// bends convince the checker that it's concave. That's okay though, we draw it correctly.
|
// bends convince the checker that it's concave. That's okay though, we draw it correctly.
|
||||||
check_convexity(reporter, tinyConvexPolygon, false);
|
check_convexity(reporter, tinyConvexPolygon, false);
|
||||||
check_direction(reporter, tinyConvexPolygon, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, tinyConvexPolygon, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
SkPath platTriangle;
|
SkPath platTriangle;
|
||||||
platTriangle.moveTo(0, 0);
|
platTriangle.moveTo(0, 0);
|
||||||
@ -1355,7 +1355,7 @@ static void test_path_crbug389050(skiatest::Reporter* reporter) {
|
|||||||
platTriangle.lineTo(100, 0.04f);
|
platTriangle.lineTo(100, 0.04f);
|
||||||
platTriangle.close();
|
platTriangle.close();
|
||||||
platTriangle.isConvex();
|
platTriangle.isConvex();
|
||||||
check_direction(reporter, platTriangle, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, platTriangle, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
platTriangle.reset();
|
platTriangle.reset();
|
||||||
platTriangle.moveTo(0, 0);
|
platTriangle.moveTo(0, 0);
|
||||||
@ -1363,7 +1363,7 @@ static void test_path_crbug389050(skiatest::Reporter* reporter) {
|
|||||||
platTriangle.lineTo(100, 0.03f);
|
platTriangle.lineTo(100, 0.03f);
|
||||||
platTriangle.close();
|
platTriangle.close();
|
||||||
platTriangle.isConvex();
|
platTriangle.isConvex();
|
||||||
check_direction(reporter, platTriangle, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, platTriangle, SkPathFirstDirection::kCW);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_convexity2(skiatest::Reporter* reporter) {
|
static void test_convexity2(skiatest::Reporter* reporter) {
|
||||||
@ -1371,14 +1371,14 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
pt.moveTo(0, 0);
|
pt.moveTo(0, 0);
|
||||||
pt.close();
|
pt.close();
|
||||||
check_convexity(reporter, pt, true);
|
check_convexity(reporter, pt, true);
|
||||||
check_direction(reporter, pt, SkPathPriv::kUnknown_FirstDirection);
|
check_direction(reporter, pt, SkPathFirstDirection::kUnknown);
|
||||||
|
|
||||||
SkPath line;
|
SkPath line;
|
||||||
line.moveTo(12*SK_Scalar1, 20*SK_Scalar1);
|
line.moveTo(12*SK_Scalar1, 20*SK_Scalar1);
|
||||||
line.lineTo(-12*SK_Scalar1, -20*SK_Scalar1);
|
line.lineTo(-12*SK_Scalar1, -20*SK_Scalar1);
|
||||||
line.close();
|
line.close();
|
||||||
check_convexity(reporter, line, true);
|
check_convexity(reporter, line, true);
|
||||||
check_direction(reporter, line, SkPathPriv::kUnknown_FirstDirection);
|
check_direction(reporter, line, SkPathFirstDirection::kUnknown);
|
||||||
|
|
||||||
SkPath triLeft;
|
SkPath triLeft;
|
||||||
triLeft.moveTo(0, 0);
|
triLeft.moveTo(0, 0);
|
||||||
@ -1386,7 +1386,7 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
triLeft.lineTo(SK_Scalar1, SK_Scalar1);
|
triLeft.lineTo(SK_Scalar1, SK_Scalar1);
|
||||||
triLeft.close();
|
triLeft.close();
|
||||||
check_convexity(reporter, triLeft, true);
|
check_convexity(reporter, triLeft, true);
|
||||||
check_direction(reporter, triLeft, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, triLeft, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
SkPath triRight;
|
SkPath triRight;
|
||||||
triRight.moveTo(0, 0);
|
triRight.moveTo(0, 0);
|
||||||
@ -1394,7 +1394,7 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
triRight.lineTo(SK_Scalar1, SK_Scalar1);
|
triRight.lineTo(SK_Scalar1, SK_Scalar1);
|
||||||
triRight.close();
|
triRight.close();
|
||||||
check_convexity(reporter, triRight, true);
|
check_convexity(reporter, triRight, true);
|
||||||
check_direction(reporter, triRight, SkPathPriv::kCCW_FirstDirection);
|
check_direction(reporter, triRight, SkPathFirstDirection::kCCW);
|
||||||
|
|
||||||
SkPath square;
|
SkPath square;
|
||||||
square.moveTo(0, 0);
|
square.moveTo(0, 0);
|
||||||
@ -1403,7 +1403,7 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
square.lineTo(0, SK_Scalar1);
|
square.lineTo(0, SK_Scalar1);
|
||||||
square.close();
|
square.close();
|
||||||
check_convexity(reporter, square, true);
|
check_convexity(reporter, square, true);
|
||||||
check_direction(reporter, square, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, square, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
SkPath redundantSquare;
|
SkPath redundantSquare;
|
||||||
redundantSquare.moveTo(0, 0);
|
redundantSquare.moveTo(0, 0);
|
||||||
@ -1420,7 +1420,7 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
redundantSquare.lineTo(0, SK_Scalar1);
|
redundantSquare.lineTo(0, SK_Scalar1);
|
||||||
redundantSquare.close();
|
redundantSquare.close();
|
||||||
check_convexity(reporter, redundantSquare, true);
|
check_convexity(reporter, redundantSquare, true);
|
||||||
check_direction(reporter, redundantSquare, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, redundantSquare, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
SkPath bowTie;
|
SkPath bowTie;
|
||||||
bowTie.moveTo(0, 0);
|
bowTie.moveTo(0, 0);
|
||||||
@ -1459,7 +1459,7 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
dent.lineTo(-200*SK_Scalar1, 100*SK_Scalar1);
|
dent.lineTo(-200*SK_Scalar1, 100*SK_Scalar1);
|
||||||
dent.close();
|
dent.close();
|
||||||
check_convexity(reporter, dent, false);
|
check_convexity(reporter, dent, false);
|
||||||
check_direction(reporter, dent, SkPathPriv::kCW_FirstDirection);
|
check_direction(reporter, dent, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
// https://bug.skia.org/2235
|
// https://bug.skia.org/2235
|
||||||
SkPath strokedSin;
|
SkPath strokedSin;
|
||||||
@ -1487,7 +1487,7 @@ static void test_convexity2(skiatest::Reporter* reporter) {
|
|||||||
degenerateConcave.lineTo(-55.971577f, 460.0f);
|
degenerateConcave.lineTo(-55.971577f, 460.0f);
|
||||||
degenerateConcave.lineTo(41.446522f, 376.25f);
|
degenerateConcave.lineTo(41.446522f, 376.25f);
|
||||||
check_convexity(reporter, degenerateConcave, false);
|
check_convexity(reporter, degenerateConcave, false);
|
||||||
check_direction(reporter, degenerateConcave, SkPathPriv::kUnknown_FirstDirection);
|
check_direction(reporter, degenerateConcave, SkPathFirstDirection::kUnknown);
|
||||||
|
|
||||||
// http://crbug.com/433683
|
// http://crbug.com/433683
|
||||||
SkPath badFirstVector;
|
SkPath badFirstVector;
|
||||||
@ -1588,30 +1588,30 @@ static void test_convexity(skiatest::Reporter* reporter) {
|
|||||||
path.reset();
|
path.reset();
|
||||||
path.addRect(0, 0, SkIntToScalar(10), SkIntToScalar(10), SkPathDirection::kCCW);
|
path.addRect(0, 0, SkIntToScalar(10), SkIntToScalar(10), SkPathDirection::kCCW);
|
||||||
check_convexity(reporter, path, true);
|
check_convexity(reporter, path, true);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(path, SkPathPriv::kCCW_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(path, SkPathFirstDirection::kCCW));
|
||||||
|
|
||||||
path.reset();
|
path.reset();
|
||||||
path.addRect(0, 0, SkIntToScalar(10), SkIntToScalar(10), SkPathDirection::kCW);
|
path.addRect(0, 0, SkIntToScalar(10), SkIntToScalar(10), SkPathDirection::kCW);
|
||||||
check_convexity(reporter, path, true);
|
check_convexity(reporter, path, true);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(path, SkPathPriv::kCW_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(path, SkPathFirstDirection::kCW));
|
||||||
|
|
||||||
path.reset();
|
path.reset();
|
||||||
path.quadTo(100, 100, 50, 50); // This from GM:convexpaths
|
path.quadTo(100, 100, 50, 50); // This from GM:convexpaths
|
||||||
check_convexity(reporter, path, true);
|
check_convexity(reporter, path, true);
|
||||||
|
|
||||||
static const struct {
|
static const struct {
|
||||||
const char* fPathStr;
|
const char* fPathStr;
|
||||||
bool fExpectedIsConvex;
|
bool fExpectedIsConvex;
|
||||||
SkPathPriv::FirstDirection fExpectedDirection;
|
SkPathFirstDirection fExpectedDirection;
|
||||||
} gRec[] = {
|
} gRec[] = {
|
||||||
{ "", true, SkPathPriv::kUnknown_FirstDirection },
|
{ "", true, SkPathFirstDirection::kUnknown },
|
||||||
{ "0 0", true, SkPathPriv::kUnknown_FirstDirection },
|
{ "0 0", true, SkPathFirstDirection::kUnknown },
|
||||||
{ "0 0 10 10", true, SkPathPriv::kUnknown_FirstDirection },
|
{ "0 0 10 10", true, SkPathFirstDirection::kUnknown },
|
||||||
{ "0 0 10 10 20 20 0 0 10 10", false, SkPathPriv::kUnknown_FirstDirection },
|
{ "0 0 10 10 20 20 0 0 10 10", false, SkPathFirstDirection::kUnknown },
|
||||||
{ "0 0 10 10 10 20", true, SkPathPriv::kCW_FirstDirection },
|
{ "0 0 10 10 10 20", true, SkPathFirstDirection::kCW },
|
||||||
{ "0 0 10 10 10 0", true, SkPathPriv::kCCW_FirstDirection },
|
{ "0 0 10 10 10 0", true, SkPathFirstDirection::kCCW },
|
||||||
{ "0 0 10 10 10 0 0 10", false, kDontCheckDir },
|
{ "0 0 10 10 10 0 0 10", false, kDontCheckDir },
|
||||||
{ "0 0 10 0 0 10 -10 -10", false, SkPathPriv::kCW_FirstDirection },
|
{ "0 0 10 0 0 10 -10 -10", false, SkPathFirstDirection::kCW },
|
||||||
};
|
};
|
||||||
|
|
||||||
for (size_t i = 0; i < SK_ARRAY_COUNT(gRec); ++i) {
|
for (size_t i = 0; i < SK_ARRAY_COUNT(gRec); ++i) {
|
||||||
@ -1623,9 +1623,9 @@ static void test_convexity(skiatest::Reporter* reporter) {
|
|||||||
if (kDontCheckDir != gRec[i].fExpectedDirection) {
|
if (kDontCheckDir != gRec[i].fExpectedDirection) {
|
||||||
// We make a copy so that we don't cache the result on the passed in path.
|
// We make a copy so that we don't cache the result on the passed in path.
|
||||||
SkPath copy(path); // NOLINT(performance-unnecessary-copy-initialization)
|
SkPath copy(path); // NOLINT(performance-unnecessary-copy-initialization)
|
||||||
SkPathPriv::FirstDirection dir;
|
SkPathFirstDirection dir;
|
||||||
bool foundDir = SkPathPriv::CheapComputeFirstDirection(copy, &dir);
|
bool foundDir = SkPathPriv::CheapComputeFirstDirection(copy, &dir);
|
||||||
REPORTER_ASSERT(reporter, (gRec[i].fExpectedDirection == SkPathPriv::kUnknown_FirstDirection)
|
REPORTER_ASSERT(reporter, (gRec[i].fExpectedDirection == SkPathFirstDirection::kUnknown)
|
||||||
^ foundDir);
|
^ foundDir);
|
||||||
REPORTER_ASSERT(reporter, !foundDir || gRec[i].fExpectedDirection == dir);
|
REPORTER_ASSERT(reporter, !foundDir || gRec[i].fExpectedDirection == dir);
|
||||||
check_convexity(reporter, copy, gRec[i].fExpectedIsConvex);
|
check_convexity(reporter, copy, gRec[i].fExpectedIsConvex);
|
||||||
@ -1680,7 +1680,7 @@ static void test_convexity(skiatest::Reporter* reporter) {
|
|||||||
case 12: path.moveTo(nonFinitePts[i]); break;
|
case 12: path.moveTo(nonFinitePts[i]); break;
|
||||||
}
|
}
|
||||||
REPORTER_ASSERT(reporter,
|
REPORTER_ASSERT(reporter,
|
||||||
SkPathPriv::GetConvexityTypeOrUnknown(path) == SkPathConvexityType::kUnknown);
|
SkPathPriv::GetConvexityOrUnknown(path) == SkPathConvexity::kUnknown);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int index = 0; index < (int) (11 * axisAlignedPtsCount); ++index) {
|
for (int index = 0; index < (int) (11 * axisAlignedPtsCount); ++index) {
|
||||||
@ -2154,7 +2154,7 @@ static void test_isRect(skiatest::Reporter* reporter) {
|
|||||||
SkRect computed, expected;
|
SkRect computed, expected;
|
||||||
bool isClosed;
|
bool isClosed;
|
||||||
SkPathDirection direction;
|
SkPathDirection direction;
|
||||||
SkPathPriv::FirstDirection cheapDirection;
|
SkPathFirstDirection cheapDirection;
|
||||||
int pointCount = tests[testIndex].fPointCount - (d2 == tests[testIndex].fPoints);
|
int pointCount = tests[testIndex].fPointCount - (d2 == tests[testIndex].fPoints);
|
||||||
expected.setBounds(tests[testIndex].fPoints, pointCount);
|
expected.setBounds(tests[testIndex].fPoints, pointCount);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapComputeFirstDirection(path, &cheapDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapComputeFirstDirection(path, &cheapDirection));
|
||||||
@ -2399,36 +2399,36 @@ static void test_isNestedFillRects(skiatest::Reporter* reporter) {
|
|||||||
struct IsNestedRectTest {
|
struct IsNestedRectTest {
|
||||||
SkPoint *fPoints;
|
SkPoint *fPoints;
|
||||||
int fPointCount;
|
int fPointCount;
|
||||||
SkPathPriv::FirstDirection fDirection;
|
SkPathFirstDirection fDirection;
|
||||||
bool fClose;
|
bool fClose;
|
||||||
bool fIsNestedRect; // nests with path.addRect(-1, -1, 2, 2);
|
bool fIsNestedRect; // nests with path.addRect(-1, -1, 2, 2);
|
||||||
} tests[] = {
|
} tests[] = {
|
||||||
{ r1, SK_ARRAY_COUNT(r1), SkPathPriv::kCW_FirstDirection , true, true },
|
{ r1, SK_ARRAY_COUNT(r1), SkPathFirstDirection::kCW , true, true },
|
||||||
{ r2, SK_ARRAY_COUNT(r2), SkPathPriv::kCW_FirstDirection , true, true },
|
{ r2, SK_ARRAY_COUNT(r2), SkPathFirstDirection::kCW , true, true },
|
||||||
{ r3, SK_ARRAY_COUNT(r3), SkPathPriv::kCW_FirstDirection , true, true },
|
{ r3, SK_ARRAY_COUNT(r3), SkPathFirstDirection::kCW , true, true },
|
||||||
{ r4, SK_ARRAY_COUNT(r4), SkPathPriv::kCW_FirstDirection , true, true },
|
{ r4, SK_ARRAY_COUNT(r4), SkPathFirstDirection::kCW , true, true },
|
||||||
{ r5, SK_ARRAY_COUNT(r5), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ r5, SK_ARRAY_COUNT(r5), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ r6, SK_ARRAY_COUNT(r6), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ r6, SK_ARRAY_COUNT(r6), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ r7, SK_ARRAY_COUNT(r7), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ r7, SK_ARRAY_COUNT(r7), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ r8, SK_ARRAY_COUNT(r8), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ r8, SK_ARRAY_COUNT(r8), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ r9, SK_ARRAY_COUNT(r9), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ r9, SK_ARRAY_COUNT(r9), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ ra, SK_ARRAY_COUNT(ra), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ ra, SK_ARRAY_COUNT(ra), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ rb, SK_ARRAY_COUNT(rb), SkPathPriv::kCW_FirstDirection, true, true },
|
{ rb, SK_ARRAY_COUNT(rb), SkPathFirstDirection::kCW, true, true },
|
||||||
{ rc, SK_ARRAY_COUNT(rc), SkPathPriv::kCW_FirstDirection, true, true },
|
{ rc, SK_ARRAY_COUNT(rc), SkPathFirstDirection::kCW, true, true },
|
||||||
{ rd, SK_ARRAY_COUNT(rd), SkPathPriv::kCCW_FirstDirection, true, true },
|
{ rd, SK_ARRAY_COUNT(rd), SkPathFirstDirection::kCCW, true, true },
|
||||||
{ re, SK_ARRAY_COUNT(re), SkPathPriv::kCW_FirstDirection, true, true },
|
{ re, SK_ARRAY_COUNT(re), SkPathFirstDirection::kCW, true, true },
|
||||||
|
|
||||||
{ f1, SK_ARRAY_COUNT(f1), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f1, SK_ARRAY_COUNT(f1), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f2, SK_ARRAY_COUNT(f2), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f2, SK_ARRAY_COUNT(f2), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f3, SK_ARRAY_COUNT(f3), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f3, SK_ARRAY_COUNT(f3), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f4, SK_ARRAY_COUNT(f4), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f4, SK_ARRAY_COUNT(f4), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f5, SK_ARRAY_COUNT(f5), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f5, SK_ARRAY_COUNT(f5), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f6, SK_ARRAY_COUNT(f6), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f6, SK_ARRAY_COUNT(f6), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f7, SK_ARRAY_COUNT(f7), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f7, SK_ARRAY_COUNT(f7), SkPathFirstDirection::kUnknown, true, false },
|
||||||
{ f8, SK_ARRAY_COUNT(f8), SkPathPriv::kUnknown_FirstDirection, true, false },
|
{ f8, SK_ARRAY_COUNT(f8), SkPathFirstDirection::kUnknown, true, false },
|
||||||
|
|
||||||
{ c1, SK_ARRAY_COUNT(c1), SkPathPriv::kCW_FirstDirection, false, true },
|
{ c1, SK_ARRAY_COUNT(c1), SkPathFirstDirection::kCW, false, true },
|
||||||
{ c2, SK_ARRAY_COUNT(c2), SkPathPriv::kCW_FirstDirection, false, true },
|
{ c2, SK_ARRAY_COUNT(c2), SkPathFirstDirection::kCW, false, true },
|
||||||
};
|
};
|
||||||
|
|
||||||
const size_t testCount = SK_ARRAY_COUNT(tests);
|
const size_t testCount = SK_ARRAY_COUNT(tests);
|
||||||
@ -2453,16 +2453,16 @@ static void test_isNestedFillRects(skiatest::Reporter* reporter) {
|
|||||||
tests[testIndex].fIsNestedRect == SkPathPriv::IsNestedFillRects(path, nullptr));
|
tests[testIndex].fIsNestedRect == SkPathPriv::IsNestedFillRects(path, nullptr));
|
||||||
if (tests[testIndex].fIsNestedRect) {
|
if (tests[testIndex].fIsNestedRect) {
|
||||||
SkRect expected[2], computed[2];
|
SkRect expected[2], computed[2];
|
||||||
SkPathPriv::FirstDirection expectedDirs[2];
|
SkPathFirstDirection expectedDirs[2];
|
||||||
SkPathDirection computedDirs[2];
|
SkPathDirection computedDirs[2];
|
||||||
SkRect testBounds;
|
SkRect testBounds;
|
||||||
testBounds.setBounds(tests[testIndex].fPoints, tests[testIndex].fPointCount);
|
testBounds.setBounds(tests[testIndex].fPoints, tests[testIndex].fPointCount);
|
||||||
expected[0] = SkRect::MakeLTRB(-1, -1, 2, 2);
|
expected[0] = SkRect::MakeLTRB(-1, -1, 2, 2);
|
||||||
expected[1] = testBounds;
|
expected[1] = testBounds;
|
||||||
if (rectFirst) {
|
if (rectFirst) {
|
||||||
expectedDirs[0] = SkPathPriv::kCW_FirstDirection;
|
expectedDirs[0] = SkPathFirstDirection::kCW;
|
||||||
} else {
|
} else {
|
||||||
expectedDirs[0] = SkPathPriv::kCCW_FirstDirection;
|
expectedDirs[0] = SkPathFirstDirection::kCCW;
|
||||||
}
|
}
|
||||||
expectedDirs[1] = tests[testIndex].fDirection;
|
expectedDirs[1] = tests[testIndex].fDirection;
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::IsNestedFillRects(path, computed, computedDirs));
|
REPORTER_ASSERT(reporter, SkPathPriv::IsNestedFillRects(path, computed, computedDirs));
|
||||||
@ -2603,8 +2603,8 @@ static void write_and_read_back(skiatest::Reporter* reporter,
|
|||||||
reader.readPath(&readBack);
|
reader.readPath(&readBack);
|
||||||
REPORTER_ASSERT(reporter, readBack == p);
|
REPORTER_ASSERT(reporter, readBack == p);
|
||||||
|
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityTypeOrUnknown(readBack) ==
|
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityOrUnknown(readBack) ==
|
||||||
SkPathPriv::GetConvexityTypeOrUnknown(p));
|
SkPathPriv::GetConvexityOrUnknown(p));
|
||||||
|
|
||||||
SkRect oval0, oval1;
|
SkRect oval0, oval1;
|
||||||
SkPathDirection dir0, dir1;
|
SkPathDirection dir0, dir1;
|
||||||
@ -2758,7 +2758,7 @@ static void test_transform(skiatest::Reporter* reporter) {
|
|||||||
p1.moveTo(SkPoint::Make(0, 0));
|
p1.moveTo(SkPoint::Make(0, 0));
|
||||||
|
|
||||||
p.transform(matrix, &p1);
|
p.transform(matrix, &p1);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p1, SkPathPriv::kCW_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p1, SkPathFirstDirection::kCW));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -2770,7 +2770,7 @@ static void test_transform(skiatest::Reporter* reporter) {
|
|||||||
p1.moveTo(SkPoint::Make(0, 0)); // Make p1 unique (i.e., not empty path)
|
p1.moveTo(SkPoint::Make(0, 0)); // Make p1 unique (i.e., not empty path)
|
||||||
|
|
||||||
p.transform(matrix, &p1);
|
p.transform(matrix, &p1);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p1, SkPathPriv::kCCW_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p1, SkPathFirstDirection::kCCW));
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -2780,7 +2780,7 @@ static void test_transform(skiatest::Reporter* reporter) {
|
|||||||
p1.moveTo(SkPoint::Make(0, 0)); // Make p1 unique (i.e., not empty path)
|
p1.moveTo(SkPoint::Make(0, 0)); // Make p1 unique (i.e., not empty path)
|
||||||
|
|
||||||
p.transform(matrix, &p1);
|
p.transform(matrix, &p1);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p1, SkPathPriv::kUnknown_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p1, SkPathFirstDirection::kUnknown));
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -3303,7 +3303,7 @@ static void test_range_iter(skiatest::Reporter* reporter) {
|
|||||||
static void check_for_circle(skiatest::Reporter* reporter,
|
static void check_for_circle(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
bool expectedCircle,
|
bool expectedCircle,
|
||||||
SkPathPriv::FirstDirection expectedDir) {
|
SkPathFirstDirection expectedDir) {
|
||||||
SkRect rect = SkRect::MakeEmpty();
|
SkRect rect = SkRect::MakeEmpty();
|
||||||
REPORTER_ASSERT(reporter, path.isOval(&rect) == expectedCircle);
|
REPORTER_ASSERT(reporter, path.isOval(&rect) == expectedCircle);
|
||||||
SkPathDirection isOvalDir;
|
SkPathDirection isOvalDir;
|
||||||
@ -3320,25 +3320,25 @@ static void check_for_circle(skiatest::Reporter* reporter,
|
|||||||
|
|
||||||
static void test_circle_skew(skiatest::Reporter* reporter,
|
static void test_circle_skew(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
SkPath tmp;
|
SkPath tmp;
|
||||||
|
|
||||||
SkMatrix m;
|
SkMatrix m;
|
||||||
m.setSkew(SkIntToScalar(3), SkIntToScalar(5));
|
m.setSkew(SkIntToScalar(3), SkIntToScalar(5));
|
||||||
path.transform(m, &tmp);
|
path.transform(m, &tmp);
|
||||||
// this matrix reverses the direction.
|
// this matrix reverses the direction.
|
||||||
if (SkPathPriv::kCCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCCW == dir) {
|
||||||
dir = SkPathPriv::kCW_FirstDirection;
|
dir = SkPathFirstDirection::kCW;
|
||||||
} else {
|
} else {
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::kCW_FirstDirection == dir);
|
REPORTER_ASSERT(reporter, SkPathFirstDirection::kCW == dir);
|
||||||
dir = SkPathPriv::kCCW_FirstDirection;
|
dir = SkPathFirstDirection::kCCW;
|
||||||
}
|
}
|
||||||
check_for_circle(reporter, tmp, false, dir);
|
check_for_circle(reporter, tmp, false, dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_circle_translate(skiatest::Reporter* reporter,
|
static void test_circle_translate(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
SkPath tmp;
|
SkPath tmp;
|
||||||
|
|
||||||
// translate at small offset
|
// translate at small offset
|
||||||
@ -3358,7 +3358,7 @@ static void test_circle_translate(skiatest::Reporter* reporter,
|
|||||||
|
|
||||||
static void test_circle_rotate(skiatest::Reporter* reporter,
|
static void test_circle_rotate(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
for (int angle = 0; angle < 360; ++angle) {
|
for (int angle = 0; angle < 360; ++angle) {
|
||||||
SkPath tmp;
|
SkPath tmp;
|
||||||
SkMatrix m;
|
SkMatrix m;
|
||||||
@ -3378,35 +3378,35 @@ static void test_circle_rotate(skiatest::Reporter* reporter,
|
|||||||
|
|
||||||
static void test_circle_mirror_x(skiatest::Reporter* reporter,
|
static void test_circle_mirror_x(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
SkPath tmp;
|
SkPath tmp;
|
||||||
SkMatrix m;
|
SkMatrix m;
|
||||||
m.reset();
|
m.reset();
|
||||||
m.setScaleX(-SK_Scalar1);
|
m.setScaleX(-SK_Scalar1);
|
||||||
path.transform(m, &tmp);
|
path.transform(m, &tmp);
|
||||||
if (SkPathPriv::kCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCW == dir) {
|
||||||
dir = SkPathPriv::kCCW_FirstDirection;
|
dir = SkPathFirstDirection::kCCW;
|
||||||
} else {
|
} else {
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::kCCW_FirstDirection == dir);
|
REPORTER_ASSERT(reporter, SkPathFirstDirection::kCCW == dir);
|
||||||
dir = SkPathPriv::kCW_FirstDirection;
|
dir = SkPathFirstDirection::kCW;
|
||||||
}
|
}
|
||||||
check_for_circle(reporter, tmp, true, dir);
|
check_for_circle(reporter, tmp, true, dir);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_circle_mirror_y(skiatest::Reporter* reporter,
|
static void test_circle_mirror_y(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
SkPath tmp;
|
SkPath tmp;
|
||||||
SkMatrix m;
|
SkMatrix m;
|
||||||
m.reset();
|
m.reset();
|
||||||
m.setScaleY(-SK_Scalar1);
|
m.setScaleY(-SK_Scalar1);
|
||||||
path.transform(m, &tmp);
|
path.transform(m, &tmp);
|
||||||
|
|
||||||
if (SkPathPriv::kCW_FirstDirection == dir) {
|
if (SkPathFirstDirection::kCW == dir) {
|
||||||
dir = SkPathPriv::kCCW_FirstDirection;
|
dir = SkPathFirstDirection::kCCW;
|
||||||
} else {
|
} else {
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::kCCW_FirstDirection == dir);
|
REPORTER_ASSERT(reporter, SkPathFirstDirection::kCCW == dir);
|
||||||
dir = SkPathPriv::kCW_FirstDirection;
|
dir = SkPathFirstDirection::kCW;
|
||||||
}
|
}
|
||||||
|
|
||||||
check_for_circle(reporter, tmp, true, dir);
|
check_for_circle(reporter, tmp, true, dir);
|
||||||
@ -3414,7 +3414,7 @@ static void test_circle_mirror_y(skiatest::Reporter* reporter,
|
|||||||
|
|
||||||
static void test_circle_mirror_xy(skiatest::Reporter* reporter,
|
static void test_circle_mirror_xy(skiatest::Reporter* reporter,
|
||||||
const SkPath& path,
|
const SkPath& path,
|
||||||
SkPathPriv::FirstDirection dir) {
|
SkPathFirstDirection dir) {
|
||||||
SkPath tmp;
|
SkPath tmp;
|
||||||
SkMatrix m;
|
SkMatrix m;
|
||||||
m.reset();
|
m.reset();
|
||||||
@ -3427,7 +3427,7 @@ static void test_circle_mirror_xy(skiatest::Reporter* reporter,
|
|||||||
|
|
||||||
static void test_circle_with_direction(skiatest::Reporter* reporter,
|
static void test_circle_with_direction(skiatest::Reporter* reporter,
|
||||||
SkPathDirection inDir) {
|
SkPathDirection inDir) {
|
||||||
const SkPathPriv::FirstDirection dir = SkPathPriv::AsFirstDirection(inDir);
|
const SkPathFirstDirection dir = SkPathPriv::AsFirstDirection(inDir);
|
||||||
SkPath path;
|
SkPath path;
|
||||||
|
|
||||||
// circle at origin
|
// circle at origin
|
||||||
@ -3511,19 +3511,19 @@ static void test_circle(skiatest::Reporter* reporter) {
|
|||||||
SkPath path;
|
SkPath path;
|
||||||
path.addCircle(0, 0, SkIntToScalar(10), SkPathDirection::kCW);
|
path.addCircle(0, 0, SkIntToScalar(10), SkPathDirection::kCW);
|
||||||
path.addCircle(0, 0, SkIntToScalar(20), SkPathDirection::kCW);
|
path.addCircle(0, 0, SkIntToScalar(20), SkPathDirection::kCW);
|
||||||
check_for_circle(reporter, path, false, SkPathPriv::kCW_FirstDirection);
|
check_for_circle(reporter, path, false, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
// some extra lineTo() would make isOval() fail
|
// some extra lineTo() would make isOval() fail
|
||||||
path.reset();
|
path.reset();
|
||||||
path.addCircle(0, 0, SkIntToScalar(10), SkPathDirection::kCW);
|
path.addCircle(0, 0, SkIntToScalar(10), SkPathDirection::kCW);
|
||||||
path.lineTo(0, 0);
|
path.lineTo(0, 0);
|
||||||
check_for_circle(reporter, path, false, SkPathPriv::kCW_FirstDirection);
|
check_for_circle(reporter, path, false, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
// not back to the original point
|
// not back to the original point
|
||||||
path.reset();
|
path.reset();
|
||||||
path.addCircle(0, 0, SkIntToScalar(10), SkPathDirection::kCW);
|
path.addCircle(0, 0, SkIntToScalar(10), SkPathDirection::kCW);
|
||||||
path.setLastPt(SkIntToScalar(5), SkIntToScalar(5));
|
path.setLastPt(SkIntToScalar(5), SkIntToScalar(5));
|
||||||
check_for_circle(reporter, path, false, SkPathPriv::kCW_FirstDirection);
|
check_for_circle(reporter, path, false, SkPathFirstDirection::kCW);
|
||||||
|
|
||||||
test_circle_with_add_paths(reporter);
|
test_circle_with_add_paths(reporter);
|
||||||
|
|
||||||
@ -3725,7 +3725,7 @@ static void test_arc(skiatest::Reporter* reporter) {
|
|||||||
// TODO: one way to keep it concave would be to introduce interpolated on curve points
|
// TODO: one way to keep it concave would be to introduce interpolated on curve points
|
||||||
// between control points and computing the on curve point at scan conversion time
|
// between control points and computing the on curve point at scan conversion time
|
||||||
REPORTER_ASSERT(reporter, p.isConvex());
|
REPORTER_ASSERT(reporter, p.isConvex());
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p, SkPathPriv::kCW_FirstDirection));
|
REPORTER_ASSERT(reporter, SkPathPriv::CheapIsFirstDirection(p, SkPathFirstDirection::kCW));
|
||||||
SkPathPriv::ForceComputeConvexity(p);
|
SkPathPriv::ForceComputeConvexity(p);
|
||||||
REPORTER_ASSERT(reporter, p.isConvex());
|
REPORTER_ASSERT(reporter, p.isConvex());
|
||||||
}
|
}
|
||||||
@ -5509,8 +5509,8 @@ struct Xforms {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static bool conditional_convex(const SkPath& path, bool is_convex) {
|
static bool conditional_convex(const SkPath& path, bool is_convex) {
|
||||||
SkPathConvexityType c = SkPathPriv::GetConvexityTypeOrUnknown(path);
|
SkPathConvexity c = SkPathPriv::GetConvexityOrUnknown(path);
|
||||||
return is_convex ? (c == SkPathConvexityType::kConvex) : (c != SkPathConvexityType::kConvex);
|
return is_convex ? (c == SkPathConvexity::kConvex) : (c != SkPathConvexity::kConvex);
|
||||||
}
|
}
|
||||||
|
|
||||||
// expect axis-aligned shape to survive assignment, identity and scale/translate matrices
|
// expect axis-aligned shape to survive assignment, identity and scale/translate matrices
|
||||||
@ -5526,15 +5526,15 @@ void survive(SkPath* path, const Xforms& x, bool isAxisAligned, skiatest::Report
|
|||||||
// a path's isa and convexity should survive assignment
|
// a path's isa and convexity should survive assignment
|
||||||
path2 = *path;
|
path2 = *path;
|
||||||
REPORTER_ASSERT(reporter, isa_proc(path2));
|
REPORTER_ASSERT(reporter, isa_proc(path2));
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityTypeOrUnknown(path2) == SkPathConvexityType::kConvex);
|
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityOrUnknown(path2) == SkPathConvexity::kConvex);
|
||||||
|
|
||||||
// a path's isa and convexity should identity transform
|
// a path's isa and convexity should identity transform
|
||||||
path->transform(x.fIM, &path2);
|
path->transform(x.fIM, &path2);
|
||||||
path->transform(x.fIM);
|
path->transform(x.fIM);
|
||||||
REPORTER_ASSERT(reporter, isa_proc(path2));
|
REPORTER_ASSERT(reporter, isa_proc(path2));
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityTypeOrUnknown(path2) == SkPathConvexityType::kConvex);
|
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityOrUnknown(path2) == SkPathConvexity::kConvex);
|
||||||
REPORTER_ASSERT(reporter, isa_proc(*path));
|
REPORTER_ASSERT(reporter, isa_proc(*path));
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityTypeOrUnknown(*path) == SkPathConvexityType::kConvex);
|
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityOrUnknown(*path) == SkPathConvexity::kConvex);
|
||||||
|
|
||||||
// a path's isa should survive translation, convexity depends on axis alignment
|
// a path's isa should survive translation, convexity depends on axis alignment
|
||||||
path->transform(x.fTM, &path2);
|
path->transform(x.fTM, &path2);
|
||||||
@ -5554,11 +5554,11 @@ void survive(SkPath* path, const Xforms& x, bool isAxisAligned, skiatest::Report
|
|||||||
|
|
||||||
// For security, post-rotation, we can't assume we're still convex. It might prove to be,
|
// For security, post-rotation, we can't assume we're still convex. It might prove to be,
|
||||||
// in fact, still be convex, be we can't have cached that setting, hence the call to
|
// in fact, still be convex, be we can't have cached that setting, hence the call to
|
||||||
// getConvexityTypeOrUnknown() instead of getConvexityType().
|
// getConvexityOrUnknown() instead of getConvexity().
|
||||||
path->transform(x.fRM, &path2);
|
path->transform(x.fRM, &path2);
|
||||||
path->transform(x.fRM);
|
path->transform(x.fRM);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityTypeOrUnknown(path2) != SkPathConvexityType::kConvex);
|
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityOrUnknown(path2) != SkPathConvexity::kConvex);
|
||||||
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityTypeOrUnknown(*path) != SkPathConvexityType::kConvex);
|
REPORTER_ASSERT(reporter, SkPathPriv::GetConvexityOrUnknown(*path) != SkPathConvexity::kConvex);
|
||||||
|
|
||||||
if (isAxisAligned) {
|
if (isAxisAligned) {
|
||||||
REPORTER_ASSERT(reporter, !isa_proc(path2));
|
REPORTER_ASSERT(reporter, !isa_proc(path2));
|
||||||
|
Loading…
Reference in New Issue
Block a user