Skip to main content

Triangle

Struct Triangle 

Source
pub struct Triangle<T: CoordNum = f64>(pub Coord<T>, pub Coord<T>, pub Coord<T>);
Expand description

A bounded 2D area whose three vertices are defined by Coords. The semantics and validity are that of the equivalent Polygon; in addition, the three vertices must not be collinear and they must be distinct.

§Notes

Irrespective of input order the resulting geometry has ccw order and its vertices are yielded in ccw order by iterators

Tuple Fields§

§0: Coord<T>
👎Deprecated since 0.7.19:

Use Triangle::new for construction and triangle.v1() to retrieve the value.

§1: Coord<T>
👎Deprecated since 0.7.19:

Use Triangle::new for construction and triangle.v2() to retrieve the value.

§2: Coord<T>
👎Deprecated since 0.7.19:

Use Triangle::new for construction and triangle.v3() to retrieve the value.

Implementations§

Source§

impl<T: CoordNum> Triangle<T>

Source

pub fn new(v1: Coord<T>, v2: Coord<T>, v3: Coord<T>) -> Self

Create a new Triangle, enforcing default (counter clockwise) winding order.

If the vertices are given in clockwise order, they will be reversed. Degenerate triangles (collinear or identical vertices) are stored as-is.

Source

pub fn unchecked_winding(v1: Coord<T>, v2: Coord<T>, v3: Coord<T>) -> Self

Create a Triangle without normalising the winding order.

Use this when the caller has already verified CCW winding, or when the calling code does not depend on a particular winding order (e.g. inside tight loops where the orientation check would be wasteful).

Unlike Triangle::new, vertices are stored in the order given.

Source

pub fn v1(&self) -> Coord<T>

Return the first vertex of this triangle.

Source

pub fn v2(&self) -> Coord<T>

Return the second vertex of this triangle.

Source

pub fn v3(&self) -> Coord<T>

Return the third vertex of this triangle.

Source

pub fn to_array(&self) -> [Coord<T>; 3]

Source

pub fn to_lines(&self) -> [Line<T>; 3]

Source

pub fn to_polygon(self) -> Polygon<T>

Create a Polygon from the Triangle.

§Examples
use geo_types::{coord, Triangle, polygon};

// Input is CW
let triangle = Triangle::new(
    coord! { x: 0., y: 0. },
    coord! { x: 10., y: 20. },
    coord! { x: 20., y: -10. },
);

// Output is CCW
assert_eq!(
    triangle.to_polygon(),
    polygon![
        (x: 20., y: -10.),
        (x: 10., y: 20.),
        (x: 0., y: 0.),
        (x: 20., y: -10.),
    ],
);

Trait Implementations§

Source§

impl<T: Clone + CoordNum> Clone for Triangle<T>

Source§

fn clone(&self) -> Triangle<T>

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<T: CoordNum> Debug for Triangle<T>

Source§

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

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

impl<IC: Into<Coord<T>> + Copy, T: CoordNum> From<[IC; 3]> for Triangle<T>

Source§

fn from(array: [IC; 3]) -> Self

Converts to this type from the input type.
Source§

impl<T: CoordNum> From<Triangle<T>> for Geometry<T>

Source§

fn from(x: Triangle<T>) -> Self

Converts to this type from the input type.
Source§

impl<T: CoordNum> From<Triangle<T>> for Polygon<T>

Source§

fn from(t: Triangle<T>) -> Self

Converts to this type from the input type.
Source§

impl<T: Hash + CoordNum> Hash for Triangle<T>

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<T: PartialEq + CoordNum> PartialEq for Triangle<T>

Source§

fn eq(&self, other: &Triangle<T>) -> 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<T: CoordNum> TryFrom<Geometry<T>> for Triangle<T>

Convert a Geometry enum into its inner type.

Fails if the enum case does not match the type you are trying to convert it to.

Source§

type Error = Error

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

fn try_from(geom: Geometry<T>) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl<T: Copy + CoordNum> Copy for Triangle<T>

Source§

impl<T: Eq + CoordNum> Eq for Triangle<T>

Source§

impl<T: CoordNum> StructuralPartialEq for Triangle<T>

Auto Trait Implementations§

§

impl<T> Freeze for Triangle<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Triangle<T>
where T: RefUnwindSafe,

§

impl<T> Send for Triangle<T>
where T: Send,

§

impl<T> Sync for Triangle<T>
where T: Sync,

§

impl<T> Unpin for Triangle<T>
where T: Unpin,

§

impl<T> UnsafeUnpin for Triangle<T>
where T: UnsafeUnpin,

§

impl<T> UnwindSafe for Triangle<T>
where T: UnwindSafe,

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.