pub trait Pixel: Copy + Clone {
type Subpixel: Primitive;
const CHANNEL_COUNT: u8;
const COLOR_MODEL: &'static str;
Show 20 methods
// Required methods
fn channels(&self) -> &[Self::Subpixel];
fn channels_mut(&mut self) -> &mut [Self::Subpixel];
fn channels4(
&self,
) -> (Self::Subpixel, Self::Subpixel, Self::Subpixel, Self::Subpixel);
fn from_channels(
a: Self::Subpixel,
b: Self::Subpixel,
c: Self::Subpixel,
d: Self::Subpixel,
) -> Self;
fn from_slice(slice: &[Self::Subpixel]) -> &Self;
fn from_slice_mut(slice: &mut [Self::Subpixel]) -> &mut Self;
fn to_rgb(&self) -> Rgb<Self::Subpixel>;
fn to_rgba(&self) -> Rgba<Self::Subpixel>;
fn to_luma(&self) -> Luma<Self::Subpixel>;
fn to_luma_alpha(&self) -> LumaA<Self::Subpixel>;
fn map<F>(&self, f: F) -> Self
where F: FnMut(Self::Subpixel) -> Self::Subpixel;
fn apply<F>(&mut self, f: F)
where F: FnMut(Self::Subpixel) -> Self::Subpixel;
fn map_with_alpha<F, G>(&self, f: F, g: G) -> Self
where F: FnMut(Self::Subpixel) -> Self::Subpixel,
G: FnMut(Self::Subpixel) -> Self::Subpixel;
fn apply_with_alpha<F, G>(&mut self, f: F, g: G)
where F: FnMut(Self::Subpixel) -> Self::Subpixel,
G: FnMut(Self::Subpixel) -> Self::Subpixel;
fn map2<F>(&self, other: &Self, f: F) -> Self
where F: FnMut(Self::Subpixel, Self::Subpixel) -> Self::Subpixel;
fn apply2<F>(&mut self, other: &Self, f: F)
where F: FnMut(Self::Subpixel, Self::Subpixel) -> Self::Subpixel;
fn invert(&mut self);
fn blend(&mut self, other: &Self);
// Provided methods
fn map_without_alpha<F>(&self, f: F) -> Self
where F: FnMut(Self::Subpixel) -> Self::Subpixel { ... }
fn apply_without_alpha<F>(&mut self, f: F)
where F: FnMut(Self::Subpixel) -> Self::Subpixel { ... }
}
Expand description
A generalized pixel.
A pixel object is usually not used standalone but as a view into an image buffer.
Required Associated Constants§
Sourceconst CHANNEL_COUNT: u8
const CHANNEL_COUNT: u8
The number of channels of this pixel type.
Sourceconst COLOR_MODEL: &'static str
const COLOR_MODEL: &'static str
A string that can help to interpret the meaning each channel See gimp babl.
Required Associated Types§
Required Methods§
Sourcefn channels_mut(&mut self) -> &mut [Self::Subpixel]
fn channels_mut(&mut self) -> &mut [Self::Subpixel]
Returns the components as a mutable slice
Sourcefn channels4(
&self,
) -> (Self::Subpixel, Self::Subpixel, Self::Subpixel, Self::Subpixel)
👎Deprecated since 0.24.0: Use channels()
or channels_mut()
fn channels4( &self, ) -> (Self::Subpixel, Self::Subpixel, Self::Subpixel, Self::Subpixel)
channels()
or channels_mut()
Returns the channels of this pixel as a 4 tuple. If the pixel has less than 4 channels the remainder is filled with the maximum value
Sourcefn from_channels(
a: Self::Subpixel,
b: Self::Subpixel,
c: Self::Subpixel,
d: Self::Subpixel,
) -> Self
👎Deprecated since 0.24.0: Use the constructor of the pixel, for example Rgba([r,g,b,a])
or Pixel::from_slice
fn from_channels( a: Self::Subpixel, b: Self::Subpixel, c: Self::Subpixel, d: Self::Subpixel, ) -> Self
Rgba([r,g,b,a])
or Pixel::from_slice
Construct a pixel from the 4 channels a, b, c and d. If the pixel does not contain 4 channels the extra are ignored.
Sourcefn from_slice(slice: &[Self::Subpixel]) -> &Self
fn from_slice(slice: &[Self::Subpixel]) -> &Self
Returns a view into a slice.
Note: The slice length is not checked on creation. Thus the caller has to ensure that the slice is long enough to prevent panics if the pixel is used later on.
Sourcefn from_slice_mut(slice: &mut [Self::Subpixel]) -> &mut Self
fn from_slice_mut(slice: &mut [Self::Subpixel]) -> &mut Self
Returns mutable view into a mutable slice.
Note: The slice length is not checked on creation. Thus the caller has to ensure that the slice is long enough to prevent panics if the pixel is used later on.
Sourcefn to_luma_alpha(&self) -> LumaA<Self::Subpixel>
fn to_luma_alpha(&self) -> LumaA<Self::Subpixel>
Convert this pixel to luma with an alpha channel
Sourcefn map_with_alpha<F, G>(&self, f: F, g: G) -> Self
fn map_with_alpha<F, G>(&self, f: F, g: G) -> Self
Apply the function f
to each channel except the alpha channel.
Apply the function g
to the alpha channel.
Sourcefn apply_with_alpha<F, G>(&mut self, f: F, g: G)
fn apply_with_alpha<F, G>(&mut self, f: F, g: G)
Apply the function f
to each channel except the alpha channel.
Apply the function g
to the alpha channel. Works in-place.
Sourcefn map2<F>(&self, other: &Self, f: F) -> Self
fn map2<F>(&self, other: &Self, f: F) -> Self
Apply the function f
to each channel of this pixel and
other
pairwise.
Provided Methods§
Sourcefn map_without_alpha<F>(&self, f: F) -> Self
fn map_without_alpha<F>(&self, f: F) -> Self
Apply the function f
to each channel except the alpha channel.
Sourcefn apply_without_alpha<F>(&mut self, f: F)
fn apply_without_alpha<F>(&mut self, f: F)
Apply the function f
to each channel except the alpha channel.
Works in place.
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.