| #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 ## |
| ## |