#css-color #css #atomic #build

skribble_color

使用 palette crate 在不同的 CSS 颜色格式之间进行转换

1 个不稳定版本

0.0.0 2023年4月4日

#22#css-color

无许可证

49KB
1K SLoC

skribble_color

将支持的 CSS 字符串解析为支持的色彩类型。

用法

将以下内容添加到您的 Cargo.toml

[dependencies]
skribble_color = "0.0.0"

颜色转换

以下代码将 Color 类型转换为另一种 Color 类型。

use skribble_color::Color;

let hex: Color = "#b1ffb0".parse().unwrap();
let rgb: Color = hex.into_rgb();
let hsl: Color = hex.into_hsl();
let hwb: Color = hex.into_hwb();
let lch: Color = hex.into_lch();
let lab: Color = hex.into_lab();
let oklch: Color = hex.into_oklch();
let oklab: Color = hex.into_oklab();

示例

以下代码将 CSS 字符串解析为 Color 类型,自动检测色彩类型。

十六进制

use skribble_color::Color;
use skribble_color::Rgba;

let hex: Color = "#b1ffb0".parse().unwrap();
assert_eq!(hex.to_string(), "#b1ffb0");
assert_eq!(hex, Color::Hex(Rgba::new(0.69411767, 1.0, 0.6901961, 1.0)));

RGB

use skribble_color::Color;
use skribble_color::Rgba;

let rgb: Color = "rgb(255, 0, 0)".parse().unwrap();
assert_eq!(rgb.to_string(), "rgb(255 0 0)");
assert_eq!(rgb, Color::Rgb(Rgba::new(1.0, 0.0, 0.0, 1.0)));

HSL

use skribble_color::Color;
use skribble_color::Hsla;

let hsl: Color = "hsl(120, 100%, 50%)".parse().unwrap();
assert_eq!(hsl.to_string(), "hsl(120 100% 50%)");
assert_eq!(hsl, Color::Hsl(Hsla::new(120.0, 1.0, 0.5, 1.0)));

HWB

use skribble_color::Color;
use skribble_color::Hwba;

let hwb: Color = "hwb(120 0% 0%)".parse().unwrap();
assert_eq!(hwb.to_string(), "hwb(120 0% 0%)");
assert_eq!(hwb, Color::Hwb(Hwba::new(120.0, 0.0, 0.0, 1.0)));

依赖项

~4–6MB
~111K SLoC