Struct Lab

Source
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§

Source§

impl Clone for Lab

Source§

fn clone(&self) -> Lab

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl ColorSpace for Lab

Source§

const TAG: Option<ColorSpaceTag>

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

const WHITE_COMPONENTS: [f32; 3]

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

fn to_linear_srgb([l, a, b]: [f32; 3]) -> [f32; 3]

Convert an opaque color to linear sRGB. Read more
Source§

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

Convert an opaque color from linear sRGB. Read more
Source§

fn scale_chroma([l, a, b]: [f32; 3], scale: f32) -> [f32; 3]

Scale the chroma by the given amount. Read more
Source§

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

Convert to a different color space. Read more
Source§

fn clip([l, a, b]: [f32; 3]) -> [f32; 3]

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

const IS_LINEAR: bool = false

Whether the color space is linear. Read more
Source§

const LAYOUT: ColorSpaceLayout = ColorSpaceLayout::Rectangular

The layout of the color space. Read more
Source§

const WHITE_POINT: Chromaticity = Chromaticity::D65

The white point of the color space. Read more
Source§

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

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

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

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

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

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

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

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

impl Debug for Lab

Source§

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

Formats the value using the given formatter. Read more
Source§

impl From<Lab> for ColorSpaceTag

Source§

fn from(_: Lab) -> Self

Converts to this type from the input type.
Source§

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§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

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

Source§

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

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

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

Source§

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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

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

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

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

Source§

type Error = Infallible

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

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

Performs the conversion.
Source§

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

Source§

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

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

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

Performs the conversion.