#color #colors #color-name-similar #closest-color-name #color-names

color-name

A crate with color names and its values and usefull functions inluded to get similar colour name by RGB data; Based on css-color names

2 stable releases

1.1.0 Sep 24, 2020
1.0.0 Sep 9, 2020

#88 in Text editors

Download history 1302/week @ 2023-10-17 1349/week @ 2023-10-24 1189/week @ 2023-10-31 1477/week @ 2023-11-07 1318/week @ 2023-11-14 1144/week @ 2023-11-21 1212/week @ 2023-11-28 1004/week @ 2023-12-05 1118/week @ 2023-12-12 1051/week @ 2023-12-19 877/week @ 2023-12-26 899/week @ 2024-01-02 1165/week @ 2024-01-09 992/week @ 2024-01-16 1442/week @ 2024-01-23 1085/week @ 2024-01-30

4,833 downloads per month
Used in 3 crates

MIT/Apache

40KB
912 lines

Build Status API

A crate with color names and its values and usefull functions inluded to get similar colour name by RGB data. Based on these named-colors; Inspired heavely by https://github.com/colorjs/color-name.

Usage

Add this to your Cargo.toml:

[dependencies]
color-name = "1.0.0"

Add this to your main.rs or any other rust file:

extern crate color_name;
use color_name::{
    // main function to trait colours
    Color,
    // enum colour names use it with Color::value(color:color)
    // Ex: Color::value(color::red);
    color,
    // for lower case colour names
    colors,
    // for snake case colour names
    Colors,
};

assert_eq!(Color::name([0, 0, 0]), "Black");
// In case there's no color match that rgb param color it return "404"
assert_eq!(Color::name([0, 1, 1]), "404");
assert_eq!(Color::name([95, 4, 1]), "404");
// to get the closest similar colour use similar() or close_to()
//NOTE: close_to() is a proxy to similar()
assert_eq!(Color::similar([0, 1, 1]), "Black");
assert_eq!(Color::similar([95, 4, 1]), "Maroon");
assert_eq!(Color::close_to([95, 4, 1]), "Maroon");

// Deprecated use val().by_enum()
assert_eq!(Color::value(color::white), [255, 255, 255]);
assert_eq!(Color::val().by_enum(color::white), [255, 255, 255]);
assert_eq!(Color::value(color::indigo), [75, 0, 130]);
assert_eq!(Color::val().by_enum(color::indigo), [75, 0, 130]);

assert_eq!(Color::val().by_string("InDigo".to_string()), [75, 0, 130]);
// NOTE: the string can be at any case it will convert it into Title-case
assert_eq!(Color::val().by_string("inDigo".to_string()), [75, 0, 130]);
assert_eq!(Color::val().by_string("IndiGo".to_string()), [75, 0, 130]);


// for lower-case colors
use color_name::colors;
assert_eq!(colors::red,[255,0,0]);
assert_eq!(colors::blue,[0,0,255]);
assert_eq!(colors::yellow,[255,255,0]);
// for Snake-case colors
use color_name::colors;
assert_eq!(Colors::Red,[255,0,0]);
assert_eq!(Colors::Blue,[0,0,255]);
assert_eq!(Colors::Yellow,[255,255,0]);
...

// Enjoy it !!

Notes:

  • Currently (as 2020/09) there is 148 colour name.
  • All colours values are [u8;3] type ([r, g, b] in rang 0..255).

Todo

  • Add script to auto generate the following files from csv file:
    • Colors.rs.
    • colors.rs.
    • colors.rs.
    • colors_array.rs.
  • Improve the whole crate to be able to eliminate these above files.
  • Improve the whole crate to be more dynamic and able to extend it with other crates.

Licence

MIT License

No runtime deps