Struct palette::Xyz
[−]
[src]
pub struct Xyz<Wp = D65, T = f32> where
T: Float,
Wp: WhitePoint, { pub x: T, pub y: T, pub z: T, pub white_point: PhantomData<Wp>, }
The CIE 1931 XYZ color space.
XYZ links the perceived colors to their wavelengths and simply makes it possible to describe the way we see colors as numbers. It's often used when converting from one color space to an other, and requires a standard illuminant and a standard observer to be defined.
Conversions and operations on this color space depend on the defined white point
Fields
x: T
X is the scale of what can be seen as a response curve for the cone cells in the human eye. Its range depends on the white point and goes from 0.0 to 0.95047 for the default D65.
y: T
Y is the luminance of the color, where 0.0 is black and 1.0 is white.
z: T
Z is the scale of what can be seen as the blue stimulation. Its range depends on the white point and goes from 0.0 to 1.08883 for the defautl D65.
white_point: PhantomData<Wp>
The white point associated with the color's illuminant and observer. D65 for 2 degree observer is used by default.
Methods
impl<T> Xyz<D65, T> where
T: Float,
[src]
T: Float,
impl<Wp, T> Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
Trait Implementations
impl<Wp: Debug, T: Debug> Debug for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp: PartialEq, T: PartialEq> PartialEq for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
fn eq(&self, __arg_0: &Xyz<Wp, T>) -> bool
[src]
This method tests for self
and other
values to be equal, and is used by ==
. Read more
fn ne(&self, __arg_0: &Xyz<Wp, T>) -> bool
[src]
This method tests for !=
.
impl<Wp, T> Copy for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> Clone for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
fn clone(&self) -> Xyz<Wp, T>
[src]
Returns a copy of the value. Read more
fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl<Wp, T> FromColor<Wp, T> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
fn from_xyz(xyz: Xyz<Wp, T>) -> Self
[src]
Convert from XYZ color space
fn from_rgb<S: RgbSpace<WhitePoint = Wp>>(rgb: Rgb<Linear<S>, T>) -> Self
[src]
Convert from RGB color space
fn from_yxy(yxy: Yxy<Wp, T>) -> Self
[src]
Convert from Yxy color space
fn from_lab(lab: Lab<Wp, T>) -> Self
[src]
Convert from L*a*b* color space
fn from_luma(luma: Luma<Wp, T>) -> Self
[src]
Convert from Luma
fn from_lch(inp: Lch<Wp, T>) -> Self
[src]
Convert from L*C*h° color space
fn from_hsl<S: RgbSpace<WhitePoint = Wp>>(inp: Hsl<S, T>) -> Self
[src]
Convert from HSL color space
fn from_hsv<S: RgbSpace<WhitePoint = Wp>>(inp: Hsv<S, T>) -> Self
[src]
Convert from HSV color space
fn from_hwb<S: RgbSpace<WhitePoint = Wp>>(inp: Hwb<S, T>) -> Self
[src]
Convert from HWB color space
impl<Wp, T> Limited for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
fn is_valid(&self) -> bool
[src]
Check if the color's components are within the expected ranges.
fn clamp(&self) -> Xyz<Wp, T>
[src]
Return a new color where the components has been clamped to the nearest valid values. Read more
fn clamp_self(&mut self)
[src]
Clamp the color's components to the nearest valid values.
impl<Wp, T> Mix for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Scalar = T
The type of the mixing factor.
fn mix(&self, other: &Xyz<Wp, T>, factor: T) -> Xyz<Wp, T>
[src]
Mix the color with an other color, by factor
. Read more
impl<Wp, T> Shade for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Scalar = T
The type of the lighten/darken amount.
fn lighten(&self, amount: T) -> Xyz<Wp, T>
[src]
Lighten the color by amount
.
fn darken(&self, amount: Self::Scalar) -> Self
[src]
Darken the color by amount
.
impl<Wp, T> ComponentWise for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Scalar = T
The scalar type for color components.
fn component_wise<F: FnMut(T, T) -> T>(
&self,
other: &Xyz<Wp, T>,
f: F
) -> Xyz<Wp, T>
[src]
&self,
other: &Xyz<Wp, T>,
f: F
) -> Xyz<Wp, T>
Perform a binary operation on this and an other color.
fn component_wise_self<F: FnMut(T) -> T>(&self, f: F) -> Xyz<Wp, T>
[src]
Perform a unary operation on this color.
impl<Wp, T> Default for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> Add<Xyz<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the +
operator.
fn add(self, other: Xyz<Wp, T>) -> Xyz<Wp, T>
[src]
Performs the +
operation.
impl<Wp, T> Add<T> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the +
operator.
fn add(self, c: T) -> Xyz<Wp, T>
[src]
Performs the +
operation.
impl<Wp, T> Sub<Xyz<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the -
operator.
fn sub(self, other: Xyz<Wp, T>) -> Xyz<Wp, T>
[src]
Performs the -
operation.
impl<Wp, T> Sub<T> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the -
operator.
fn sub(self, c: T) -> Xyz<Wp, T>
[src]
Performs the -
operation.
impl<Wp, T> Mul<Xyz<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the *
operator.
fn mul(self, other: Xyz<Wp, T>) -> Xyz<Wp, T>
[src]
Performs the *
operation.
impl<Wp, T> Mul<T> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the *
operator.
fn mul(self, c: T) -> Xyz<Wp, T>
[src]
Performs the *
operation.
impl<Wp, T> Div<Xyz<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the /
operator.
fn div(self, other: Xyz<Wp, T>) -> Xyz<Wp, T>
[src]
Performs the /
operation.
impl<Wp, T> Div<T> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
type Output = Xyz<Wp, T>
The resulting type after applying the /
operator.
fn div(self, c: T) -> Xyz<Wp, T>
[src]
Performs the /
operation.
impl<Wp, T> From<Alpha<Xyz<Wp, T>, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> IntoColor<Wp, T> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
fn into_xyz(self) -> Xyz<Wp, T>
[src]
Convert into XYZ space
fn into_yxy(self) -> Yxy<Wp, T>
[src]
Convert into Yxy color space
fn into_lab(self) -> Lab<Wp, T>
[src]
Convert into L*a*b* color space
fn into_lch(self) -> Lch<Wp, T>
[src]
Convert into L*C*h° color space
fn into_rgb<S: RgbSpace<WhitePoint = Wp>>(self) -> Rgb<Linear<S>, T>
[src]
Convert into RGB color space.
fn into_hsl<S: RgbSpace<WhitePoint = Wp>>(self) -> Hsl<S, T>
[src]
Convert into HSL color space
fn into_hsv<S: RgbSpace<WhitePoint = Wp>>(self) -> Hsv<S, T>
[src]
Convert into HSV color space
fn into_luma(self) -> Luma<Wp, T>
[src]
Convert into Luma
fn into_hwb<S: RgbSpace<WhitePoint = Wp>>(self) -> Hwb<S, T>
[src]
Convert into HWB color space
impl<S, T> From<Color<S, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
fn from(color: Color<S, T>) -> Xyz<S::WhitePoint, T>
[src]
Performs the conversion.
impl<S, T> From<Alpha<Color<S, T>, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
impl<S, T> From<Hsl<S, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
fn from(other: Hsl<S, T>) -> Xyz<S::WhitePoint, T>
[src]
Performs the conversion.
impl<S, T> From<Alpha<Hsl<S, T>, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
impl<S, T> From<Hsv<S, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
fn from(other: Hsv<S, T>) -> Xyz<S::WhitePoint, T>
[src]
Performs the conversion.
impl<S, T> From<Alpha<Hsv<S, T>, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
impl<S, T> From<Hwb<S, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
fn from(other: Hwb<S, T>) -> Xyz<S::WhitePoint, T>
[src]
Performs the conversion.
impl<S, T> From<Alpha<Hwb<S, T>, T>> for Xyz<S::WhitePoint, T> where
T: Float,
S: RgbSpace,
[src]
T: Float,
S: RgbSpace,
impl<Wp, T> From<Yxy<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Alpha<Yxy<Wp, T>, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Lab<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Alpha<Lab<Wp, T>, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Lch<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Alpha<Lch<Wp, T>, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Luma<Wp, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<Wp, T> From<Alpha<Luma<Wp, T>, T>> for Xyz<Wp, T> where
T: Float,
Wp: WhitePoint,
[src]
T: Float,
Wp: WhitePoint,
impl<S, T> From<Rgb<S, T>> for Xyz<<S::Space as RgbSpace>::WhitePoint, T> where
T: Float,
S: RgbStandard,
[src]
T: Float,
S: RgbStandard,
fn from(other: Rgb<S, T>) -> Xyz<<S::Space as RgbSpace>::WhitePoint, T>
[src]
Performs the conversion.
impl<S, T> From<Alpha<Rgb<S, T>, T>> for Xyz<<S::Space as RgbSpace>::WhitePoint, T> where
T: Float,
S: RgbStandard,
[src]
T: Float,
S: RgbStandard,
fn from(
other: Alpha<Rgb<S, T>, T>
) -> Xyz<<S::Space as RgbSpace>::WhitePoint, T>
[src]
other: Alpha<Rgb<S, T>, T>
) -> Xyz<<S::Space as RgbSpace>::WhitePoint, T>
Performs the conversion.
impl<Wp, T> ApproxEq for Xyz<Wp, T> where
T: Float + ApproxEq,
T::Epsilon: Copy + Float,
Wp: WhitePoint,
[src]
T: Float + ApproxEq,
T::Epsilon: Copy + Float,
Wp: WhitePoint,
type Epsilon = <T as ApproxEq>::Epsilon
Used for specifying relative comparisons.
fn default_epsilon() -> Self::Epsilon
[src]
The default tolerance to use when testing values that are close together. Read more
fn default_max_relative() -> Self::Epsilon
[src]
The default relative tolerance for testing values that are far-apart. Read more
fn default_max_ulps() -> u32
[src]
The default ULPs to tolerate when testing values that are far-apart. Read more
fn relative_eq(
&self,
other: &Self,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon
) -> bool
[src]
&self,
other: &Self,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon
) -> bool
A test for equality that uses a relative comparison if the values are far apart.
fn ulps_eq(&self, other: &Self, epsilon: Self::Epsilon, max_ulps: u32) -> bool
[src]
A test for equality that uses units in the last place (ULP) if the values are far apart.
fn relative_ne(
&self,
other: &Self,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon
) -> bool
[src]
&self,
other: &Self,
epsilon: Self::Epsilon,
max_relative: Self::Epsilon
) -> bool
The inverse of ApproxEq::relative_eq
.
fn ulps_ne(&self, other: &Self, epsilon: Self::Epsilon, max_ulps: u32) -> bool
[src]
The inverse of ApproxEq::ulps_eq
.