pub enum CssColor {
    CurrentColor,
    RGBA(RGBA),
    LAB(Box<LABColor>),
    Predefined(Box<PredefinedColor>),
    Float(Box<FloatColor>),
}
Expand description

A CSS <color> value.

CSS supports many different color spaces to represent colors. The most common values are stored as RGBA using a single byte per component. Less common values are stored using a Box to reduce the amount of memory used per color.

Each color space is represented as a struct that implements the From and Into traits for all other color spaces, so it is possible to convert between color spaces easily. In addition, colors support interpolation as in the color-mix() function.

Variants§

§

CurrentColor

The currentColor keyword.

§

RGBA(RGBA)

An value in the RGB color space, including values parsed as hex colors, or the rgb(), hsl(), and hwb() functions.

§

LAB(Box<LABColor>)

A value in a LAB color space, including the lab(), lch(), oklab(), and oklch() functions.

§

Predefined(Box<PredefinedColor>)

A value in a predefined color space, e.g. display-p3.

§

Float(Box<FloatColor>)

A floating point representation of an RGB, HSL, or HWB color when it contains none components.

Implementations§

source§

impl CssColor

source

pub fn current_color() -> CssColor

Returns the currentColor keyword.

source

pub fn transparent() -> CssColor

Returns the transparent keyword.

source

pub fn to_rgb(&self) -> Result<CssColor, ()>

Converts the color to RGBA.

source

pub fn to_lab(&self) -> Result<CssColor, ()>

Converts the color to the LAB color space.

source

pub fn to_p3(&self) -> Result<CssColor, ()>

Converts the color to the P3 color space.

source

pub fn get_necessary_fallbacks(&self, targets: Targets) -> ColorFallbackKind

Returns the color fallback types needed for the given browser targets.

source

pub fn get_fallback(&self, kind: ColorFallbackKind) -> CssColor

Returns a fallback color for the given fallback type.

source§

impl CssColor

source

pub fn interpolate<'a, T>( &'a self, p1: f32, other: &'a CssColor, p2: f32, method: HueInterpolationMethod ) -> Result<CssColor, ()>where T: 'static + TryFrom<&'a CssColor> + Interpolate + Into<CssColor> + Into<OKLCH> + ColorGamut + Into<OKLAB> + From<OKLCH> + Copy,

Mixes this color with another color, including the specified amount of each. Implemented according to the color-mix() function.

Trait Implementations§

source§

impl Clone for CssColor

source§

fn clone(&self) -> CssColor

Returns a copy 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 Debug for CssColor

source§

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

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

impl Default for CssColor

source§

fn default() -> CssColor

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for CssColor

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl From<A98> for CssColor

source§

fn from(color: A98) -> CssColor

Converts to this type from the input type.
source§

impl From<HSL> for CssColor

source§

fn from(color: HSL) -> CssColor

Converts to this type from the input type.
source§

impl From<HWB> for CssColor

source§

fn from(color: HWB) -> CssColor

Converts to this type from the input type.
source§

impl From<LAB> for CssColor

source§

fn from(color: LAB) -> CssColor

Converts to this type from the input type.
source§

impl From<LCH> for CssColor

source§

fn from(color: LCH) -> CssColor

Converts to this type from the input type.
source§

impl From<OKLAB> for CssColor

source§

fn from(color: OKLAB) -> CssColor

Converts to this type from the input type.
source§

impl From<OKLCH> for CssColor

source§

fn from(color: OKLCH) -> CssColor

Converts to this type from the input type.
source§

impl From<P3> for CssColor

source§

fn from(color: P3) -> CssColor

Converts to this type from the input type.
source§

impl From<ProPhoto> for CssColor

source§

fn from(color: ProPhoto) -> CssColor

Converts to this type from the input type.
source§

impl From<RGBA> for CssColor

source§

fn from(color: RGBA) -> CssColor

Converts to this type from the input type.
source§

impl From<Rec2020> for CssColor

source§

fn from(color: Rec2020) -> CssColor

Converts to this type from the input type.
source§

impl From<SRGB> for CssColor

source§

fn from(color: SRGB) -> CssColor

Converts to this type from the input type.
source§

impl From<SRGBLinear> for CssColor

source§

fn from(color: SRGBLinear) -> CssColor

Converts to this type from the input type.
source§

impl From<XYZd50> for CssColor

source§

fn from(color: XYZd50) -> CssColor

Converts to this type from the input type.
source§

impl From<XYZd65> for CssColor

source§

fn from(color: XYZd65) -> CssColor

Converts to this type from the input type.
source§

impl IsCompatible for CssColor

source§

fn is_compatible(&self, browsers: Browsers) -> bool

Returns whether the value is compatible with all of the given browser targets.
source§

impl JsonSchema for CssColor

source§

fn schema_name() -> String

The name of the generated JSON Schema. Read more
source§

fn schema_id() -> Cow<'static, str>

