Struct kurbo::QuadBez[][src]

pub struct QuadBez {
    pub p0: Point,
    pub p1: Point,
    pub p2: Point,
}
Expand description

A single quadratic Bézier segment.

Fields

p0: Pointp1: Pointp2: Point

Implementations

Create a new quadratic Bézier segment.

Raise the order by 1.

Returns a cubic Bézier segment that exactly represents this quadratic.

Is this quadratic Bezier curve finite?

Is this quadratic Bezier curve NaN?

Trait Implementations

Returns a copy of the value. Read more

Performs copy-assignment from source. Read more

Formats the value using the given formatter. Read more

Deserialize this value from the given Serde deserializer. Read more

Performs the conversion.

The name of the generated JSON Schema. Read more

Generates a JSON Schema for this type. Read more

Whether JSON Schemas generated for this type should be re-used where possible using the $ref keyword. Read more

The resulting type after applying the * operator.

Performs the * operation. Read more

The resulting type after applying the * operator.

Performs the * operation. Read more

Subdivide into halves, using de Casteljau.

Evaluate the curve at parameter t. Read more

Get a subsegment of the curve for the given parameter range.

The start point.

The end point.

Arclength of a quadratic Bézier segment.

This computation is based on an analytical formula. Since that formula suffers from numerical instability when the curve is very close to a straight line, we detect that case and fall back to Legendre-Gauss quadrature.

Accuracy should be better than 1e-13 over the entire range.

Adapted from http://www.malczak.linuxpl.com/blog/quadratic-bezier-curve-length/ with permission.

Solve for the parameter that has the given arc length from the start. Read more

Compute the signed area under the curve. Read more

Compute the signed curvature at parameter t.

The parametric curve obtained by taking the derivative of this one.

The derivative of the curve. Read more

Estimate arclength using Gaussian quadrature. Read more

Compute the extrema of the curve. Read more

Return parameter ranges, each of which is monotonic within the range.

The smallest rectangle that encloses the curve in the range (0..1).

Find the nearest point, using analytical algorithm based on cubic root finding.

This method tests for self and other values to be equal, and is used by ==. Read more

This method tests for !=.

Serialize this value into the given Serde serializer. Read more

The iterator returned by the path_elements method. Read more

Returns an iterator over this shape expressed as PathEls; that is, as Bézier path elements. Read more

Signed area. Read more

Total length of perimeter.

The winding number of a point. Read more

The smallest rectangle that encloses the shape.

Convert to a Bézier path. Read more

Convert into a Bézier path. Read more

Returns an iterator over this shape expressed as Bézier path segments (PathSegs). Read more

Returns true if the Point is inside this shape. Read more

If the shape is a line, make it available.

If the shape is a rectangle, make it available.

If the shape is a rounded rectangle, make it available.

If the shape is a circle, make it available.

If the shape is stored as a slice of path elements, make that available. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Performs the conversion.

Performs the conversion.

The resulting type after obtaining ownership.

Creates owned data from borrowed data, usually by cloning. Read more

🔬 This is a nightly-only experimental API. (toowned_clone_into)

Uses borrowed data to replace owned data, usually by cloning. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.