Struct geng::prelude::Aabb2

pub struct Aabb2<T> {
    pub min: vec2<T>,
    pub max: vec2<T>,
}
Expand description

2d Axis aligned bounding box.

Fields§

§min: vec2<T>

Minimum coordinates

§max: vec2<T>

Maximum coordinates

Implementations§

§

impl<T> Aabb2<T>
where T: Copy,

pub fn bottom_left(&self) -> vec2<T>

Get the bottom-left corner of the Aabb2.

pub fn bottom_right(&self) -> vec2<T>

Get the bottom-right corner of the Aabb2.

pub fn top_left(&self) -> vec2<T>

Get the top-left corner of the Aabb2.

pub fn top_right(&self) -> vec2<T>

Get the top-right corner of the Aabb2.

pub fn corners(&self) -> [vec2<T>; 4]

Get an array of all four corner points

§

impl<T> Aabb2<T>
where T: UNum,

pub const ZERO: Aabb2<T> = _

An Aabb2 with both position and size equal to (0, 0).

pub fn from_corners(p1: vec2<T>, p2: vec2<T>) -> Aabb2<T>

Construct an Aabb2 from two opposite corners. The two corners can be given in any order.

§Examples
let aabb = Aabb2::from_corners(vec2(-5.0, -5.0), vec2(5.0, 5.0));
let same = Aabb2::from_corners(vec2(5.0, -5.0), vec2(-5.0, 5.0));
assert_eq!(aabb, same);

pub fn point(point: vec2<T>) -> Aabb2<T>

Create an Aabb2 at given position of size (0, 0).

§Examples
assert_eq!(Aabb2::<f32>::ZERO, Aabb2::point(vec2::ZERO));

pub fn extend_uniform(self, extend: T) -> Aabb2<T>

Extend boundaries of the Aabb2 by a given value in each direction.

§Examples
let aabb = Aabb2::point(vec2(5, 5)).extend_uniform(10);
assert_eq!(aabb, Aabb2::from_corners(vec2(-5, -5), vec2(15, 15)));

pub fn extend_symmetric(self, extend: vec2<T>) -> Aabb2<T>

Extend the boundaries equally right and left and equally up and down

§Examples
let aabb = Aabb2::ZERO.extend_symmetric(vec2(10, 5));
let same = Aabb2::from_corners(vec2(-10, -5), vec2(10, 5));
assert_eq!(aabb, same);

pub fn extend_positive(self, extend: vec2<T>) -> Aabb2<T>

Extend the boundaries to the right and up by the given values

§Examples
let aabb = Aabb2::point(vec2(-10.0, -5.0)).extend_positive(vec2(20.0, 10.0));
let same = Aabb2::ZERO.extend_symmetric(vec2(10.0, 5.0));
assert_eq!(aabb, same);

pub fn extend_left(self, extend: T) -> Aabb2<T>

Extend the left edge of the Aabb2 by a given value.

pub fn extend_right(self, extend: T) -> Aabb2<T>

Extend the right edge of the Aabb2 by a given value.

pub fn extend_up(self, extend: T) -> Aabb2<T>

Extend the top edge of the Aabb2 by a given value.

pub fn extend_down(self, extend: T) -> Aabb2<T>

Extend the bottom edge of the Aabb2 by a given value.

pub fn normalized(self) -> Aabb2<T>

Ensure that the Aabb2 has positive size

§Examples
let original = Aabb2::point(vec2(10.0, 5.0)).extend_positive(vec2(-20.0, -10.0));
let normalized = Aabb2::ZERO.extend_symmetric(vec2(10.0, 5.0));
assert_eq!(original.normalized(), normalized);

pub fn center(&self) -> vec2<T>

Get the center position of the Aabb2.

pub fn map<U, F>(self, f: F) -> Aabb2<U>
where U: UNum, F: Fn(T) -> U,

Map every value (coordinate) of the Aabb2.

pub fn zip<U>(self, other: Aabb2<U>) -> Aabb2<(T, U)>

Zip every value (coordinate) with another Aabb2

