Skip to main content

Rect

Struct Rect 

Source
pub struct Rect {
    pub x: u16,
    pub y: u16,
    pub width: u16,
    pub height: u16,
}
Expand description

A rectangle for scissor regions, layout bounds, and hit testing.

Uses terminal coordinates (0-indexed, origin at top-left).

Fields§

§x: u16

Left edge (inclusive).

§y: u16

Top edge (inclusive).

§width: u16

Width in cells.

§height: u16

Height in cells.

Implementations§

Source§

impl Rect

Source

pub const fn new(x: u16, y: u16, width: u16, height: u16) -> Self

Create a new rectangle.

Source

pub const fn from_size(width: u16, height: u16) -> Self

Create a rectangle from origin with given size.

Source

pub const fn left(&self) -> u16

Left edge (inclusive). Alias for self.x.

Source

pub const fn top(&self) -> u16

Top edge (inclusive). Alias for self.y.

Source

pub const fn right(&self) -> u16

Right edge (exclusive).

Source

pub const fn bottom(&self) -> u16

Bottom edge (exclusive).

Source

pub const fn area(&self) -> u32

Area in cells.

Source

pub const fn is_empty(&self) -> bool

Check if the rectangle has zero area.

Source

pub const fn contains(&self, x: u16, y: u16) -> bool

Check if a point is inside the rectangle.

Source

pub fn intersection(&self, other: &Rect) -> Rect

Compute the intersection with another rectangle.

Returns an empty rectangle if the rectangles don’t overlap.

Source

pub fn inner(&self, margin: Sides) -> Rect

Create a new rectangle inside the current one with the given margin.

Source

pub fn union(&self, other: &Rect) -> Rect

Create a new rectangle that is the union of this rectangle and another.

The result is the smallest rectangle that contains both.

Source

pub fn intersection_opt(&self, other: &Rect) -> Option<Rect>

Compute the intersection with another rectangle, returning None if no overlap.

Trait Implementations§

Source§

impl Clone for Rect

Source§

fn clone(&self) -> Rect

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 Rect

Source§

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

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

impl Default for Rect

Source§

fn default() -> Rect

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

impl From<Rect> for Size

Source§

fn from(rect: Rect) -> Self

Converts to this type from the input type.
Source§

impl PartialEq for Rect

Source§

fn eq(&self, other: &Rect) -> 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 Copy for Rect

Source§

impl Eq for Rect

Source§

impl StructuralPartialEq for Rect

Auto Trait Implementations§

§

impl Freeze for Rect

§

impl RefUnwindSafe for Rect

§

impl Send for Rect

§

impl Sync for Rect

§

impl Unpin for Rect

§

impl UnsafeUnpin for Rect

§

impl UnwindSafe for Rect

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.