OpaqueColor

Struct OpaqueColor 

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

An opaque color.

A color in a color space known at compile time, without transparency. Note that “opaque” refers to the color, not the representation; the components are publicly accessible.

Arithmetic traits are defined on this type, and operate component-wise. A major motivation for including these is to enable weighted sums, including for spline interpolation. For cylindrical color spaces, hue fixup should be applied before interpolation.

Fields§

§components: [f32; 3]

The components, which may be manipulated directly.

The interpretation of the components depends on the color space.

§cs: PhantomData<CS>

The color space.

Implementations§

§

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

pub const BLACK: OpaqueColor<CS>

A black color.

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

pub const WHITE: OpaqueColor<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; 3]) -> OpaqueColor<CS>

Create a new color from the given components.

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

Convert a color into a different color space.

pub const fn with_alpha(self, alpha: f32) -> AlphaColor<CS>

Add an alpha channel.

This function is the inverse of AlphaColor::split.

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

Difference between two colors by Euclidean metric.

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

Linearly interpolate colors, without hue fixup.

This method produces meaningful results in rectangular color spaces, or if hue fixup has been applied.

pub fn fixup_hues(self, other: &mut OpaqueColor<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: OpaqueColor<CS>, t: f32, direction: HueDirection, ) -> OpaqueColor<CS>

Linearly interpolate colors, with hue fixup if needed.

pub fn scale_chroma(self, scale: f32) -> OpaqueColor<CS>

Scale the chroma by the given amount.

See ColorSpace::scale_chroma for more details.

pub fn relative_luminance(self) -> f32

Compute the relative luminance of the color.

This can be useful for choosing contrasting colors, and follows the WCAG 2.1 spec.

pub fn map(self, f: impl Fn(f32, f32, f32) -> [f32; 3]) -> OpaqueColor<CS>

Map components.

pub fn map_in<TargetCS>( self, f: impl Fn(f32, f32, f32) -> [f32; 3], ) -> OpaqueColor<CS>
where TargetCS: ColorSpace,

Map components in a given color space.

pub fn map_lightness(self, f: impl Fn(f32) -> f32) -> OpaqueColor<CS>

Map the lightness of the color.

In a color space that naturally has a lightness component, map that value. Otherwise, do the mapping in Oklab. The lightness range is normalized so that 1.0 is white. That is the normal range for Oklab but differs from the range in Lab, Lch, and Hsl.

§Examples
use color::{Lab, OpaqueColor};

let color = OpaqueColor::<Lab>::new([40., 4., -17.]);
let lighter = color.map_lightness(|l| l + 0.2);
let expected = OpaqueColor::<Lab>::new([60., 4., -17.]);

assert!(lighter.difference(expected) < 1e-4);

pub fn map_hue(self, f: impl Fn(f32) -> f32) -> OpaqueColor<CS>

Map the hue of the color.

In a color space that naturally has a hue component, map that value. Otherwise, do the mapping in Oklch. The hue is in degrees.

§Examples
use color::{Oklab, OpaqueColor};

let color = OpaqueColor::<Oklab>::new([0.5, 0.2, -0.1]);
let complementary = color.map_hue(|h| (h + 180.) % 360.);
let expected = OpaqueColor::<Oklab>::new([0.5, -0.2, 0.1]);

assert!(complementary.difference(expected) < 1e-4);

pub fn to_rgba8(self) -> Rgba8

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

The RGB 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. The alpha component is set to 255.

§Implementation note

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

§

impl OpaqueColor<Srgb>

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

Create a color from 8-bit rgb values.

Trait Implementations§

§

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

Component-wise addition of components.

§

type Output = OpaqueColor<CS>

The resulting type after applying the + operator.
§

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

Performs the + operation. Read more
§

impl<CS> BitEq for OpaqueColor<CS>

§

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

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

impl<CS> BitHash for OpaqueColor<CS>

§

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

Feeds this value into the given Hasher.
§

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

§

fn clone(&self) -> OpaqueColor<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 OpaqueColor<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 OpaqueColor<CS>
where CS: ColorSpace,

Divide components by a scalar.

§

type Output = OpaqueColor<CS>

The resulting type after applying the / operator.
§

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

Performs the / operation. Read more
§

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

§

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

Converts to this type from the input type.
§

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<CS> FromStr for OpaqueColor<CS>
where CS: ColorSpace,

§

type Err = ParseError

The associated error which can be returned from parsing.
§

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

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

impl<CS: ColorSpace> Interpolatable for OpaqueColor<CS>

Source§

fn lerp(&self, target: &Self, t: f64) -> Self

Lerping between values
§

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

Multiply components by a scalar.

§

type Output = OpaqueColor<CS>

The resulting type after applying the * operator.
§

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

Performs the * operation. Read more
§

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

§

fn eq(&self, other: &OpaqueColor<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 OpaqueColor<CS>
where CS: ColorSpace,

Component-wise subtraction of components.

§

type Output = OpaqueColor<CS>

The resulting type after applying the - operator.
§

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

Performs the - operation. Read more
§

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

Auto Trait Implementations§

§

impl<CS> Freeze for OpaqueColor<CS>

§

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

§

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

§

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

§

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

§

impl<CS> UnwindSafe for OpaqueColor<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,