summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gtk2_ardour/color_theme_manager.cc72
-rw-r--r--gtk2_ardour/color_theme_manager.h18
-rw-r--r--gtk2_ardour/theme_manager.cc65
-rw-r--r--gtk2_ardour/theme_manager.h22
4 files changed, 88 insertions, 89 deletions
diff --git a/gtk2_ardour/color_theme_manager.cc b/gtk2_ardour/color_theme_manager.cc
index c3d0765726..31f0530fb6 100644
--- a/gtk2_ardour/color_theme_manager.cc
+++ b/gtk2_ardour/color_theme_manager.cc
@@ -62,7 +62,53 @@ ColorThemeManager::ColorThemeManager ()
, palette_viewport (*palette_scroller.get_hadjustment(), *palette_scroller.get_vadjustment())
, palette_group (0)
, palette_window (0)
+ , color_theme_label (_("Color Theme"))
{
+ set_spacing (12);
+
+ std::map<string,string> color_themes;
+
+ get_color_themes (color_themes);
+
+ if (color_themes.size() > 1) {
+ theme_list = TreeStore::create (color_theme_columns);
+
+ TreeModel::iterator selected_iter = theme_list->children().end();
+
+ for (std::map<string,string>::iterator c = color_themes.begin(); c != color_themes.end(); ++c) {
+ TreeModel::Row row;
+
+ row = *(theme_list->append());
+ row[color_theme_columns.name] = c->first;
+ row[color_theme_columns.path] = c->second;
+
+ /* match second (path; really basename) since that is
+ what we store/restore.
+ */
+
+ if (UIConfiguration::instance().get_color_file() == c->second) {
+ selected_iter = row;
+ }
+ }
+
+ color_theme_dropdown.set_model (theme_list);
+ color_theme_dropdown.pack_start (color_theme_columns.name);
+
+ if (selected_iter != theme_list->children().end()) {
+ color_theme_dropdown.set_active (selected_iter);
+ }
+
+ Gtk::HBox* hbox = Gtk::manage (new Gtk::HBox());
+ Gtk::Alignment* align = Gtk::manage (new Gtk::Alignment);
+ align->set (0, 0.5);
+ align->add (color_theme_dropdown);
+ hbox->set_spacing (6);
+ hbox->pack_start (color_theme_label, false, false);
+ hbox->pack_start (*align, true, true);
+ pack_start (*hbox, PACK_SHRINK);
+ hbox->show_all ();
+ }
+
reset_button.signal_clicked().connect (sigc::mem_fun (*this, &ColorThemeManager::reset_canvas_colors));
/* Now the alias list */
@@ -100,9 +146,15 @@ ColorThemeManager::ColorThemeManager ()
notebook.set_size_request (400, 400);
- set_spacing (12);
- pack_start (reset_button, false, false);
pack_start (notebook, true, true);
+ pack_start (reset_button, false, false);
+
+ color_dialog.get_colorsel()->set_has_opacity_control (true);
+ color_dialog.get_colorsel()->set_has_palette (true);
+ color_dialog.get_ok_button()->signal_clicked().connect (sigc::bind (sigc::mem_fun (color_dialog, &Gtk::Dialog::response), RESPONSE_ACCEPT));
+ color_dialog.get_cancel_button()->signal_clicked().connect (sigc::bind (sigc::mem_fun (color_dialog, &Gtk::Dialog::response), RESPONSE_CANCEL));
+
+ color_theme_dropdown.signal_changed().connect (sigc::mem_fun (*this, &ColorThemeManager::on_color_theme_changed));
/* no need to call setup_palette() here, it will be done when its size is allocated */
setup_aliases ();
@@ -551,3 +603,19 @@ ColorThemeManager::tip_widget()
{
return reset_button; /* XXX need a better widget for this purpose */
}
+
+void
+ColorThemeManager::on_color_theme_changed ()
+{
+ Gtk::TreeModel::iterator iter = color_theme_dropdown.get_active();
+
+ if (iter) {
+ Gtk::TreeModel::Row row = *iter;
+
+ if (row) {
+ string new_theme = row[color_theme_columns.path];
+ UIConfiguration::instance().set_color_file (new_theme);
+ }
+ }
+}
+
diff --git a/gtk2_ardour/color_theme_manager.h b/gtk2_ardour/color_theme_manager.h
index b83b5ae523..d565066a18 100644
--- a/gtk2_ardour/color_theme_manager.h
+++ b/gtk2_ardour/color_theme_manager.h
@@ -147,6 +147,24 @@ class ColorThemeManager : public Gtk::VBox, public OptionEditorComponent
void colors_changed ();
void set_ui_to_state ();
+
+
+ struct ColorThemeModelColumns : public Gtk::TreeModel::ColumnRecord {
+ ColorThemeModelColumns() {
+ add (name);
+ add (path);
+ }
+
+ Gtk::TreeModelColumn<std::string> name;
+ Gtk::TreeModelColumn<std::string> path;
+ };
+
+ ColorThemeModelColumns color_theme_columns;
+ Glib::RefPtr<Gtk::TreeStore> theme_list;
+
+ Gtk::Label color_theme_label;
+ Gtk::ComboBox color_theme_dropdown;
+
};
#endif /* __ardour_gtk_color_manager_h__ */
diff --git a/gtk2_ardour/theme_manager.cc b/gtk2_ardour/theme_manager.cc
index 084bc368ca..c49fd5381b 100644
--- a/gtk2_ardour/theme_manager.cc
+++ b/gtk2_ardour/theme_manager.cc
@@ -28,7 +28,6 @@
#include <gtkmm/settings.h>
#include "gtkmm2ext/gtk_ui.h"
-#include "gtkmm2ext/cell_renderer_color_selector.h"
#include "gtkmm2ext/utils.h"
#include "pbd/file_utils.h"
@@ -70,7 +69,6 @@ ThemeManager::ThemeManager()
, transients_follow_front (_("Transient windows follow front window."))
, floating_monitor_section (_("Float detached monitor-section window"))
, icon_set_label (_("Icon Set"))
- , color_theme_label (_("Color Theme"))
{
Gtk::HBox* hbox;
@@ -78,48 +76,6 @@ ThemeManager::ThemeManager()
set_homogeneous (false);
- std::map<string,string> color_themes;
-
- get_color_themes (color_themes);
-
- if (color_themes.size() > 1) {
- theme_list = TreeStore::create (color_theme_columns);
-
- TreeModel::iterator selected_iter = theme_list->children().end();
-
- for (std::map<string,string>::iterator c = color_themes.begin(); c != color_themes.end(); ++c) {
- TreeModel::Row row;
-
- row = *(theme_list->append());
- row[color_theme_columns.name] = c->first;
- row[color_theme_columns.path] = c->second;
-
- /* match second (path; really basename) since that is
- what we store/restore.
- */
-
- if (UIConfiguration::instance().get_color_file() == c->second) {
- selected_iter = row;
- }
- }
-
- color_theme_dropdown.set_model (theme_list);
- color_theme_dropdown.pack_start (color_theme_columns.name);
-
- if (selected_iter != theme_list->children().end()) {
- color_theme_dropdown.set_active (selected_iter);
- }
-
- hbox = Gtk::manage (new Gtk::HBox());
- Gtk::Alignment* align = Gtk::manage (new Gtk::Alignment);
- align->set (0, 0.5);
- align->add (color_theme_dropdown);
- hbox->set_spacing (6);
- hbox->pack_start (color_theme_label, false, false);
- hbox->pack_start (*align, true, true);
- pack_start (*hbox, PACK_SHRINK);
- hbox->show_all ();
- }
#ifndef __APPLE__
pack_start (all_dialogs, PACK_SHRINK);
@@ -166,13 +122,8 @@ ThemeManager::ThemeManager()
waveform_gradient_depth.set_update_policy (Gtk::UPDATE_DELAYED);
timeline_item_gradient_depth.set_update_policy (Gtk::UPDATE_DELAYED);
- color_dialog.get_colorsel()->set_has_opacity_control (true);
- color_dialog.get_colorsel()->set_has_palette (true);
-
set_ui_to_state();
- color_dialog.get_ok_button()->signal_clicked().connect (sigc::bind (sigc::mem_fun (color_dialog, &Gtk::Dialog::response), RESPONSE_ACCEPT));
- color_dialog.get_cancel_button()->signal_clicked().connect (sigc::bind (sigc::mem_fun (color_dialog, &Gtk::Dialog::response), RESPONSE_CANCEL));
flat_buttons.signal_toggled().connect (sigc::mem_fun (*this, &ThemeManager::on_flat_buttons_toggled));
blink_rec_button.signal_toggled().connect (sigc::mem_fun (*this, &ThemeManager::on_blink_rec_arm_toggled));
region_color_button.signal_toggled().connect (sigc::mem_fun (*this, &ThemeManager::on_region_color_toggled));
@@ -183,7 +134,6 @@ ThemeManager::ThemeManager()
transients_follow_front.signal_toggled().connect (sigc::mem_fun (*this, &ThemeManager::on_transients_follow_front_toggled));
floating_monitor_section.signal_toggled().connect (sigc::mem_fun (*this, &ThemeManager::on_floating_monitor_section_toggled));
icon_set_dropdown.signal_changed().connect (sigc::mem_fun (*this, &ThemeManager::on_icon_set_changed));
- color_theme_dropdown.signal_changed().connect (sigc::mem_fun (*this, &ThemeManager::on_color_theme_changed));
Gtkmm2ext::UI::instance()->set_tip (all_dialogs,
string_compose (_("Mark all floating windows to be type \"Dialog\" rather than using \"Utility\" for some.\n"
@@ -271,21 +221,6 @@ ThemeManager::on_icon_set_changed ()
}
void
-ThemeManager::on_color_theme_changed ()
-{
- Gtk::TreeModel::iterator iter = color_theme_dropdown.get_active();
-
- if (iter) {
- Gtk::TreeModel::Row row = *iter;
-
- if (row) {
- string new_theme = row[color_theme_columns.path];
- UIConfiguration::instance().set_color_file (new_theme);
- }
- }
-}
-
-void
ThemeManager::set_ui_to_state()
{
/* there is no need to block signal handlers, here,
diff --git a/gtk2_ardour/theme_manager.h b/gtk2_ardour/theme_manager.h
index 93d558810c..6b0626bd1d 100644
--- a/gtk2_ardour/theme_manager.h
+++ b/gtk2_ardour/theme_manager.h
@@ -49,27 +49,8 @@ class ThemeManager : public Gtk::VBox
void on_transients_follow_front_toggled ();
void on_floating_monitor_section_toggled ();
void on_icon_set_changed ();
- void on_color_theme_changed ();
private:
- Gtk::Notebook notebook;
-
- struct ColorThemeModelColumns : public Gtk::TreeModel::ColumnRecord {
- ColorThemeModelColumns() {
- add (name);
- add (path);
- }
-
- Gtk::TreeModelColumn<std::string> name;
- Gtk::TreeModelColumn<std::string> path;
- };
-
- ColorThemeModelColumns color_theme_columns;
- Glib::RefPtr<Gtk::TreeStore> theme_list;
-
- Gtk::ColorSelectionDialog color_dialog;
- sigc::connection color_dialog_connection;
-
Gtk::CheckButton flat_buttons;
Gtk::CheckButton blink_rec_button;
Gtk::CheckButton region_color_button;
@@ -84,9 +65,6 @@ class ThemeManager : public Gtk::VBox
Gtk::CheckButton gradient_waveforms;
Gtk::Label icon_set_label;
Gtk::ComboBoxText icon_set_dropdown;
- Gtk::Label color_theme_label;
- Gtk::ComboBox color_theme_dropdown;
-
void colors_changed ();
void set_ui_to_state ();