Curves topic
Curves turn a discrete (pointwise) representation of a line or area into a continuous shape: curves specify how to interpolate between two-dimensional [x, y] points.
Curves are typically not constructed or used directly. Instead, one of the built-in curves is being passed to line.curve or area.curve.
final line = Line(
(d, i, data) => x(d["date"]),
(d, i, data) => y(d["value"]),
)..curve = curveCatmullRomAlpha(0.5);
If desired, you can implement a custom curve. For an example of using a curve directly, see Context to Curve.
Classes
- Curve Curves
- Curves are typically not used directly, instead being passed to Line.curve and Area.curve. However, you can define your own curve implementation should none of the built-in curves satisfy your needs using the following interface; see the curveLinear source for an example implementation.
Functions
-
curveBasis(
Path context) → Curve Curves - Produces a cubic basis spline using the specified control points.
-
curveBasisClosed(
Path context) → Curve Curves - Produces a closed cubic basis spline using the specified control points.
-
curveBasisOpen(
Path context) → Curve Curves - Produces a cubic basis spline using the specified control points.
-
curveBumpX(
Path context) → Curve Curves - Produces a Bézier curve between each pair of points, with horizontal tangents at each point.
-
curveBumpY(
Path context) → Curve Curves - Produces a Bézier curve between each pair of points, with vertical tangents at each point.
-
curveBundle(
Path context) → Curve Curves - Produces a straightened cubic basis spline using the specified control points, with the spline straightened according to the curve’s beta (see curveBundleBeta), which defaults to 0.85.
-
curveBundleBeta(
num beta) → CurveFactory Curves -
Returns a bundle curve with the specified
beta
in the range [0, 1], representing the bundle strength. -
curveCardinal(
Path context) → Curve Curves - Produces a cubic cardinal spline using the specified control points, with one-sided differences used for the first and last piece.
-
curveCardinalClosed(
Path context) → Curve Curves - Produces a closed cubic cardinal spline using the specified control points. When a line segment ends, the first three control points are repeated, producing a closed loop.
-
curveCardinalClosedTension(
num tension) → CurveFactory Curves - Equivalent to curveCardinalTension, but returns a curveCardinalClosed.
-
curveCardinalOpen(
Path context) → Curve Curves - Produces a cubic cardinal spline using the specified control points.
-
curveCardinalOpenTension(
num tension) → CurveFactory Curves - Equivalent to curveCardinalTension, but returns a curveCardinalOpen.
-
curveCardinalTension(
num tension) → CurveCardinal Function(Path) Curves -
Returns a cardinal curve with the specified
tension
in the range [0, 1]. -
curveCatmullRom(
Path context) → Curve Curves - Produces a cubic Catmull–Rom spline using the specified control points and the parameter alpha (see curveCatmullRomAlpha), which defaults to 0.5, as proposed by Yuksel et al. in On the Parameterization of Catmull–Rom Curves, with one-sided differences used for the first and last piece.
-
curveCatmullRomAlpha(
num alpha) → CurveFactory Curves -
Returns a cubic Catmull–Rom curve with the specified
alpha
in the range [0, 1]. -
curveCatmullRomClosed(
Path context) → Curve Curves - Produces a closed cubic Catmull–Rom spline using the specified control points and the parameter alpha (see curveCatmullRomClosedAlpha), which defaults to 0.5, as proposed by Yuksel et al.
-
curveCatmullRomClosedAlpha(
num alpha) → CurveFactory Curves - Equivalent to curveCatmullRomAlpha, but returns a curveCatmullRomClosed.
-
curveCatmullRomOpen(
Path context) → Curve Curves - Produces a cubic Catmull–Rom spline using the specified control points and the parameter alpha (see curveCatmullRomClosedAlpha), which defaults to 0.5, as proposed by Yuksel et al.
-
curveCatmullRomOpenAlpha(
num alpha) → CurveFactory Curves - Equivalent to curveCatmullRomAlpha, but returns a curveCatmullRomOpen.
-
curveLinear(
Path context) → Curve Curves - Produces a polyline through the specified points.
-
curveLinearClosed(
Path context) → Curve Curves - Produces a closed polyline through the specified points by repeating the first point when the line segment ends.
-
curveMonotoneX(
Path context) → Curve Curves - Produces a cubic spline that preserves monotonicity in y, assuming monotonicity in x, as proposed by Steffen in A simple method for monotonic interpolation in one dimension: “a smooth curve with continuous first-order derivatives that passes through any given set of data points without spurious oscillations.
-
curveMonotoneY(
Path context) → Curve Curves - Produces a cubic spline that preserves monotonicity in x, assuming monotonicity in y, as proposed by Steffen in A simple method for monotonic interpolation in one dimension: “a smooth curve with continuous first-order derivatives that passes through any given set of data points without spurious oscillations.
-
curveNatural(
Path context) → Curve Curves - Produces a natural cubic spline with the second derivative of the spline set to zero at the endpoints.
-
curveStep(
Path context) → Curve Curves - Produces a piecewise constant function (a step function) consisting of alternating horizontal and vertical lines.
-
curveStepAfter(
Path context) → Curve Curves - Produces a piecewise constant function (a step function) consisting of alternating horizontal and vertical lines.
-
curveStepBefore(
Path context) → Curve Curves - Produces a piecewise constant function (a step function) consisting of alternating horizontal and vertical lines.
Typedefs
- CurveFactory = Curve Function(Path context) Curves
-
The definition of a curve factory: given a
context
, returns a curve.