blob: 6eeb1a5703f1e59994bb680a643b5d3bedba177a [file] [log] [blame]
#Topic Point
#Alias Points
#Alias Point_Reference
#Struct SkPoint
#Topic Overview
#Subtopic Subtopics
#ToDo manually add subtopics ##
#Table
#Legend
# topics # description ##
#Legend ##
#Table ##
##
#Subtopic Operators
#Table
#Legend
# description # function ##
#Legend ##
# SkPoint operator*(SkScalar scale)_const # Returns Point multiplied by scale. ##
# SkPoint operator-()_const # Reverses sign of Point. ##
# SkPoint& operator*=(SkScalar scale) # Multiplies Point by scale factor. ##
# SkPoint operator+(const SkPoint& a, const SkVector& b) # Returns Point offset by Vector. ##
# SkVector operator-(const SkPoint& a, const SkPoint& b) # Returns Vector between Points. ##
# bool operator!=(const SkPoint& a, const SkPoint& b) # Returns true if Point are unequal. ##
# bool operator==(const SkPoint& a, const SkPoint& b) # Returns true if Point are equal. ##
# void operator+=(const SkVector& v) # Adds Vector to Point. ##
# void operator-=(const SkVector& v) # Subtracts Vector from Point. ##
#Table ##
#Subtopic ##
#Subtopic Member_Functions
#Table
#Legend
# description # function ##
#Legend ##
# CrossProduct # Returns cross product. ##
# Distance # Returns straight-line distance between points. ##
# DotProduct # Returns dot product. ##
# Length # Returns straight-line distance to origin. ##
# Make # Constructs from SkScalar inputs. ##
# Normalize # Sets length to one, and returns prior length. ##
# Offset # Translates Point array. ##
# cross() # Returns cross product. ##
# distanceToOrigin # Returns straight-line distance to origin. ##
# dot() # Returns dot product. ##
# equals() # Returns true if Points are equal. ##
# isFinite # Returns true if no member is infinite or NaN. ##
# isZero # Returns true if both members equal zero. ##
# iset() # Sets to integer input. ##
# length() # Returns straight-line distance to origin. ##
# negate() # Reverses the sign of both members. ##
# normalize() # Sets length to one, preserving direction. ##
# offset() # Translates Point. ##
# scale() # Multiplies Point by scale factor. ##
# set() # Sets to SkScalar input. ##
# setAbs # Sets sign of both members to positive. ##
# setLength # Sets straight-line distance to origin. ##
# setNormalize # Sets length to one, in direction of (x, y). ##
# x() # Returns fX. ##
# y() # Returns fY. ##
#Table ##
#Subtopic ##
#Topic ##
#Member SkScalar fX
x-axis value used by both Point and Vector. May contain any value, including
infinities and NaN.
##
#Member SkScalar fY
y-axis value used by both Point and Vector. May contain any value, including
infinities and NaN.
##
# ------------------------------------------------------------------------------
#Method static constexpr SkPoint Make(SkScalar x, SkScalar y)
Sets fX to x, fY to y. Used both to set Point and Vector.
#Param x SkScalar x-axis value of constructed Point or Vector ##
#Param y SkScalar y-axis value of constructed Point or Vector ##
#Return Point (x, y) ##
#Example
SkPoint pt1 = {45, 66};
SkPoint pt2 = SkPoint::Make(45, 66);
SkVector v1 = {45, 66};
SkVector v2 = SkPoint::Make(45, 66);
SkDebugf("all %s" "equal\n", pt1 == pt2 && pt2 == v1 && v1 == v2 ? "" : "not ");
#StdOut
all equal
##
##
#SeeAlso set() iset() SkIPoint::Make
#Method ##
# ------------------------------------------------------------------------------
#Method SkScalar x() const
Returns x-axis value of Point or Vector.
#Return fX ##
#Example
SkPoint pt1 = {45, 66};
SkDebugf("pt1.fX %c= pt1.x()\n", pt1.fX == pt1.x() ? '=' : '!');
#StdOut
pt1.fX == pt1.x()
##
##
#SeeAlso y() SkIPoint::x()
#Method ##
# ------------------------------------------------------------------------------
#Method SkScalar y() const
Returns y-axis value of Point or Vector.
#Return fY ##
#Example
SkPoint pt1 = {45, 66};
SkDebugf("pt1.fY %c= pt1.y()\n", pt1.fY == pt1.y() ? '=' : '!');
#StdOut
pt1.fY == pt1.y()
##
##
#SeeAlso x() SkIPoint::y()
#Method ##
# ------------------------------------------------------------------------------
#Method bool isZero() const
Returns true if fX and fY are both zero.
#Return true if fX is zero and fY is zero ##
#Example
SkPoint pt = { 0.f, -0.f};
SkDebugf("pt.fX=%c%g pt.fY=%c%g\n", std::signbit(pt.fX) ? '-' : '+', fabsf(pt.fX),
std::signbit(pt.fY) ? '-' : '+', fabsf(pt.fY));
SkDebugf("pt.isZero() == %s\n", pt.isZero() ? "true" : "false");
#StdOut
pt.fX=+0 pt.fY=-0
pt.isZero() == true
##
##
#SeeAlso isFinite SkIPoint::isZero
#Method ##
# ------------------------------------------------------------------------------
#Method void set(SkScalar x, SkScalar y)
Sets fX to x and fY to y.
#Param x new value for fX ##
#Param y new value for fY ##
#Example
SkPoint pt1, pt2 = { SK_ScalarPI, SK_ScalarSqrt2 };
pt1.set(SK_ScalarPI, SK_ScalarSqrt2);
SkDebugf("pt1 %c= pt2\n", pt1 == pt2 ? '=' : '!');
#StdOut
pt1 == pt2
##
##
#SeeAlso iset() Make
#Method ##
# ------------------------------------------------------------------------------
#Method void iset(int32_t x, int32_t y)
Sets fX to x and fY to y, promoting integers to SkScalar values.
Assigning a large integer value directly to fX or fY may cause a compiler
error, triggered by narrowing conversion of int to SkScalar. This safely
casts x and y to avoid the error.
#Param x new value for fX ##
#Param y new value for fY ##
#Example
SkPoint pt1, pt2 = { SK_MinS16, SK_MaxS16 };
pt1.iset(SK_MinS16, SK_MaxS16);
SkDebugf("pt1 %c= pt2\n", pt1 == pt2 ? '=' : '!');
##
#SeeAlso set Make SkIPoint::set
#Method ##
# ------------------------------------------------------------------------------
#Method void iset(const SkIPoint& p)
Sets fX to p.fX and fY to p.fY, promoting integers to SkScalar values.
Assigning an IPoint containing a large integer value directly to fX or fY may
cause a compiler error, triggered by narrowing conversion of int to SkScalar.
This safely casts p.fX and p.fY to avoid the error.
#Param p IPoint members promoted to SkScalar ##
#Example
SkIPoint iPt = { SK_MinS32, SK_MaxS32 };
SkPoint fPt;
fPt.iset(iPt);
SkDebugf("iPt: %d, %d\n", iPt.fX, iPt.fY);
SkDebugf("fPt: %g, %g\n", fPt.fX, fPt.fY);
#StdOut
iPt: -2147483647, 2147483647
fPt: -2.14748e+09, 2.14748e+09
##
##
#SeeAlso set Make SkIPoint::set
#Method ##
# ------------------------------------------------------------------------------
#Method void setAbs(const SkPoint& pt)
Sets fX to absolute value of pt.fX; and fY to absolute value of pt.fY.
#Param pt members providing magnitude for fX and fY ##
#Example
SkPoint test[] = { {0.f, -0.f}, {-1, -2},
{ SK_ScalarInfinity, SK_ScalarNegativeInfinity },
{ SK_ScalarNaN, -SK_ScalarNaN } };
for (const SkPoint& pt : test) {
SkPoint absPt;
absPt.setAbs(pt);
SkDebugf("pt: %g, %g abs: %g, %g\n", pt.fX, pt.fY, absPt.fX, absPt.fY);
}
#StdOut
pt: 0, -0 abs: 0, 0
pt: -1, -2 abs: 1, 2
pt: inf, -inf abs: inf, inf
pt: nan, -nan abs: nan, nan
##
##
#SeeAlso set Make negate
#Method ##
# ------------------------------------------------------------------------------
#Method static void Offset(SkPoint points[], int count, const SkVector& offset)
Adds offset to each Point in points array with count entries.
#Param points Point array ##
#Param count entries in array ##
#Param offset Vector added to points ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
SkPoint::Offset(points, SK_ARRAY_COUNT(points), { 1, 9 } );
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso offset operator+=(const SkVector& v)
#Method ##
# ------------------------------------------------------------------------------
#Method static void Offset(SkPoint points[], int count, SkScalar dx, SkScalar dy)
Adds offset (dx, dy) to each Point in points array of length count.
#Param points Point array ##
#Param count entries in array ##
#Param dx added to fX in points ##
#Param dy added to fY in points ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
SkPoint::Offset(points, SK_ARRAY_COUNT(points), 1, 9);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso offset operator+=(const SkVector& v)
#Method ##
# ------------------------------------------------------------------------------
#Method void offset(SkScalar dx, SkScalar dy)
Adds offset (dx, dy) to Point.
#Param dx added to fX ##
#Param dy added to fY ##
#Example
#Height 128
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
points[1].offset(1, 1);
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso Offset operator+=(const SkVector& v)
#Method ##
# ------------------------------------------------------------------------------
#Method SkScalar length() const
Returns the Euclidean_Distance from origin, computed as:
#Code
#Literal
sqrt(fX * fX + fY * fY)
##
.
#Return straight-line distance to origin ##
#Example
#Height 192
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint points[] = { { 90, 30 }, { 120, 150 }, { 150, 30 }, { 210, 90 } };
const SkPoint origin = {30, 140};
for (auto point : points) {
canvas->drawLine(origin, point, paint);
SkAutoCanvasRestore acr(canvas, true);
SkScalar angle = SkScalarATan2((point.fY - origin.fY), point.fX - origin.fX);
canvas->rotate(angle * 180 / SK_ScalarPI, origin.fX, origin.fY);
SkString length("length = ");
length.appendScalar(point.length());
canvas->drawString(length, origin.fX + 25, origin.fY - 4, paint);
}
##
#SeeAlso distanceToOrigin Length setLength Distance
#Method ##
# ------------------------------------------------------------------------------
#Method SkScalar distanceToOrigin() const
Returns the Euclidean_Distance from origin, computed as:
#Code
#Literal
sqrt(fX * fX + fY * fY)
##
.
#Return straight-line distance to origin ##
#Example
#Height 192
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint points[] = { { 60, -110 }, { 90, 10 }, { 120, -110 }, { 180, -50 } };
const SkPoint origin = {0, 0};
canvas->translate(30, 140);
for (auto point : points) {
canvas->drawLine(origin, point, paint);
SkAutoCanvasRestore acr(canvas, true);
SkScalar angle = SkScalarATan2((point.fY - origin.fY), point.fX - origin.fX);
canvas->rotate(angle * 180 / SK_ScalarPI, origin.fX, origin.fY);
SkString distance("distance = ");
distance.appendScalar(point.distanceToOrigin());
canvas->drawString(distance, origin.fX + 25, origin.fY - 4, paint);
}
##
#SeeAlso length Length setLength Distance
#Method ##
# ------------------------------------------------------------------------------
#Method bool normalize()
Scales (fX, fY) so that length() returns one, while preserving ratio of fX to fY,
if possible. If prior length is nearly zero, sets Vector to (0, 0) and returns
false; otherwise returns true.
#Return true if former length is not zero or nearly zero ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint lines[][2] = { {{ 30, 110 }, { 190, 30 }},
{{ 120, 140 }, { 30, 220 }}};
for (auto line : lines) {
canvas->drawLine(line[0], line[1], paint);
SkVector vector = line[1] - line[0];
if (vector.normalize()) {
SkVector rotate90 = { -vector.fY, vector.fX };
rotate90 *= 10.f;
canvas->drawLine(line[0] - rotate90, line[0] + rotate90, paint);
canvas->drawLine(line[1] - rotate90, line[1] + rotate90, paint);
}
}
##
#SeeAlso Normalize setLength length Length
#Method ##
# ------------------------------------------------------------------------------
#Method bool setNormalize(SkScalar x, SkScalar y)
Sets Vector to (x, y) scaled so length() returns one, and so that
(fX, fY) is proportional to (x, y). If (x, y) length is nearly zero,
sets Vector to (0, 0) and returns false; otherwise returns true.
#Param x proportional value for fX ##
#Param y proportional value for fY ##
#Return true if (x, y) length is not zero or nearly zero ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint points[] = { { 60, -110 }, { 90, 10 }, { 120, -110 }, { 180, -50 } };
const SkPoint origin = {0, 0};
canvas->translate(30, 140);
for (auto point : points) {
paint.setStrokeWidth(1);
paint.setColor(SK_ColorBLACK);
canvas->drawLine(origin, point, paint);
SkVector normal;
normal.setNormalize(point.fX, point.fY);
normal *= 100;
paint.setStrokeWidth(10);
paint.setColor(0x3f4512bf);
canvas->drawLine(origin, normal, paint);
}
##
#SeeAlso normalize setLength
#Method ##
# ------------------------------------------------------------------------------
#Method bool setLength(SkScalar length)
Scales Vector so that distanceToOrigin returns length, if possible. If former
length is nearly zero, sets Vector to (0, 0) and return false; otherwise returns
true.
#Param length straight-line distance to origin ##
#Return true if former length is not zero or nearly zero ##
#Example
#Height 160
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint points[] = { { 60, -110 }, { 90, 10 }, { 120, -110 }, { 180, -50 } };
const SkPoint origin = {0, 0};
canvas->translate(30, 140);
for (auto point : points) {
paint.setStrokeWidth(1);
paint.setColor(SK_ColorBLACK);
canvas->drawLine(origin, point, paint);
SkVector normal = point;
normal.setLength(100);
paint.setStrokeWidth(10);
paint.setColor(0x3f45bf12);
canvas->drawLine(origin, normal, paint);
}
##
#SeeAlso length Length setNormalize setAbs
#Method ##
# ------------------------------------------------------------------------------
#Method bool setLength(SkScalar x, SkScalar y, SkScalar length)
Sets Vector to (x, y) scaled to length, if possible. If former
length is nearly zero, sets Vector to (0, 0) and return false; otherwise returns
true.
#Param x proportional value for fX ##
#Param y proportional value for fY ##
#Param length straight-line distance to origin ##
#Return true if (x, y) length is not zero or nearly zero ##
#Example
#Height 160
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint points[] = { { 60, -110 }, { 90, 10 }, { 120, -110 }, { 180, -50 } };
const SkPoint origin = {0, 0};
canvas->translate(30, 140);
for (auto point : points) {
paint.setStrokeWidth(1);
paint.setColor(SK_ColorBLACK);
canvas->drawLine(origin, point, paint);
SkVector normal;
normal.setLength(point.fX, point.fY, 100);
paint.setStrokeWidth(10);
paint.setColor(0x3fbf4512);
canvas->drawLine(origin, normal, paint);
}
##
#SeeAlso length Length setNormalize setAbs
#Method ##
# ------------------------------------------------------------------------------
#Method void scale(SkScalar scale, SkPoint* dst) const
Sets dst to Point times scale. dst may be Point to modify Point in place.
#Param scale factor to multiply Point by ##
#Param dst storage for scaled Point ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkPoint point = {40, -15}, scaled;
SkPoint origin = {30, 110};
for (auto scale : {1, 2, 3, 5}) {
paint.setStrokeWidth(scale * 5);
paint.setARGB(0x7f, 0x9f, 0xbf, 0x33 * scale);
point.scale(scale, &scaled);
canvas->drawLine(origin, origin + scaled, paint);
}
##
#SeeAlso operator*(SkScalar scale)_const operator*=(SkScalar scale) setLength
#Method ##
# ------------------------------------------------------------------------------
#Method void scale(SkScalar value)
Scales Point in place by scale.
#Param value factor to multiply Point by ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkPoint point = {40, -15};
SkPoint origin = {30, 110};
for (auto scale : {1, 2, 3, 5}) {
paint.setStrokeWidth(scale * 5);
paint.setARGB(0x7f, 0x9f, 0xbf, 0x33 * scale);
point.scale(scale);
canvas->drawLine(origin, origin + point, paint);
}
##
#SeeAlso operator*(SkScalar scale)_const operator*=(SkScalar scale) setLength
#Method ##
# ------------------------------------------------------------------------------
#Method void negate()
Changes the sign of fX and fY.
#Example
SkPoint test[] = { {0.f, -0.f}, {-1, -2},
{ SK_ScalarInfinity, SK_ScalarNegativeInfinity },
{ SK_ScalarNaN, -SK_ScalarNaN } };
for (const SkPoint& pt : test) {
SkPoint negPt = pt;
negPt.negate();
SkDebugf("pt: %g, %g negate: %g, %g\n", pt.fX, pt.fY, negPt.fX, negPt.fY);
}
#StdOut
pt: 0, -0 negate: -0, 0
pt: -1, -2 negate: 1, 2
pt: inf, -inf negate: -inf, inf
pt: nan, -nan negate: -nan, nan
##
##
#SeeAlso operator-()_const setAbs
#Method ##
# ------------------------------------------------------------------------------
#Method SkPoint operator-()_const
Returns Point changing the signs of fX and fY.
#Return Point as (-fX, -fY) ##
#Example
SkPoint test[] = { {0.f, -0.f}, {-1, -2},
{ SK_ScalarInfinity, SK_ScalarNegativeInfinity },
{ SK_ScalarNaN, -SK_ScalarNaN } };
for (const SkPoint& pt : test) {
SkPoint negPt = -pt;
SkDebugf("pt: %g, %g negate: %g, %g\n", pt.fX, pt.fY, negPt.fX, negPt.fY);
}
#StdOut
pt: 0, -0 negate: -0, 0
pt: -1, -2 negate: 1, 2
pt: inf, -inf negate: -inf, inf
pt: nan, -nan negate: -nan, nan
##
##
#SeeAlso negate operator-(const SkPoint& a, const SkPoint& b) operator-=(const SkVector& v) SkIPoint::operator-()_const
#Method ##
# ------------------------------------------------------------------------------
#Method void operator+=(const SkVector& v)
Adds Vector v to Point. Sets Point to:
#Formula
(fX + v.fX, fY + v.fY)
##
.
#Param v Vector to add ##
#Example
#Height 128
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
points[1] += {1, 1};
points[2] += {-1, -1};
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso offset() operator+(const SkPoint& a, const SkVector& b) SkIPoint::operator+=(const SkIVector& v)
#Method ##
# ------------------------------------------------------------------------------
#Method void operator-=(const SkVector& v)
Subtracts Vector v from Point. Sets Point to:
#Formula
(fX - v.fX, fY - v.fY)
##
.
#Param v Vector to subtract ##
#Example
#Height 128
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
points[1] -= {1, 1};
points[2] -= {-1, -1};
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso offset() operator-(const SkPoint& a, const SkPoint& b) SkIPoint::operator-=(const SkIVector& v)
#Method ##
# ------------------------------------------------------------------------------
#Method SkPoint operator*(SkScalar scale)_const
Returns Point multiplied by scale.
#Param scale Scalar to multiply by ##
#Return Point as (fX * scale, fY * scale) ##
#Example
#Height 128
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(15, 10);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
for (auto& point : points) {
point = point * 1.5f;
}
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso operator*=(SkScalar scale) scale() setLength setNormalize
#Method ##
# ------------------------------------------------------------------------------
#Method SkPoint& operator*=(SkScalar scale)
Multiplies Point by scale. Sets Point to:
#Formula
(fX * scale, fY * scale)
##
#Param scale Scalar to multiply by ##
#Return reference to Point ##
#Example
#Height 128
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(15, 10);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
for (auto& point : points) {
point *= 2;
}
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso operator*(SkScalar scale)_const scale() setLength setNormalize
#Method ##
# ------------------------------------------------------------------------------
#Method bool isFinite() const
Returns true if both fX and fY are measurable values.
#Return true for values other than infinities and NaN ##
#Example
SkPoint test[] = { {0, -0.f}, {-1, -2}, {SK_ScalarInfinity, 1}, {SK_ScalarNaN, -1} };
for (const SkPoint& pt : test) {
SkDebugf("pt: %g, %g finite: %s\n", pt.fX, pt.fY, pt.isFinite() ? "true" : "false");
}
#StdOut
pt: 0, -0 finite: true
pt: -1, -2 finite: true
pt: inf, 1 finite: false
pt: nan, -1 finite: false
##
##
#SeeAlso SkRect::isFinite SkPath::isFinite
#Method ##
# ------------------------------------------------------------------------------
#Method bool equals(SkScalar x, SkScalar y) const
Returns true if Point is equivalent to Point constructed from (x, y).
#Param x value compared with fX ##
#Param y value compared with fY ##
#Return true if Point equals (x, y) ##
#Example
SkPoint test[] = { {0, -0.f}, {-1, -2}, {SK_ScalarInfinity, 1}, {SK_ScalarNaN, -1} };
for (const SkPoint& pt : test) {
SkDebugf("pt: %g, %g %c= pt\n", pt.fX, pt.fY, pt.equals(pt.fX, pt.fY) ? '=' : '!');
}
#StdOut
pt: 0, -0 == pt
pt: -1, -2 == pt
pt: inf, 1 == pt
pt: nan, -1 != pt
##
##
#SeeAlso operator==(const SkPoint& a, const SkPoint& b)
#Method ##
# ------------------------------------------------------------------------------
#Method bool operator==(const SkPoint& a, const SkPoint& b)
Returns true if a is equivalent to b.
#Param a Point to compare ##
#Param b Point to compare ##
#Return true if a.fX == b.fX and a.fY == b.fY ##
#Example
SkPoint test[] = { {0, -0.f}, {-1, -2}, {SK_ScalarInfinity, 1}, {SK_ScalarNaN, -1} };
for (const SkPoint& pt : test) {
SkDebugf("pt: %g, %g %c= pt\n", pt.fX, pt.fY, pt == pt ? '=' : '!');
}
#StdOut
pt: 0, -0 == pt
pt: -1, -2 == pt
pt: inf, 1 == pt
pt: nan, -1 != pt
##
##
#SeeAlso equals() operator!=(const SkPoint& a, const SkPoint& b)
#Method ##
# ------------------------------------------------------------------------------
#Method bool operator!=(const SkPoint& a, const SkPoint& b)
Returns true if a is not equivalent to b.
#Param a Point to compare ##
#Param b Point to compare ##
#Return true if a.fX != b.fX or a.fY != b.fY ##
#Example
SkPoint test[] = { {0, -0.f}, {-1, -2}, {SK_ScalarInfinity, 1}, {SK_ScalarNaN, -1} };
for (const SkPoint& pt : test) {
SkDebugf("pt: %g, %g %c= pt\n", pt.fX, pt.fY, pt != pt ? '!' : '=');
}
#StdOut
pt: 0, -0 == pt
pt: -1, -2 == pt
pt: inf, 1 == pt
pt: nan, -1 != pt
##
##
#SeeAlso operator==(const SkPoint& a, const SkPoint& b) equals()
#Method ##
# ------------------------------------------------------------------------------
#Method SkVector operator-(const SkPoint& a, const SkPoint& b)
Returns Vector from b to a, computed as
#Formula
(a.fX - b.fX, a.fY - b.fY)
##
.
Can also be used to subtract Vector from Point, returning Point.
Can also be used to subtract Vector from Vector, returning Vector.
#Param a Point to subtract from ##
#Param b Point to subtract ##
#Return Vector from b to a ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
points[1] += points[0] - points[2];
points[2] -= points[3] - points[5];
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso operator-=(const SkVector& v) offset()
#Method ##
# ------------------------------------------------------------------------------
#Method SkPoint operator+(const SkPoint& a, const SkVector& b)
Returns Point resulting from Point a offset by Vector b, computed as:
#Formula
(a.fX + b.fX, a.fY + b.fY)
##
.
Can also be used to offset Point b by Vector a, returning Point.
Can also be used to add Vector to Vector, returning Vector.
#Param a Point or Vector to add to ##
#Param b Point or Vector to add ##
#Return Point equal to a offset by b ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkPoint points[] = { { 3, 1 }, { 4, 2 }, { 5, 1 }, { 7, 3 },
{ 6, 4 }, { 7, 5 }, { 5, 7 },
{ 4, 6 }, { 3, 7 }, { 1, 5 },
{ 2, 4 }, { 1, 3 }, { 3, 1 } };
canvas->scale(30, 15);
paint.setStyle(SkPaint::kStroke_Style);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
SkVector mod = {1, 1};
for (auto& point : points) {
point = point + mod;
mod.fX *= 1.1f;
mod.fY += .2f;
}
paint.setColor(SK_ColorRED);
canvas->drawPoints(SkCanvas::kPolygon_PointMode, SK_ARRAY_COUNT(points), points, paint);
##
#SeeAlso operator+=(const SkVector& v) offset()
#Method ##
# ------------------------------------------------------------------------------
#Method static SkScalar Length(SkScalar x, SkScalar y)
Returns the Euclidean_Distance from origin, computed as:
#Code
#Literal
sqrt(x * x + y * y)
##
.
#Param x component of length ##
#Param y component of length ##
#Return straight-line distance to origin ##
#Example
#Height 192
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint points[] = { { 90, 30 }, { 120, 150 }, { 150, 30 }, { 210, 90 } };
const SkPoint origin = {30, 140};
for (auto point : points) {
canvas->drawLine(origin, point, paint);
SkAutoCanvasRestore acr(canvas, true);
SkScalar angle = SkScalarATan2((point.fY - origin.fY), point.fX - origin.fX);
canvas->rotate(angle * 180 / SK_ScalarPI, origin.fX, origin.fY);
SkString length("length = ");
length.appendScalar(SkPoint::Length(point.fX, point.fY));
canvas->drawString(length, origin.fX + 25, origin.fY - 4, paint);
}
##
#SeeAlso length() Distance setLength
#Method ##
# ------------------------------------------------------------------------------
#Method static SkScalar Normalize(SkVector* vec)
Scales (vec->fX, vec->fY) so that length() returns one, while preserving ratio of vec->fX to vec->fY,
if possible. If original length is nearly zero, sets vec to (0, 0) and returns zero;
otherwise, returns length of vec before vec is scaled.
Returned prior length may be SK_ScalarInfinity if it can not be represented by SkScalar.
Note that normalize() is faster if prior length is not required.
#Param vec normalized to unit length ##
#Return original vec length ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint lines[][2] = { {{ 30, 110 }, { 190, 30 }},
{{ 30, 220 }, { 120, 140 }}};
for (auto line : lines) {
canvas->drawLine(line[0], line[1], paint);
SkVector vector = line[1] - line[0];
SkScalar priorLength = SkPoint::Normalize(&vector);
SkVector rotate90 = { -vector.fY, vector.fX };
rotate90 *= 10.f;
canvas->drawLine(line[0] - rotate90, line[0] + rotate90, paint);
canvas->drawLine(line[1] - rotate90, line[1] + rotate90, paint);
SkString length("length = ");
length.appendScalar(priorLength);
canvas->drawString(length, line[0].fX + 25, line[0].fY - 4, paint);
}
##
#SeeAlso normalize() setLength Length
#Method ##
# ------------------------------------------------------------------------------
#Method static SkScalar Distance(const SkPoint& a, const SkPoint& b)
Returns the Euclidean_Distance between a and b.
#Param a line end point ##
#Param b line end point ##
#Return straight-line distance from a to b ##
#Example
#Height 192
SkPaint paint;
paint.setAntiAlias(true);
const SkPoint lines[][2] = {{{-10, -10}, {90, 30}}, {{0, 0}, {150, 30}}, {{10, 25}, {120, 150}}};
const SkPoint origin = {30, 160};
for (auto line : lines) {
SkPoint a = origin + line[0];
const SkPoint& b = line[1];
canvas->drawLine(a, b, paint);
SkAutoCanvasRestore acr(canvas, true);
SkScalar angle = SkScalarATan2((b.fY - a.fY), b.fX - a.fX);
canvas->rotate(angle * 180 / SK_ScalarPI, a.fX, a.fY);
SkString distance("distance = ");
distance.appendScalar(SkPoint::Distance(a, b));
canvas->drawString(distance, a.fX + 25, a.fY - 4, paint);
}
##
#SeeAlso length() setLength
#Method ##
# ------------------------------------------------------------------------------
#Method static SkScalar DotProduct(const SkVector& a, const SkVector& b)
Returns the dot product of Vector a and Vector b.
#Param a left side of dot product ##
#Param b right side of dot product ##
#Return product of input magnitudes and cosine of the angle between them ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkVector vectors[][2] = {{{50, 2}, {-14, 20}}, {{0, 50}, {-50, 0}}, {{-20, 25}, {25, -20}},
{{-20, -24}, {-24, -20}}};
SkPoint center[] = {{32, 32}, {160, 32}, {32, 160}, {160, 160}};
paint.setStrokeWidth(2);
for (size_t i = 0; i < 4; ++i) {
canvas->drawLine(center[i], center[i] + vectors[i][0], paint);
canvas->drawLine(center[i], center[i] + vectors[i][1], paint);
SkString str;
str.printf("dot = %g", SkPoint::DotProduct(vectors[i][0], vectors[i][1]));
canvas->drawString(str, center[i].fX, center[i].fY, paint);
}
##
#SeeAlso dot CrossProduct
#Method ##
# ------------------------------------------------------------------------------
#Method static SkScalar CrossProduct(const SkVector& a, const SkVector& b)
Returns the cross product of Vector a and Vector b.
a and b form three-dimensional vectors with z equal to zero. The cross product
is a three-dimensional vector with x and y equal to zero. The cross product z
term equals the returned value.
#Param a left side of cross product ##
#Param b right side of cross product ##
#Return area spanned by Vectors signed by angle direction ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkVector vectors[][2] = {{{50, 2}, {-14, 20}}, {{0, 50}, {-50, 0}}, {{-20, 25}, {25, -20}},
{{-20, -24}, {-24, -20}}};
SkPoint center[] = {{32, 32}, {160, 32}, {32, 160}, {160, 160}};
paint.setStrokeWidth(2);
for (size_t i = 0; i < 4; ++i) {
paint.setColor(SK_ColorRED);
canvas->drawLine(center[i], center[i] + vectors[i][0], paint);
paint.setColor(SK_ColorBLUE);
canvas->drawLine(center[i], center[i] + vectors[i][1], paint);
SkString str;
SkScalar cross = SkPoint::CrossProduct(vectors[i][1], vectors[i][0]);
str.printf("cross = %g", cross);
paint.setColor(cross >= 0 ? SK_ColorRED : SK_ColorBLUE);
canvas->drawString(str, center[i].fX, center[i].fY, paint);
}
##
#SeeAlso cross DotProduct
#Method ##
# ------------------------------------------------------------------------------
#Method SkScalar cross(const SkVector& vec) const
Returns the cross product of Vector and vec.
Vector and vec form three-dimensional vectors with z equal to zero. The
cross product is a three-dimensional vector with x and y equal to zero.
The cross product z term equals the returned value.
#Param vec right side of cross product ##
#Return area spanned by Vectors signed by angle direction ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkVector vectors[][2] = {{{50, 2}, {-14, 20}}, {{0, 50}, {-50, 0}}, {{-20, 25}, {25, -20}},
{{-20, -24}, {-24, -20}}};
SkPoint center[] = {{32, 32}, {160, 32}, {32, 160}, {160, 160}};
paint.setStrokeWidth(2);
for (size_t i = 0; i < 4; ++i) {
paint.setColor(SK_ColorRED);
canvas->drawLine(center[i], center[i] + vectors[i][0], paint);
paint.setColor(SK_ColorBLUE);
canvas->drawLine(center[i], center[i] + vectors[i][1], paint);
SkString str;
SkScalar cross = vectors[i][0].cross(vectors[i][1]);
str.printf("cross = %g", cross);
paint.setColor(cross >= 0 ? SK_ColorRED : SK_ColorBLUE);
canvas->drawString(str, center[i].fX, center[i].fY, paint);
}
##
#SeeAlso CrossProduct dot
#Method ##
# ------------------------------------------------------------------------------
#Method SkScalar dot(const SkVector& vec) const
Returns the dot product of Vector and Vector vec.
#Param vec right side of dot product ##
#Return product of input magnitudes and cosine of the angle between them ##
#Example
SkPaint paint;
paint.setAntiAlias(true);
SkVector vectors[][2] = {{{50, 2}, {-14, 20}}, {{0, 50}, {-50, 0}}, {{-20, 25}, {25, -20}},
{{-20, -24}, {-24, -20}}};
SkPoint center[] = {{32, 32}, {160, 32}, {32, 160}, {160, 160}};
paint.setStrokeWidth(2);
for (size_t i = 0; i < 4; ++i) {
canvas->drawLine(center[i], center[i] + vectors[i][0], paint);
canvas->drawLine(center[i], center[i] + vectors[i][1], paint);
SkString str;
str.printf("dot = %g", vectors[i][0].dot(vectors[i][1]));
canvas->drawString(str, center[i].fX, center[i].fY, paint);
}
##
#SeeAlso DotProduct cross
#Method ##
#Struct SkPoint ##
#Topic Point ##
# ------------------------------------------------------------------------------
#Topic Vector
#Alias Vectors
#Typedef SkPoint SkVector
#Typedef ##
##