Решение на CSS Цветове от Марио Николов

Обратно към всички решения

Към профила на Марио Николов

Резултати

  • 20 точки от тестове
  • 0 бонус точки
  • 20 точки общо
  • 5 успешни тест(а)
  • 0 неуспешни тест(а)

Код

pub enum Color {
RGB { red: u8, green: u8, blue: u8 },
HSV { hue: u16, saturation: u8, value: u8 },
}
impl Color {
pub fn new_rgb(red: u8, green: u8, blue: u8) -> Color {
return Color::RGB {
red: red,
green: green,
blue: blue,
};
}
pub fn new_hsv(hue: u16, saturation: u8, value: u8) -> Color {
if hue > 360 {
panic!("Hue degree above acceptable range of 360 degrees");
};
if saturation > 100 || value > 100 {
panic!("Saturation or value exceeds max limit of 100");
}
return Color::HSV {
hue: hue,
saturation: saturation,
value: value,
};
}
pub fn unwrap_rgb(&self) -> (u8, u8, u8) {
match self {
Color::RGB { red, green, blue } => (red.clone(), green.clone(), blue.clone()),
_ => panic!("Self is not a RGB"),
}
}
pub fn unwrap_hsv(&self) -> (u16, u8, u8) {
match self {
Color::HSV {
hue,
saturation,
value,
} => (hue.clone(), saturation.clone(), value.clone()),
_ => panic!("Self is not a HSV"),
}
}
pub fn to_string(&self) -> String {
match self {
Color::RGB { red, green, blue } => format!("#{:02x}{:02x}{:02x}", red, green, blue),
Color::HSV {
hue,
saturation,
value,
} => format!("hsv({},{}%,{}%)", hue, saturation, value),
}
}
pub fn invert(&self) -> Self {
match self {
Color::RGB { red, green, blue } => {
let red:u8 = 255 - red;
let green:u8 = 255 - green;
let blue:u8 = 255 - blue;
return Self::RGB { red: red, green: green, blue: blue };
},
Color::HSV { hue, saturation, value } => {
let hue = 360 - hue;
let saturation = 100 - saturation;
let value = 100 - value;
return Self::HSV { hue: hue, saturation: saturation, value: value };
}
}
}
}

Лог от изпълнението

Compiling solution v0.1.0 (/tmp/d20230111-3772066-3h217u/solution)
    Finished test [unoptimized + debuginfo] target(s) in 0.67s
     Running tests/solution_test.rs (target/debug/deps/solution_test-0edbea2040daef01)

running 5 tests
test solution_test::test_hsv_display ... ok
test solution_test::test_invert_hsv ... ok
test solution_test::test_invert_rgb ... ok
test solution_test::test_rgb_display ... ok
test solution_test::test_new_hsv ... ok

test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s

История (2 версии и 0 коментара)

Марио качи първо решение на 27.10.2022 00:53 (преди почти 3 години)

Марио качи решение на 27.10.2022 16:23 (преди почти 3 години)

pub enum Color {
RGB { red: u8, green: u8, blue: u8 },
HSV { hue: u16, saturation: u8, value: u8 },
}
impl Color {
pub fn new_rgb(red: u8, green: u8, blue: u8) -> Color {
return Color::RGB {
red: red,
green: green,
blue: blue,
};
}
pub fn new_hsv(hue: u16, saturation: u8, value: u8) -> Color {
if hue > 360 {
panic!("Hue degree above acceptable range of 360 degrees");
};
+ if saturation > 100 || value > 100 {
+ panic!("Saturation or value exceeds max limit of 100");
+ }
+
return Color::HSV {
hue: hue,
saturation: saturation,
value: value,
};
}
pub fn unwrap_rgb(&self) -> (u8, u8, u8) {
match self {
Color::RGB { red, green, blue } => (red.clone(), green.clone(), blue.clone()),
_ => panic!("Self is not a RGB"),
}
}
pub fn unwrap_hsv(&self) -> (u16, u8, u8) {
match self {
Color::HSV {
hue,
saturation,
value,
} => (hue.clone(), saturation.clone(), value.clone()),
_ => panic!("Self is not a HSV"),
}
}
pub fn to_string(&self) -> String {
match self {
- Color::RGB { red, green, blue } => format!("#{:02X}{:02X}{:02X}", red, green, blue),
+ Color::RGB { red, green, blue } => format!("#{:02x}{:02x}{:02x}", red, green, blue),
Color::HSV {
hue,
saturation,
value,
} => format!("hsv({},{}%,{}%)", hue, saturation, value),
}
}
pub fn invert(&self) -> Self {
match self {
Color::RGB { red, green, blue } => {
let red:u8 = 255 - red;
let green:u8 = 255 - green;
let blue:u8 = 255 - blue;
return Self::RGB { red: red, green: green, blue: blue };
},
Color::HSV { hue, saturation, value } => {
let hue = 360 - hue;
let saturation = 100 - saturation;
let value = 100 - value;
return Self::HSV { hue: hue, saturation: saturation, value: value };
}
}
}
}