Lab

Struct Lab 

pub struct Lab;
Expand description

🌌 The CIELAB color space

The CIE L*a*b* color space was created in 1976 to be more perceptually uniform than RGB color spaces, and is both widely used and the basis of other efforts to express colors, including FreieFarbe.

Its components are [L, a, b] with

  • L - the lightness with a natural bound between 0 and 100, where 0 represents pure black and 100 represents the lightness of white;
  • a - how green/red the color is; and
  • b - how blue/yellow the color is.

a and b are unbounded, but are usually between -160 and 160.

The color space has poor hue linearity and hue uniformity compared with Oklab, though superior lightness uniformity. Note that the lightness range differs from Oklab as well; in Oklab white has a lightness of 1.

The CIE L*a*b* color space is defined in terms of a D50 white point. For conversion between color spaces with other illuminants (especially D65 as in sRGB), the standard Bradform linear chromatic adaptation transform is used.

This corresponds to the color space in CSS Color Module Level 4 § 9.1 .

Lab has a cylindrical counterpart: Lch.

Trait Implementations§

§

impl Clone for Lab

§

fn clone(&self) -> Lab

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 ColorSpace for Lab

§

const TAG: Option<ColorSpaceTag>

The tag corresponding to this color space, if a matching tag exists.
§

const WHITE_COMPONENTS: [f32; 3]

The component values for the color white within this color space.
§

fn to_linear_srgb(_: [f32; 3]) -> [f32; 3]

Convert an opaque color to linear sRGB. Read more
§

fn from_linear_srgb(src: [f32; 3]) -> [f32; 3]

Convert an opaque color from linear sRGB. Read more
§

fn scale_chroma(_: [f32; 3], scale: f32) -> [f32; 3]

Scale the chroma by the given amount. Read more
§

fn convert<TargetCS>(src: [f32; 3]) -> [f32; 3]
where TargetCS: ColorSpace,

Convert to a different color space. Read more
§

fn clip(_: [f32; 3]) -> [f32; 3]

Clip the color’s components to fit within the natural gamut of the color space. Read more
§

const IS_LINEAR: bool = false

Whether the color space is linear. Read more
§

const LAYOUT: ColorSpaceLayout = ColorSpaceLayout::Rectangular

The layout of the color space. Read more
§

const WHITE_POINT: Chromaticity = Chromaticity::D65

The white point of the color space. Read more
§

fn to_linear_srgb_absolute(src: [f32; 3]) -> [f32; 3]

Convert an opaque color to linear sRGB, without chromatic adaptation. Read more
§

fn from_linear_srgb_absolute(src: [f32; 3]) -> [f32; 3]

Convert an opaque color from linear sRGB, without chromatic adaptation. Read more
§

fn convert_absolute<TargetCS>(src: [f32; 3]) -> [f32; 3]
where TargetCS: ColorSpace,

Convert to a different color space, without chromatic adaptation. Read more
§

fn chromatically_adapt( src: [f32; 3], from: Chromaticity, to: Chromaticity, ) -> [f32; 3]

Chromatically adapt the color between the given white point chromaticities. Read more
§

impl Debug for Lab

§

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

Formats the value using the given formatter. Read more
§

impl From<Lab> for ColorSpaceTag

§

fn from(_: Lab) -> ColorSpaceTag

Converts to this type from the input type.
§

impl Copy for Lab

Auto Trait Implementations§

§

impl Freeze for Lab

§

impl RefUnwindSafe for Lab

§

impl Send for Lab

§

impl Sync for Lab

§

impl Unpin for Lab

§

impl UnwindSafe for Lab

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,