Returns a string that uniquely identifies the schema produced by this type. Read more
source§

fn json_schema(gen: &mut SchemaGenerator) -> Schema

Generates a JSON Schema for this type. Read more
source§

fn is_referenceable() -> bool

Whether JSON Schemas generated for this type should be re-used where possible using the $ref keyword. Read more
source§

impl<'i> Parse<'i> for CssColor

source§

fn parse<'t>( input: &mut Parser<'i, 't> ) -> Result<Self, ParseError<'i, ParserError<'i>>>

Parse a value of this type using an existing parser.
source§

fn parse_string(input: &'i str) -> Result<Self, ParseError<'i, ParserError<'i>>>

Parse a value from a string. Read more
source§

impl PartialEq<CssColor> for CssColor

source§

fn eq(&self, other: &CssColor) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Serialize for CssColor

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
source§

impl ToCss for CssColor

source§

fn to_css<W>( &self, dest: &mut Printer<'_, '_, '_, W> ) -> Result<(), PrinterError>where W: Write,

Serialize self in CSS syntax, writing to dest.
source§

fn to_css_string( &self, options: PrinterOptions<'_> ) -> Result<String, PrinterError>

Serialize self in CSS syntax and return a string. Read more
source§

impl TryFrom<&CssColor> for A98

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<A98, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for HSL

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<HSL, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for HWB

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<HWB, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for LAB

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<LAB, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for LCH

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<LCH, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for OKLAB

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<OKLAB, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for OKLCH

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<OKLCH, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for P3

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<P3, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for ProPhoto

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<ProPhoto, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for RGBA

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<RGBA, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for Rec2020

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<Rec2020, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for SRGB

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<SRGB, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for SRGBLinear

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<SRGBLinear, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for XYZd50

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<XYZd50, ()>

Performs the conversion.
source§

impl TryFrom<&CssColor> for XYZd65

§

type Error = ()

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

fn try_from(color: &CssColor) -> Result<XYZd65, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for A98

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<A98, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for HSL

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<HSL, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for HWB

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<HWB, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for LAB

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<LAB, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for LCH

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<LCH, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for OKLAB

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<OKLAB, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for OKLCH

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<OKLCH, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for P3

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<P3, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for ProPhoto

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<ProPhoto, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for RGBA

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<RGBA, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for Rec2020

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<Rec2020, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for SRGB

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<SRGB, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for SRGBLinear

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<SRGBLinear, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for XYZd50

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<XYZd50, ()>

Performs the conversion.
source§

impl TryFrom<CssColor> for XYZd65

§

type Error = ()

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

fn try_from(color: CssColor) -> Result<XYZd65, ()>

Performs the conversion.
source§

impl<'i, __T: Visit<'i, __T, __V>, __V: ?Sized + Visitor<'i, __T>> Visit<'i, __T, __V> for CssColor

source§

const CHILD_TYPES: VisitTypes = _

Available on crate feature visitor only.
The types of values contained within this value and its children. This is used to skip branches that don’t have any values requested by the Visitor.
source§

fn visit(&mut self, visitor: &mut __V) -> Result<(), __V::Error>

Available on crate feature visitor only.
Visits the value by calling an appropriate method on the Visitor. If no corresponding visitor method exists, then the children are visited.
source§

fn visit_children(&mut self, visitor: &mut __V) -> Result<(), __V::Error>

Available on crate feature visitor only.
Visit the children of this value.
source§

impl StructuralPartialEq for CssColor

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

source§

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

Mutably borrows from an owned value. Read more
§

impl<F, W, T, D> Deserialize<With<T, W>, D> for Fwhere W: DeserializeWith<F, T, D>, D: Fallible + ?Sized, F: ?Sized,

§

fn deserialize( &self, deserializer: &mut D ) -> Result<With<T, W>, <D as Fallible>::Error>

Deserializes using the given deserializer
source§

impl<T> DynClone for Twhere T: Clone,

source§

fn __clone_box(&self, _: Private) -> *mut ()

source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere 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<'i, T> ParseWithOptions<'i> for Twhere T: Parse<'i>,

source§

fn parse_with_options<'t>( input: &mut Parser<'i, 't>, _options: &ParserOptions<'_, '_> ) -> Result<T, ParseError<'i, ParserError<'i>>>

Parse a value of this type with the given options.
source§

fn parse_string_with_options( input: &'i str, options: ParserOptions<'_, 'i> ) -> Result<Self, ParseError<'i, ParserError<'i>>>

Parse a value from a string with the given options.
§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> Pointee for T

§

type Metadata = ()

The type for metadata in pointers and references to Self.
source§

impl<T> ToOwned for Twhere T: Clone,

§

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 Twhere U: Into<T>,

§

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 Twhere U: TryFrom<T>,

§

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.
source§

impl<T> DeserializeOwned for Twhere T: for<'de> Deserialize<'de>,