PremulColor

Struct PremulColor 

#[repr(transparent)]
pub struct PremulColor<CS> { pub components: [f32; 4], pub cs: PhantomData<CS>, }
Expand description

A color with premultiplied alpha.

A color in a color space known at compile time, with color channels premultiplied by the alpha channel.

Following the convention of CSS Color 4, in cylindrical color spaces the hue channel is not premultiplied. If it were, interpolation would give undesirable results.

See AlphaColor for a color type without alpha premultiplication.

See OpaqueColor for a discussion of arithmetic traits and interpolation.

Fields§

§components: [f32; 4]

The components, which may be manipulated directly.

The interpretation of the first three components depends on the color space, and are premultiplied with the alpha value. The fourth component is alpha.

Note that in cylindrical color spaces, the hue component is not premultiplied, as specified in the CSS Color 4 spec. The methods on this type take care of that for you, but if you’re manipulating the components yourself, be aware.

§cs: PhantomData<CS>

The color space.

Implementations§

§

impl<CS> PremulColor<CS>
where CS: ColorSpace,

pub const BLACK: PremulColor<CS>

A black color.

More comprehensive pre-defined colors are available in the color::palette module.

pub const TRANSPARENT: PremulColor<CS>

A transparent color.

This is a black color with full alpha.

More comprehensive pre-defined colors are available in the color::palette module.

pub const WHITE: PremulColor<CS>

A white color.

This value is specific to the color space.

More comprehensive pre-defined colors are available in the color::palette module.

pub const fn new(components: [f32; 4]) -> PremulColor<CS>

Create a new color from the given components.

pub const fn discard_alpha(self) -> OpaqueColor<CS>

Split out the opaque components, discarding the alpha.

This is a shorthand for un-premultiplying the alpha and calling AlphaColor::discard_alpha.

The result of calling this on a fully transparent color will be the color black.

pub fn convert<TargetCS>(self) -> PremulColor<TargetCS>
where TargetCS: ColorSpace,

Convert a color into a different color space.

pub const fn un_premultiply(self) -> AlphaColor<CS>

Convert a color to the corresponding separate alpha form.

pub fn lerp_rect(self, other: PremulColor<CS>, t: f32) -> PremulColor<CS>

Interpolate colors.

Note: this function doesn’t fix up hue in cylindrical spaces. It is still useful if the hue angles are compatible, particularly if the fixup has been applied.

pub fn fixup_hues(self, other: &mut PremulColor<CS>, direction: HueDirection)

Apply hue fixup for interpolation.

Adjust the hue angle of other so that linear interpolation results in the expected hue direction.

pub fn lerp( self, other: PremulColor<CS>, t: f32, direction: HueDirection, ) -> PremulColor<CS>

Linearly interpolate colors, with hue fixup if needed.

pub const fn multiply_alpha(self, rhs: f32) -> PremulColor<CS>

Multiply alpha by the given factor.

pub fn difference(self, other: PremulColor<CS>) -> f32

Difference between two colors by Euclidean metric.

pub fn to_rgba8(self) -> PremulRgba8

Convert the color to sRGB if not already in sRGB, and pack into 8 bit per component integer encoding.

The RGBA components are mapped from the floating point range of 0.0-1.0 to the integer range of 0-255. Component values outside of this range are saturated to 0 or 255.

§Implementation note

This performs almost-correct rounding, see the note on AlphaColor::to_rgba8.

§

impl PremulColor<Srgb>

pub const fn from_rgba8(r: u8, g: u8, b: u8, a: u8) -> PremulColor<Srgb>

Create a color from pre-multiplied 8-bit rgba values.

Note: for conversion from the PremulRgba8 type, just use the From trait.

pub const fn from_rgb8(r: u8, g: u8, b: u8) -> PremulColor<Srgb>

Create a color from 8-bit rgb values with an opaque alpha.

Note: for conversion from the Rgba8 type, just use the From trait.

Trait Implementations§

§

impl<CS> Add for PremulColor<CS>
where CS: ColorSpace,

Component-wise addition of components.

