#[repr(C)]pub struct Bgra<T, A = T> {
pub b: T,
pub g: T,
pub r: T,
pub a: A,
}
Expand description
A Blue + Green + Red + Alpha
pixel.
§Examples
use rgb::Bgra;
let pixel: Bgra<u8> = Bgra { b: 0, g: 0, r: 0, a: 255 };
Fields§
§b: T
Blue Component
g: T
Green Component
r: T
Red Component
a: A
Alpha Component
Implementations§
source§impl<T, A> Bgra<T, A>
impl<T, A> Bgra<T, A>
source§impl<T: Copy, A: Clone> Bgra<T, A>
impl<T: Copy, A: Clone> Bgra<T, A>
sourcepub fn map_rgb<F, U, B>(&self, f: F) -> BGRA<U, B>
👎Deprecated: Renamed to map_colors()
pub fn map_rgb<F, U, B>(&self, f: F) -> BGRA<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<Bgra<T>> for [T]
impl<T> AsPixels<Bgra<T>> for [T]
source§fn as_pixels_mut(&mut self) -> &mut [BGRA<T>]
fn as_pixels_mut(&mut self) -> &mut [BGRA<T>]
Use
::bytemuck::cast_slice_mut()
instead. Read moresource§impl<T: Copy, A: Copy, B> ColorComponentMap<Bgra<B, A>, T, B> for Bgra<T, A>
impl<T: Copy, A: Copy, B> ColorComponentMap<Bgra<B, A>, T, B> for Bgra<T, A>
source§impl<T> ComponentSlice<T> for Bgra<T>
impl<T> ComponentSlice<T> for Bgra<T>
source§impl<R, S> From<(R, R, R, R)> for Bgra<S>where
R: Into<S>,
impl<R, S> From<(R, R, R, R)> for Bgra<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 Bgra<T, A>
impl<T: Ord, A: Ord> Ord for Bgra<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 Bgra<T, A>
impl<T: PartialOrd, A: PartialOrd> PartialOrd for Bgra<T, A>
source§impl<T, A> Zeroable for Bgra<T, A>
impl<T, A> Zeroable for Bgra<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 Bgra<T, A>
impl<T: Eq, A: Eq> Eq for Bgra<T, A>
impl<T, A> Pod for Bgra<T, A>
This is unsound. You can disable as-bytes
feature, enable bytemuck
, and use bytemuck::cast_slice()
instead.
impl<T, A> StructuralPartialEq for Bgra<T, A>
Auto Trait Implementations§
impl<T, A> Freeze for Bgra<T, A>
impl<T, A> RefUnwindSafe for Bgra<T, A>where
T: RefUnwindSafe,
A: RefUnwindSafe,
impl<T, A> Send for Bgra<T, A>
impl<T, A> Sync for Bgra<T, A>
impl<T, A> Unpin for Bgra<T, A>
impl<T, A> UnwindSafe for Bgra<T, A>where
T: UnwindSafe,
A: 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
)