#[repr(C)]
pub struct CGSize { pub width: CGFloat, pub height: CGFloat, }
Available on crate feature foundation only.
Expand description

A two-dimensional size.

As this is sometimes used to represent a distance vector, rather than a physical size, the width and height are not guaranteed to be non-negative! Methods that expect that must use one of CGSize::abs or CGRect::standardize.

This technically belongs to the CoreGraphics framework, but we define it here for convenience.

See Apple’s documentation.

Fields

width: CGFloat

The dimensions along the x-axis.

height: CGFloat

The dimensions along the y-axis.

Implementations

Create a new size with the given dimensions.

Examples
use objc2::foundation::CGSize;
let size = CGSize::new(10.0, 2.3);
assert_eq!(size.width, 10.0);
assert_eq!(size.height, 2.3);

Negative values are allowed (though often undesired).

use objc2::foundation::CGSize;
let size = CGSize::new(-1.0, 0.0);
assert_eq!(size.width, -1.0);

Convert the size to a non-negative size.

This can be used to convert the size to a safe value.

Examples
use objc2::foundation::CGSize;
assert_eq!(CGSize::new(-1.0, 1.0).abs(), CGSize::new(1.0, 1.0));

A size that is 0.0 in both dimensions.

Examples
use objc2::foundation::CGSize;
assert_eq!(CGSize::ZERO, CGSize { width: 0.0, height: 0.0 });

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

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

The Objective-C type-encoding for this type.

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

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

The Objective-C type-encoding for a reference of this type. 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

Returns the argument unchanged.

Calls U::from(self).

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

The resulting type after obtaining ownership.

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

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.