Решение на 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 {
const HUE_LIMIT: u16 = 360_u16;
const SAT_AND_VALUE_LIMIT: u8 = 100_u8;
const RGB_LIMIT: u8 = 255_u8;
/// Конструира нова стойност от вариант `RGB` с дадените стойности за червено, зелено и синьо.
///
pub fn new_rgb(red: u8, green: u8, blue: u8) -> Color {
Self::RGB { red, green, blue }
}
/// Конструира нова стойност от вариант `HSV` с дадените стойности.
///
/// В случай, че hue е над 360 или saturation или value са над 100, очакваме да `panic!`-нете с
/// каквото съобщение си изберете.
///
pub fn new_hsv(hue: u16, saturation: u8, value: u8) -> Color {
let hue = Self::is_less_than_or_eq(hue, Self::HUE_LIMIT)
.unwrap_or_else(|| panic!("Hue have to be less than or equal to {}", Self::HUE_LIMIT));
let saturation = Self::is_less_than_or_eq(saturation, Self::SAT_AND_VALUE_LIMIT)
.unwrap_or_else(|| panic!("Saturation have to be less than or equal to {}", Self::SAT_AND_VALUE_LIMIT));
let value = Self::is_less_than_or_eq(value, Self::SAT_AND_VALUE_LIMIT)
.unwrap_or_else(|| panic!("Value have to be less than or equal to {}", Self::SAT_AND_VALUE_LIMIT));
Self::HSV { hue, saturation, value }
}
fn is_less_than_or_eq<T: std::cmp::PartialOrd>(number: T, limit: T) -> Option<T> {
if number > limit {
None
} else {
Some(number)
}
}
/// Ако `self` е `RGB`, тогава връщате неговите `red`, `green`, `blue` компоненти в този ред.
/// Иначе, `panic!`-вате с каквото съобщение си изберете.
///
pub fn unwrap_rgb(&self) -> (u8, u8, u8) {
if let Self::RGB { red, green, blue } = self {
return (*red, *green, *blue);
}
panic!("Color is not RGB variant")
}
/// Ако `self` е `HSV`, тогава връщате неговите `hue`, `saturation`, `value` компоненти в този
/// ред. Иначе, `panic!`-вате с каквото съобщение си изберете.
///
pub fn unwrap_hsv(&self) -> (u16, u8, u8) {
if let Self::HSV { hue, saturation, value } = self {
return (*hue, *saturation, *value);
}
panic!("Color is not HSV variant")
}
/// В случай, че варианта на `self` е `RGB`, очакваме низ със съдържание `#rrggbb`, където
/// червения, зеления и синия компонент са форматирани в шестнадесетична система, и всеки от тях е
/// точно два символа с малки букви (запълнени с нули).
///
/// Ако варианта е `HSV`, очакваме низ `hsv(h,s%,v%)`, където числата са си напечатани в
/// десетичната система, без водещи нули, без интервали след запетаите, вторите две завършващи на
/// `%`.
///
pub fn to_string(&self) -> String {
match self {
Self::RGB { red, green, blue } => format!("#{:02x}{:02x}{:02x}", *red, *green, *blue),
Self::HSV { hue, saturation, value } => format!("hsv({},{}%,{}%)", *hue, *saturation, *value)
}
}
/// Инвертира цвят покомпонентно -- за всяка от стойностите се взема разликата с максимума.
///
pub fn invert(&self) -> Self {
match self {
Self::RGB { red, green, blue } => {
Self::RGB { red: Self::RGB_LIMIT - red, green: Self::RGB_LIMIT - green, blue: Self::RGB_LIMIT - blue }
},
Self::HSV { hue, saturation, value } => {
Self::HSV { hue: Self::HUE_LIMIT - hue, saturation: Self::SAT_AND_VALUE_LIMIT - saturation, value: Self::SAT_AND_VALUE_LIMIT - value }
}
}
}
}

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

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

running 5 tests
test solution_test::test_invert_hsv ... ok
test solution_test::test_hsv_display ... 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

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

Георги качи първо решение на 26.10.2022 18:28 (преди почти 3 години)