From 9e75c124a8e19bad8504dc04bab3324f67315fb7 Mon Sep 17 00:00:00 2001 From: LepkoQQ Date: Tue, 25 Aug 2020 22:56:57 +0200 Subject: [PATCH] LibGUI: Add spinbox for alpha channel in ColorPicker --- Libraries/LibGUI/ColorPicker.cpp | 20 ++++++++++++++++---- Libraries/LibGUI/ColorPicker.h | 1 + 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/Libraries/LibGUI/ColorPicker.cpp b/Libraries/LibGUI/ColorPicker.cpp index 9059d35a2b..d1f5fb3c71 100644 --- a/Libraries/LibGUI/ColorPicker.cpp +++ b/Libraries/LibGUI/ColorPicker.cpp @@ -222,7 +222,8 @@ void ColorPicker::build_ui_custom(Widget& root_container) enum RGBComponent { Red, Green, - Blue + Blue, + Alpha }; auto& horizontal_container = root_container.add(); @@ -282,7 +283,7 @@ void ColorPicker::build_ui_custom(Widget& root_container) auto& html_label = html_container.add(); html_label.set_text_alignment(Gfx::TextAlignment::CenterLeft); html_label.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fill); - html_label.set_preferred_size({ 70, 0 }); + html_label.set_preferred_size({ 48, 0 }); html_label.set_text("HTML:"); m_html_text = html_container.add(); @@ -312,7 +313,7 @@ void ColorPicker::build_ui_custom(Widget& root_container) auto& rgb_label = rgb_container.add(); rgb_label.set_text_alignment(Gfx::TextAlignment::CenterLeft); rgb_label.set_size_policy(GUI::SizePolicy::Fixed, GUI::SizePolicy::Fill); - rgb_label.set_preferred_size({ 70, 0 }); + rgb_label.set_preferred_size({ 48, 0 }); auto& spinbox = rgb_container.add(); spinbox.set_size_policy(SizePolicy::Fill, SizePolicy::Fixed); @@ -320,6 +321,7 @@ void ColorPicker::build_ui_custom(Widget& root_container) spinbox.set_min(0); spinbox.set_max(255); spinbox.set_value(initial_value); + spinbox.set_enabled(m_color_has_alpha_channel); spinbox.on_change = [this, component](auto value) { auto color = m_color; @@ -329,6 +331,8 @@ void ColorPicker::build_ui_custom(Widget& root_container) color.set_green(value); if (component == Blue) color.set_blue(value); + if (component == Alpha) + color.set_alpha(value); if (m_color == color) return; @@ -347,12 +351,16 @@ void ColorPicker::build_ui_custom(Widget& root_container) } else if (component == Blue) { rgb_label.set_text("Blue:"); m_blue_spinbox = spinbox; + } else if (component == Alpha) { + rgb_label.set_text("Alpha:"); + m_alpha_spinbox = spinbox; } }; make_spinbox(Red, m_color.red()); make_spinbox(Green, m_color.green()); make_spinbox(Blue, m_color.blue()); + make_spinbox(Alpha, m_color.alpha()); } void ColorPicker::update_color_widgets() @@ -367,6 +375,8 @@ void ColorPicker::update_color_widgets() m_red_spinbox->set_value(m_color.red()); m_green_spinbox->set_value(m_color.green()); m_blue_spinbox->set_value(m_color.blue()); + m_alpha_spinbox->set_value(m_color.alpha()); + m_alpha_spinbox->set_enabled(m_color_has_alpha_channel); } void ColorPicker::create_color_button(Widget& container, unsigned rgb) @@ -454,7 +464,7 @@ CustomColorWidget::CustomColorWidget(Color color) m_color_slider = add(color.to_hsv().hue); m_color_slider->set_size_policy(SizePolicy::Fixed, SizePolicy::Fixed); - auto slider_width = 32 + (m_color_slider->frame_thickness() * 2); + auto slider_width = 24 + (m_color_slider->frame_thickness() * 2); m_color_slider->set_preferred_size(slider_width, size); m_color_slider->on_pick = [this](double value) { m_color_field->set_hue(value); @@ -524,6 +534,7 @@ void ColorField::set_hue(double hue) create_color_bitmap(); auto color = Color::from_hsv(hsv); + color.set_alpha(m_color.alpha()); set_color(color); if (on_pick) @@ -538,6 +549,7 @@ void ColorField::pick_color_at_position(GUI::MouseEvent& event) auto inner_rect = frame_inner_rect(); auto position = event.position().constrained(inner_rect).translated(-frame_thickness(), -frame_thickness()); auto color = Color::from_hsv(m_hue, (double)position.x() / inner_rect.width(), (double)(inner_rect.height() - position.y()) / inner_rect.height()); + color.set_alpha(m_color.alpha()); m_last_position = position; m_color = color; diff --git a/Libraries/LibGUI/ColorPicker.h b/Libraries/LibGUI/ColorPicker.h index 60a3d88b2d..228ddc46f3 100644 --- a/Libraries/LibGUI/ColorPicker.h +++ b/Libraries/LibGUI/ColorPicker.h @@ -63,6 +63,7 @@ private: RefPtr m_red_spinbox; RefPtr m_green_spinbox; RefPtr m_blue_spinbox; + RefPtr m_alpha_spinbox; }; }