9 releases (breaking)

0.7.0 Aug 5, 2024
0.6.2 Jul 22, 2022
0.6.0 May 14, 2022
0.5.0 Jun 12, 2021
0.1.0 Dec 13, 2020

#38 in Web programming

Download history 21047/week @ 2024-09-17 23399/week @ 2024-09-24 23145/week @ 2024-10-01 21762/week @ 2024-10-08 19106/week @ 2024-10-15 19950/week @ 2024-10-22 21535/week @ 2024-10-29 20622/week @ 2024-11-05 28349/week @ 2024-11-12 25914/week @ 2024-11-19 23171/week @ 2024-11-26 26390/week @ 2024-12-03 32043/week @ 2024-12-10 41400/week @ 2024-12-17 11710/week @ 2024-12-24 11373/week @ 2024-12-31

101,044 downloads per month
Used in 146 crates (34 directly)

MIT/Apache

60KB
1.5K SLoC

Rust CSS Color Parser Library

License crates.io Documentation Build Status Total Downloads

DocumentationChangelogFeatures


Rust library for parsing CSS color string as defined in the W3C's CSS Color Module Level 4.

Supported Color Format

  • Named colors
  • RGB hexadecimal (with and without # prefix)
    • Short format #rgb
    • Short format with alpha #rgba
    • Long format #rrggbb
    • Long format with alpha #rrggbbaa
  • rgb() and rgba()
  • hsl() and hsla()
  • hwb()
  • lab()
  • lch()
  • hwba(), hsv(), hsva() - not in CSS standard.

Example Color Format

Click to expand!
transparent
gold
rebeccapurple
lime
#0f0
#0f0f
#00ff00
#00ff00ff
rgb(0,255,0)
rgb(0% 100% 0%)
rgb(0 255 0 / 100%)
rgba(0,255,0,1)
hsl(120,100%,50%)
hsl(120deg 100% 50%)
hsl(-240 100% 50%)
hsl(-240deg 100% 50%)
hsl(0.3333turn 100% 50%)
hsl(133.333grad 100% 50%)
hsl(2.0944rad 100% 50%)
hsla(120,100%,50%,100%)
hwb(120 0% 0%)
hwb(480deg 0% 0% / 100%)
hsv(120,100%,100%)
hsv(120deg 100% 100% / 100%)

Usage

Add this to your Cargo.toml

csscolorparser = "0.7.0"

Examples

Using csscolorparser::parse() function.

let c = csscolorparser::parse("rgb(100%,0%,0%)")?;

assert_eq!(c.to_array(), [1.0, 0.0, 0.0, 1.0]);
assert_eq!(c.to_rgba8(), [255, 0, 0, 255]);
assert_eq!(c.to_hex_string(), "#ff0000");
assert_eq!(c.to_rgb_string(), "rgb(255,0,0)");

Using parse() method on &str.

use csscolorparser::Color;

let c = "#ff00007f".parse::<Color>()?;

assert_eq!(c.to_rgba8(), [255, 0, 0, 127]);
assert_eq!(c.to_hex_string(), "#ff00007f");

Features

Default

  • named-colors: Enables parsing from named colors. Requires phf. Can be disabled using default-features = false.

Optional

  • lab: Enables parsing lab() and lch() color format.
  • rust-rgb: Enables converting from rgb crate types into Color.
  • cint: Enables converting cint crate types to and from Color.
  • serde: Enables serializing (into HEX string) and deserializing (from any supported string color format) using serde framework.

Similar Projects

Dependencies

~0–285KB