UNPKG

toosoon-utils

Version:
76 lines (75 loc) 2.07 kB
import { cubicBezier } from '../../geometry'; import Curve from './Curve'; /** * Utility class for manipulating Cubic Bézier curves * * @exports * @class CubicBezierCurve * @extends Curve */ export default class CubicBezierCurve extends Curve { type = 'CubicBezierCurve'; /** * X-axis coordinate of the start point */ x1; /** * Y-axis coordinate of the start point */ y1; /** * X-axis coordinate of the first control point */ cp1x; /** * Y-axis coordinate of the first control point */ cp1y; /** * X-axis coordinate of the second control point */ cp2x; /** * Y-axis coordinate of the second control point */ cp2y; /** * X-axis coordinate of the end point */ x2; /** * Y-axis coordinate of the end point */ y2; /** * @param {number} x1 X-axis coordinate of the start point * @param {number} y1 Y-axis coordinate of the start point * @param {number} cp1x X-axis coordinate of the first control point * @param {number} cp1y Y-axis coordinate of the first control point * @param {number} cp2x X-axis coordinate of the second control point * @param {number} cp2y Y-axis coordinate of the second control point * @param {number} x2 X-axis coordinate of the end point * @param {number} y2 Y-axis coordinate of the end point */ constructor(x1, y1, cp1x, cp1y, cp2x, cp2y, x2, y2) { super(); this.x1 = x1; this.y1 = y1; this.cp1x = cp1x; this.cp1y = cp1y; this.cp2x = cp2x; this.cp2y = cp2y; this.x2 = x2; this.y2 = y2; } /** * Interpolate a point on the Cubic Bézier curve * * @param {number} t Normalized time value to interpolate * @returns {Point} Interpolated coordinates on the curve */ getPoint(t) { const point = cubicBezier(t, this.x1, this.y1, this.cp1x, this.cp1y, this.cp2x, this.cp2y, this.x2, this.y2); return point; } }