§

type Output = PremulColor<CS>

The resulting type after applying the + operator.
§

fn add(self, rhs: PremulColor<CS>) -> PremulColor<CS>

Performs the + operation. Read more
§

impl<CS> BitEq for PremulColor<CS>

§

fn bit_eq(&self, other: &PremulColor<CS>) -> bool

Returns true if self is equal to other. Read more
§

impl<CS> BitHash for PremulColor<CS>

§

fn bit_hash<H>(&self, state: &mut H)
where H: Hasher,

Feeds this value into the given Hasher.
§

impl<CS> Clone for PremulColor<CS>
where CS: Clone,

§

fn clone(&self) -> PremulColor<CS>

Returns a duplicate of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
§

impl<CS> Debug for PremulColor<CS>
where CS: Debug,

§

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

Formats the value using the given formatter. Read more
§

impl<CS> Div<f32> for PremulColor<CS>
where CS: ColorSpace,

Divide components by a scalar.

§

type Output = PremulColor<CS>

The resulting type after applying the / operator.
§

fn div(self, rhs: f32) -> PremulColor<CS>

Performs the / operation. Read more
§

impl<CS> From<OpaqueColor<CS>> for PremulColor<CS>
where CS: ColorSpace,

§

fn from(value: OpaqueColor<CS>) -> PremulColor<CS>

Converts to this type from the input type.
§

impl From<PremulRgba8> for PremulColor<Srgb>

§

fn from(value: PremulRgba8) -> PremulColor<Srgb>

Converts to this type from the input type.
§

impl<CS> FromStr for PremulColor<CS>
where CS: ColorSpace,

§

type Err = ParseError

The associated error which can be returned from parsing.
§

fn from_str( s: &str, ) -> Result<PremulColor<CS>, <PremulColor<CS> as FromStr>::Err>

Parses a string s to return a value of this type. Read more
§

impl<CS> Mul<f32> for PremulColor<CS>
where CS: ColorSpace,

Multiply components by a scalar.

For rectangular color spaces, this is equivalent to multiplying alpha, but for cylindrical color spaces, PremulColor::multiply_alpha is the preferred method.

§

type Output = PremulColor<CS>

The resulting type after applying the * operator.
§

fn mul(self, rhs: f32) -> PremulColor<CS>

Performs the * operation. Read more
§

impl<CS> PartialEq for PremulColor<CS>
where CS: ColorSpace,

§

fn eq(&self, other: &PremulColor<CS>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
§

impl<CS> Sub for PremulColor<CS>
where CS: ColorSpace,

Component-wise subtraction of components.

§

type Output = PremulColor<CS>

The resulting type after applying the - operator.
§

fn sub(self, rhs: PremulColor<CS>) -> PremulColor<CS>

Performs the - operation. Read more
§

impl<CS> Copy for PremulColor<CS>
where CS: Copy,

Auto Trait Implementations§

§

impl<CS> Freeze for PremulColor<CS>

§

impl<CS> RefUnwindSafe for PremulColor<CS>
where CS: RefUnwindSafe,

§

impl<CS> Send for PremulColor<CS>
where CS: Send,

§

impl<CS> Sync for PremulColor<CS>
where CS: Sync,

§

impl<CS> Unpin for PremulColor<CS>
where CS: Unpin,

§

impl<CS> UnwindSafe for PremulColor<CS>
where CS: UnwindSafe,

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

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> Discard for T

Source§

fn discard(&self)

Simply returns ()
Source§

impl<T> DynClone for T
where T: Clone,

§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
§

impl<T, U> Into<U> for T
where U: From<T>,

§

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> StaticAnim for T
where T: StaticAnimRequirement + 'static,

Source§

fn show(&self) -> AnimationCell<T>

Show the item
Source§

fn hide(&self) -> AnimationCell<T>

Hide the item
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

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

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> With for T

Source§

fn with(self, f: impl Fn(&mut Self)) -> Self
where Self: Sized,

Mutating a value in place
§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
Source§

impl<T> StaticAnimRequirement for T
where T: Clone,