pub fn map_bounds<U, F>(self, f: F) -> Aabb2<U>
where U: UNum, F: Fn(vec2<T>) -> vec2<U>,

Map bounds (min & max vectors)

pub fn width(&self) -> T

Returns the width of the Aabb2.

pub fn height(&self) -> T

Returns the height of the Aabb2.

pub fn size(&self) -> vec2<T>

Return the size of the Aabb2.

pub fn contains(&self, point: vec2<T>) -> bool

Check if a point is inside the Aabb2.

§Examples
let rect = Aabb2::from_corners(vec2(1, 2), vec2(3, 4));
assert!(rect.contains(vec2(2, 3)));
assert!(!rect.contains(vec2(5, 5)));

pub fn intersects(&self, other: &Aabb2<T>) -> bool

Checks whether two Aabb2’s intersect.

pub fn translate(self, v: vec2<T>) -> Aabb2<T>

Moves the Aabb2 by a given vector.

pub fn points(self) -> impl Iterator<Item = vec2<T>>
where Range<T>: Iterator<Item = T>,

Returns an iterator over points inside the Aabb2.

pub fn points_bounding_box( points: impl IntoIterator<Item = vec2<T>> ) -> Option<Aabb2<T>>

Returns the smallest possible Aabb2 such that it contains all the points.

§Examples
let aabb = Aabb2::points_bounding_box([
    vec2(3, 0),
    vec2(0, -2),
    vec2(1, 4),
    vec2(-1, -1),
    vec2(0, 3),
]).unwrap();
assert_eq!(aabb, Aabb2 { min: vec2(-1, -2), max: vec2(3, 4) });

Trait Implementations§

§

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

§

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

Returns a copy of the value. Read more
1.0.0 · source§

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

Performs copy-assignment from source. Read more
§

impl<T> Debug for Aabb2<T>
where T: Debug,

§

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

Formats the value using the given formatter. Read more
§

impl<'de, T> Deserialize<'de> for Aabb2<T>
where T: Deserialize<'de>,

§

fn deserialize<__D>( __deserializer: __D ) -> Result<Aabb2<T>, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
§

impl<T> FitTarget2d<T> for Aabb2<T>
where T: Float,

§

fn make_fit(&self, object: &mut impl Transform2d<T>)

Make given object’s bounding Quad fit into self
§

impl<T> PartialEq for Aabb2<T>
where T: PartialEq,

§

fn eq(&self, other: &Aabb2<T>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

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

impl<T> Serialize for Aabb2<T>
where T: Serialize,

§

fn serialize<__S>( &self, __serializer: __S ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
§

impl<T> Copy for Aabb2<T>
where T: Copy,

§

impl<T> Eq for Aabb2<T>
where T: Eq,

§

impl<T> StructuralEq for Aabb2<T>

§

impl<T> StructuralPartialEq for Aabb2<T>

Auto Trait Implementations§

§

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

§

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

§

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

§

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

§

impl<T> UnwindSafe for Aabb2<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
§

impl<T> CompatExt for T

§

fn compat(self) -> Compat<T>

Applies the [Compat] adapter by value. Read more
§

fn compat_ref(&self) -> Compat<&T>

Applies the [Compat] adapter by shared reference. Read more
§

fn compat_mut(&mut self) -> Compat<&mut T>

Applies the [Compat] adapter by mutable reference. Read more
§

impl<T> Diff for T
where T: Debug + Serialize + DeserializeOwned + Sync + Send + Copy + PartialEq + 'static + Unpin,

§

type Delta = T

Object representing the difference between two states of Self
§

fn diff(&self, to: &T) -> T

Calculate the difference between two states
§

fn update(&mut self, new_value: &T)

Update the state using the delta Read more
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
source§

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

source§

fn __clone_box(&self, _: Private) -> *mut ()

§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<S> FromSample<S> for S

§

fn from_sample_(s: S) -> S

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.

§

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

§

fn into_sample(self) -> T

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

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

§

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
§

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

§

fn to_sample_(self) -> U

source§

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

§

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>,

§

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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

source§

impl<T> Message for T
where T: Debug + Serialize + for<'de> Deserialize<'de> + Send + 'static + Unpin,