summaryrefslogtreecommitdiff
path: root/gtk2_ardour/stripable_colorpicker.cc
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2017-03-30 15:20:48 +0200
committerRobin Gareus <robin@gareus.org>2017-03-30 15:20:48 +0200
commitdd7063277a52efd0a335156f055a778613d63283 (patch)
tree1a63cbb4bdfa8cf4fb9d41d26ee418e04edf78da /gtk2_ardour/stripable_colorpicker.cc
parentea8c6e9fc81fb4a5bf44e6c2d5a3506b52e530e1 (diff)
Add ColorButton drop-in replacement with palette support
Diffstat (limited to 'gtk2_ardour/stripable_colorpicker.cc')
-rw-r--r--gtk2_ardour/stripable_colorpicker.cc60
1 files changed, 46 insertions, 14 deletions
diff --git a/gtk2_ardour/stripable_colorpicker.cc b/gtk2_ardour/stripable_colorpicker.cc
index b9c4990cfe..3defed8120 100644
--- a/gtk2_ardour/stripable_colorpicker.cc
+++ b/gtk2_ardour/stripable_colorpicker.cc
@@ -78,6 +78,25 @@ StripableColorDialog::reset ()
}
void
+StripableColorDialog::popup (const std::string& name, uint32_t color)
+{
+ set_title (string_compose (_("Color Selection: %1"), name));
+ _initial_color = color;
+
+ get_colorsel()->set_has_opacity_control (false);
+ get_colorsel()->set_has_palette (true);
+
+ Gdk::Color c = gdk_color_from_rgba (_initial_color);
+
+ get_colorsel()->set_previous_color (c);
+ get_colorsel()->set_current_color (c);
+ _color_changed_connection.disconnect ();
+ _color_changed_connection = get_colorsel()->signal_color_changed().connect (sigc::mem_fun (*this, &StripableColorDialog::color_changed));
+
+ present ();
+}
+
+void
StripableColorDialog::popup (boost::shared_ptr<ARDOUR::Stripable> s)
{
if (s && s->active_color_picker()) {
@@ -92,27 +111,18 @@ StripableColorDialog::popup (boost::shared_ptr<ARDOUR::Stripable> s)
_stripable = s;
_stripable->set_active_color_picker (this);
- _initial_color = _stripable->presentation_info().color ();
- set_title (string_compose (_("Color Selection: %1"), s->name()));
-
- get_colorsel()->set_has_opacity_control (false);
- get_colorsel()->set_has_palette (true);
-
- Gdk::Color c = gdk_color_from_rgba (_initial_color);
-
- get_colorsel()->set_previous_color (c);
- get_colorsel()->set_current_color (c);
- _color_changed_connection = get_colorsel()->signal_color_changed().connect (sigc::mem_fun (*this, &StripableColorDialog::color_changed));
-
- present ();
+ popup (s->name(), _stripable->presentation_info().color ());
}
void
StripableColorDialog::finish_color_edit (int response)
{
+ if (response == RESPONSE_OK) {
+ ColorChanged (gdk_color_to_rgba (get_colorsel()->get_current_color())); /* EMIT SIGNAL */
+ }
if (_stripable && response == RESPONSE_OK) {
_stripable->presentation_info().set_color (gdk_color_to_rgba (get_colorsel()->get_current_color()));
- } else {
+ } else if (_stripable) {
_stripable->presentation_info().set_color (_initial_color);
}
reset ();
@@ -125,3 +135,25 @@ StripableColorDialog::color_changed ()
_stripable->presentation_info().set_color (gdk_color_to_rgba (get_colorsel()->get_current_color()));
}
}
+
+
+ArdourColorButton::ArdourColorButton ()
+{
+ _color_picker.ColorChanged.connect (sigc::mem_fun(*this, &ArdourColorButton::color_selected));
+}
+
+void
+ArdourColorButton::on_clicked ()
+{
+ _color_picker.popup ("", gdk_color_to_rgba (get_color ()));
+ _color_picker.get_window ()->set_transient_for (get_window ());
+}
+
+void
+ArdourColorButton::color_selected (uint32_t color)
+{
+ Gdk::Color c;
+ set_color_from_rgba (c, color);
+ set_color (c);
+ g_signal_emit_by_name (GTK_WIDGET(gobj()), "color-set", 0);
+}