1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
use super::{grayscale, Hsl, Rgb};
use crate::{consts, ColorTransform, SaturationInSpace};
use consts::RGB_UNIT_MAX;
impl ColorTransform for Rgb {
fn lighten(&mut self, amt: f64) {
let mut hsl: Hsl = self.into();
hsl.lighten(amt);
let lightened_rgb: Rgb = hsl.as_ref().into();
self._apply_tuple(&lightened_rgb.into());
}
fn saturate(&mut self, sat: SaturationInSpace) {
match sat {
SaturationInSpace::Hsl(amt) => {
let mut hsl: Hsl = self.into();
hsl.set_saturation(hsl.get_saturation() + amt);
let new_rgb = Rgb::from(hsl);
self._apply_tuple(&new_rgb.into());
}
SaturationInSpace::Hsv(amt) => {
println!("{}", amt);
unimplemented!();
}
}
}
fn adjust_hue(&mut self, hue: f64) {
let mut hsl: Hsl = self.into();
hsl.adjust_hue(hue);
self._apply_tuple(&Rgb::from(hsl).into());
}
fn grayscale_simple(&mut self) {
grayscale::rgb_grayscale(self, grayscale::GrayScaleMethod::AverageProminent);
}
fn invert(&mut self) {
self.r = RGB_UNIT_MAX - self.r;
self.g = RGB_UNIT_MAX - self.g;
self.b = RGB_UNIT_MAX - self.b;
}
}
#[test]
fn lighten_darken_test() {
use crate::ColorTuple;
pub fn as_rounded_rgb_tuple(t: &ColorTuple) -> (u16, u16, u16) {
let (r, g, b) = *t;
(r.round() as u16, g.round() as u16, b.round() as u16)
}
let asserts = [
((30.0, 108.0, 77.0), 20.0, (52, 188, 134)),
((30.0, 108.0, 77.0), 90.0, (255, 255, 255)),
((30.0, 108.0, 77.0), -20.0, (8, 28, 20)),
((0.0, 0.0, 0.0), 50.0, (128, 128, 128)),
((0.0, 0.0, 0.0), -50.0, (0, 0, 0)),
((0.0, 0.0, 0.0), 300.5, (255, 255, 255)),
];
for a in asserts.iter() {
let (origin, amt, result) = *a;
let mut rgb = Rgb::from(&origin);
rgb.lighten(amt);
assert_eq!(as_rounded_rgb_tuple(&rgb.into()), result);
}
}