#[repr(C)]pub struct Abgr<T, A = T> {
pub a: A,
pub b: T,
pub g: T,
pub r: T,
}
Expand description
An Alpha + Blue + Green + Red
pixel.
§Examples
use rgb::Abgr;
let pixel: Abgr<u8> = Abgr { a: 255, b: 0, g: 0, r: 0 };
Fields§
§a: A
Alpha Component
b: T
Blue Component
g: T
Green Component
r: T
Red Component
Implementations§
source§impl<T: Copy, A: Clone> Abgr<T, A>
impl<T: Copy, A: Clone> Abgr<T, A>
sourcepub fn map_rgb<F, U, B>(&self, f: F) -> ABGR<U, B>
👎Deprecated: Renamed to map_colors()
pub fn map_rgb<F, U, B>(&self, f: F) -> ABGR<U, B>
Create new RGBA with the same alpha value, but different RGB values
sourcepub fn with_alpha(&self, a: A) -> Self
pub fn with_alpha(&self, a: A) -> Self
Create a new RGBA with the new alpha value, but same RGB values
Trait Implementations§
source§impl<T> AsPixels<Abgr<T>> for [T]
impl<T> AsPixels<Abgr<T>> for [T]
source§fn as_pixels_mut(&mut self) -> &mut [ABGR<T>]
fn as_pixels_mut(&mut self) -> &mut [ABGR<T>]
Use
::bytemuck::cast_slice_mut()
instead. Read moresource§impl<T: Copy, A: Copy, B> ColorComponentMap<Abgr<B, A>, T, B> for Abgr<T, A>
impl<T: Copy, A: Copy, B> ColorComponentMap<Abgr<B, A>, T, B> for Abgr<T, A>
source§impl<T> ComponentSlice<T> for Abgr<T>
impl<T> ComponentSlice<T> for Abgr<T>
source§impl<R, S> From<(R, R, R, R)> for Abgr<S>where
R: Into<S>,
impl<R, S> From<(R, R, R, R)> for Abgr<S>where
R: Into<S>,
source§fn from(value: (R, R, R, R)) -> Self
fn from(value: (R, R, R, R)) -> Self
Converts to this type from the input type.
source§impl<T: Ord, A: Ord> Ord for Abgr<T, A>
impl<T: Ord, A: Ord> Ord for Abgr<T, A>
1.21.0 · source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
source§impl<T: PartialOrd, A: PartialOrd> PartialOrd for Abgr<T, A>
impl<T: PartialOrd, A: PartialOrd> PartialOrd for Abgr<T, A>
source§impl<T, A> Zeroable for Abgr<T, A>
impl<T, A> Zeroable for Abgr<T, A>
This is unsound. You can disable as-bytes
feature, enable bytemuck
, and use bytemuck::cast_slice()
instead.
impl<T: Copy, A: Copy> Copy for Abgr<T, A>
impl<T: Eq, A: Eq> Eq for Abgr<T, A>
impl<T, A> Pod for Abgr<T, A>
This is unsound. You can disable as-bytes
feature, enable bytemuck
, and use bytemuck::cast_slice()
instead.
impl<T, A> StructuralPartialEq for Abgr<T, A>
Auto Trait Implementations§
impl<T, A> Freeze for Abgr<T, A>
impl<T, A> RefUnwindSafe for Abgr<T, A>where
A: RefUnwindSafe,
T: RefUnwindSafe,
impl<T, A> Send for Abgr<T, A>
impl<T, A> Sync for Abgr<T, A>
impl<T, A> Unpin for Abgr<T, A>
impl<T, A> UnwindSafe for Abgr<T, A>where
A: UnwindSafe,
T: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
impl<T> CheckedBitPattern for Twhere
T: AnyBitPattern,
source§type Bits = T
type Bits = T
Self
must have the same layout as the specified Bits
except for
the possible invalid bit patterns being checked during
is_valid_bit_pattern
.source§fn is_valid_bit_pattern(_bits: &T) -> bool
fn is_valid_bit_pattern(_bits: &T) -> bool
If this function returns true, then it must be valid to reinterpret
bits
as &Self
.source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)