Struct palette::Lab [] [src]

pub struct Lab<Wp = D65, T = f32> where
    T: Float,
    Wp: WhitePoint
{ pub l: T, pub a: T, pub b: T, pub white_point: PhantomData<Wp>, }

The CIE L*a*b* (CIELAB) color space.

CIE L*a*b* is a device independent color space which includes all perceivable colors. It's sometimes used to convert between other color spaces, because of its ability to represent all of their colors, and sometimes in color manipulation, because of its perceptual uniformity. This means that the perceptual difference between two colors is equal to their numerical difference.

The parameters of L*a*b* are quite different, compared to many other color spaces, so manipulating them manually may be unintuitive.

Fields

L* is the lightness of the color. 0.0 gives absolute black and 100 give the brightest white.

a* goes from red at -128 to green at 127.

b* goes from yellow at -128 to blue at 127.

The white point associated with the color's illuminant and observer. D65 for 2 degree observer is used by default.

Methods

impl<T> Lab<D65, T> where
    T: Float
[src]

[src]

CIE L*a*b* with white point D65.

impl<Wp, T> Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

CIE L*a*b*.

Trait Implementations

impl<Wp: Debug, T: Debug> Debug for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Formats the value using the given formatter.

impl<Wp: PartialEq, T: PartialEq> PartialEq for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

This method tests for self and other values to be equal, and is used by ==. Read more

[src]

This method tests for !=.

impl<Wp, T> Copy for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

impl<Wp, T> Clone for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Returns a copy of the value. Read more

1.0.0
[src]

Performs copy-assignment from source. Read more

impl<Wp, T> FromColor<Wp, T> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Convert from XYZ color space

[src]

Convert from L*a*b* color space

[src]

Convert from L*C*h° color space

[src]

Convert from Yxy color space

[src]

Convert from RGB color space

[src]

Convert from HSL color space

[src]

Convert from HSV color space

[src]

Convert from HWB color space

[src]

Convert from Luma

impl<Wp, T> Limited for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Check if the color's components are within the expected ranges.

[src]

Return a new color where the components has been clamped to the nearest valid values. Read more

[src]

Clamp the color's components to the nearest valid values.

impl<Wp, T> Mix for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The type of the mixing factor.

[src]

Mix the color with an other color, by factor. Read more

impl<Wp, T> Shade for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The type of the lighten/darken amount.

[src]

Lighten the color by amount.

[src]

Darken the color by amount.

impl<Wp, T> GetHue for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The kind of hue unit this color space uses. Read more

[src]

Calculate a hue if possible. Read more

impl<Wp, T> ComponentWise for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The scalar type for color components.

[src]

Perform a binary operation on this and an other color.

[src]

Perform a unary operation on this color.

impl<Wp, T> Default for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Returns the "default value" for a type. Read more

impl<Wp, T> Add<Lab<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the + operator.

[src]

Performs the + operation.

impl<Wp, T> Add<T> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the + operator.

[src]

Performs the + operation.

impl<Wp, T> Sub<Lab<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the - operator.

[src]

Performs the - operation.

impl<Wp, T> Sub<T> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the - operator.

[src]

Performs the - operation.

impl<Wp, T> Mul<Lab<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the * operator.

[src]

Performs the * operation.

impl<Wp, T> Mul<T> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the * operator.

[src]

Performs the * operation.

impl<Wp, T> Div<Lab<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the / operator.

[src]

Performs the / operation.

impl<Wp, T> Div<T> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

The resulting type after applying the / operator.

[src]

Performs the / operation.

impl<Wp, T> From<Alpha<Lab<Wp, T>, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> IntoColor<Wp, T> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Convert into XYZ space

[src]

Convert into Yxy color space

[src]

Convert into L*a*b* color space

[src]

Convert into L*C*h° color space

[src]

Convert into RGB color space.

[src]

Convert into HSL color space

[src]

Convert into HSV color space

[src]

Convert into Luma

[src]

Convert into HWB color space

impl<S, T> From<Color<S, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Alpha<Color<S, T>, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Hsl<S, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Alpha<Hsl<S, T>, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Hsv<S, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Alpha<Hsv<S, T>, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Hwb<S, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<S, T> From<Alpha<Hwb<S, T>, T>> for Lab<S::WhitePoint, T> where
    T: Float,
    S: RgbSpace
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Xyz<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Alpha<Xyz<Wp, T>, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Yxy<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Alpha<Yxy<Wp, T>, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Lch<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Alpha<Lch<Wp, T>, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Luma<Wp, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<Wp, T> From<Alpha<Luma<Wp, T>, T>> for Lab<Wp, T> where
    T: Float,
    Wp: WhitePoint
[src]

[src]

Performs the conversion.

impl<S, T> From<Rgb<S, T>> for Lab<<S::Space as RgbSpace>::WhitePoint, T> where
    T: Float,
    S: RgbStandard
[src]

[src]

Performs the conversion.

impl<S, T> From<Alpha<Rgb<S, T>, T>> for Lab<<S::Space as RgbSpace>::WhitePoint, T> where
    T: Float,
    S: RgbStandard
[src]

[src]

Performs the conversion.

impl<Wp, T> ApproxEq for Lab<Wp, T> where
    T: Float + ApproxEq,
    T::Epsilon: Copy + Float,
    Wp: WhitePoint
[src]

Used for specifying relative comparisons.

[src]

The default tolerance to use when testing values that are close together. Read more

[src]

The default relative tolerance for testing values that are far-apart. Read more

[src]

The default ULPs to tolerate when testing values that are far-apart. Read more

[src]

A test for equality that uses a relative comparison if the values are far apart.

[src]

A test for equality that uses units in the last place (ULP) if the values are far apart.

[src]

The inverse of ApproxEq::relative_eq.

[src]

The inverse of ApproxEq::ulps_eq.