Struct Ellipse

Source
pub struct Ellipse { /* private fields */ }
Expand description

An ellipse.

Implementations§

Source§

impl Ellipse

Source

pub fn new( center: impl Into<Point>, radii: impl Into<Vec2>, x_rotation: f64, ) -> Ellipse

Create A new ellipse with a given center, radii, and rotation.

The returned ellipse will be the result of taking a circle, stretching it by the radii along the x and y axes, then rotating it from the x axis by rotation radians, before finally translating the center to center.

Rotation is clockwise in a y-down coordinate system. For more on rotation, see Affine::rotate.

Source

pub fn from_rect(rect: Rect) -> Self

Returns the largest ellipse that can be bounded by this Rect.

This uses the absolute width and height of the rectangle.

This ellipse is always axis-aligned; to apply rotation you can call with_rotation with the result.

Source

pub fn from_affine(affine: Affine) -> Self

Create an ellipse from an affine transformation of the unit circle.

Source

pub fn with_center(self, new_center: impl Into<Point>) -> Ellipse

Create a new Ellipse centered on the provided point.

Source

pub fn with_radii(self, new_radii: Vec2) -> Ellipse

Create a new Ellipse with the provided radii.

Source

pub fn with_rotation(self, rotation: f64) -> Ellipse

Create a new Ellipse, with the rotation replaced by rotation radians.

The rotation is clockwise, for a y-down coordinate system. For more on rotation, See Affine::rotate.

Source

pub fn center(&self) -> Point

Returns the center of this ellipse.

Source

pub fn radii(&self) -> Vec2

Returns the two radii of this ellipse.

The first number is the horizontal radius and the second is the vertical radius, before rotation.

Source

pub fn rotation(&self) -> f64

The ellipse’s rotation, in radians.

This allows all possible ellipses to be drawn by always starting with an ellipse with the two radii on the x and y axes.

Source

pub fn radii_and_rotation(&self) -> (Vec2, f64)

Returns the radii and the rotation of this ellipse.

Equivalent to (self.radii(), self.rotation()) but more efficient.

Source

pub fn is_finite(&self) -> bool

Is this ellipse finite?

Source

pub fn is_nan(&self) -> bool

Is this ellipse NaN?

Trait Implementations§

Source§

impl Add<Vec2> for Ellipse

Source§

fn add(self, v: Vec2) -> Ellipse

In this context adding a Vec2 applies the corresponding translation to the ellipse.

Source§

type Output = Ellipse

The resulting type after applying the + operator.
Source§

impl Clone for Ellipse

Source§

fn clone(&self) -> Ellipse

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Ellipse

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Ellipse

Source§

fn default() -> Ellipse

Returns the “default value” for a type. Read more
Source§

impl From<Circle> for Ellipse

Source§

fn from(circle: Circle) -> Self

Converts to this type from the input type.
Source§

impl Mul<Ellipse> for Affine

Source§

type Output = Ellipse

The resulting type after applying the * operator.
Source§

fn mul(self, other: Ellipse) -> Self::Output

Performs the * operation. Read more
Source§

impl PartialEq for Ellipse

Source§

fn eq(&self, other: &Ellipse) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Shape for Ellipse

Source§

fn perimeter(&self, accuracy: f64) -> f64

Approximate the ellipse perimeter.

This uses a numerical approximation. The absolute error between the calculated perimeter and the true perimeter is bounded by accuracy (modulo floating point rounding errors).

For circular ellipses (equal horizontal and vertical radii), the calculated perimeter is exact.

Source§

type PathElementsIter<'iter> = Chain<Once<PathEl>, ArcAppendIter>

The iterator returned by the path_elements method.
Source§

fn path_elements(&self, tolerance: f64) -> Self::PathElementsIter<'_>

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

fn area(&self) -> f64

Signed area. Read more
Source§

fn winding(&self, pt: Point) -> i32

The winding number of a point. Read more
Source§

fn bounding_box(&self) -> Rect

The smallest rectangle that encloses the shape.
Source§

fn to_path(&self, tolerance: f64) -> BezPath

Convert to a Bézier path. Read more
Source§

fn into_path(self, tolerance: f64) -> BezPath
where Self: Sized,

Convert into a Bézier path. Read more
Source§

fn path_segments(&self, tolerance: f64) -> Segments<Self::PathElementsIter<'_>>

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

fn contains(&self, pt: Point) -> bool

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

fn as_line(&self) -> Option<Line>

If the shape is a line, make it available.
Source§

fn as_rect(&self) -> Option<Rect>

If the shape is a rectangle, make it available.
Source§

fn as_rounded_rect(&self) -> Option<RoundedRect>

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

fn as_circle(&self) -> Option<Circle>

If the shape is a circle, make it available.
Source§

fn as_path_slice(&self) -> Option<&[PathEl]>

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

impl Sub<Vec2> for Ellipse

Source§

fn sub(self, v: Vec2) -> Ellipse

In this context subtracting a Vec2 applies the corresponding translation to the ellipse.

Source§

type Output = Ellipse

The resulting type after applying the - operator.
Source§

impl Copy for Ellipse

Source§

impl StructuralPartialEq for Ellipse

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

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

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.