mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-11 00:56:33 +01:00
Prepare ExportPresetSelector read-only mode (for quick export)
This commit is contained in:
parent
56fd2a299f
commit
5c05e8d047
2 changed files with 62 additions and 29 deletions
|
|
@ -28,31 +28,40 @@
|
||||||
|
|
||||||
#include "pbd/i18n.h"
|
#include "pbd/i18n.h"
|
||||||
|
|
||||||
ExportPresetSelector::ExportPresetSelector ()
|
ExportPresetSelector::ExportPresetSelector (bool readonly)
|
||||||
: label (_("Preset"), Gtk::ALIGN_START)
|
: label (_("Preset"), Gtk::ALIGN_START)
|
||||||
|
, combo (!readonly)
|
||||||
, save_button (Gtk::Stock::SAVE)
|
, save_button (Gtk::Stock::SAVE)
|
||||||
, remove_button (Gtk::Stock::REMOVE)
|
, remove_button (Gtk::Stock::REMOVE)
|
||||||
, new_button (Gtk::Stock::NEW)
|
, new_button (Gtk::Stock::NEW)
|
||||||
{
|
{
|
||||||
list = Gtk::ListStore::create (cols);
|
list = Gtk::ListStore::create (cols);
|
||||||
list->set_sort_column (cols.label, Gtk::SORT_ASCENDING);
|
list->set_sort_column (cols.label, Gtk::SORT_ASCENDING);
|
||||||
entry.set_model (list);
|
combo.set_model (list);
|
||||||
entry.set_text_column (cols.label);
|
|
||||||
|
|
||||||
pack_start (label, false, false, 0);
|
if (readonly) {
|
||||||
pack_start (entry, true, true, 6);
|
combo.pack_start (cols.label);
|
||||||
pack_start (save_button, false, false, 0);
|
pack_start (label, false, false, 0);
|
||||||
pack_start (remove_button, false, false, 6);
|
pack_start (combo, true, true, 6);
|
||||||
pack_start (new_button, false, false, 0);
|
select_connection = combo.signal_changed ().connect (sigc::mem_fun (*this, &ExportPresetSelector::selection_changed));
|
||||||
|
} else {
|
||||||
|
combo.set_entry_text_column (cols.label);
|
||||||
|
|
||||||
save_button.set_sensitive (false);
|
pack_start (label, false, false, 0);
|
||||||
remove_button.set_sensitive (false);
|
pack_start (combo, true, true, 6);
|
||||||
new_button.set_sensitive (false);
|
pack_start (save_button, false, false, 0);
|
||||||
|
pack_start (remove_button, false, false, 6);
|
||||||
|
pack_start (new_button, false, false, 0);
|
||||||
|
|
||||||
select_connection = entry.signal_changed ().connect (sigc::mem_fun (*this, &ExportPresetSelector::update_selection));
|
save_button.set_sensitive (false);
|
||||||
save_button.signal_clicked ().connect (sigc::mem_fun (*this, &ExportPresetSelector::save_current));
|
remove_button.set_sensitive (false);
|
||||||
new_button.signal_clicked ().connect (sigc::mem_fun (*this, &ExportPresetSelector::create_new));
|
new_button.set_sensitive (false);
|
||||||
remove_button.signal_clicked ().connect (sigc::mem_fun (*this, &ExportPresetSelector::remove_current));
|
|
||||||
|
select_connection = combo.signal_changed ().connect (sigc::mem_fun (*this, &ExportPresetSelector::update_selection));
|
||||||
|
save_button.signal_clicked ().connect (sigc::mem_fun (*this, &ExportPresetSelector::save_current));
|
||||||
|
new_button.signal_clicked ().connect (sigc::mem_fun (*this, &ExportPresetSelector::create_new));
|
||||||
|
remove_button.signal_clicked ().connect (sigc::mem_fun (*this, &ExportPresetSelector::remove_current));
|
||||||
|
}
|
||||||
|
|
||||||
show_all_children ();
|
show_all_children ();
|
||||||
}
|
}
|
||||||
|
|
@ -61,6 +70,7 @@ void
|
||||||
ExportPresetSelector::set_manager (boost::shared_ptr<ARDOUR::ExportProfileManager> manager)
|
ExportPresetSelector::set_manager (boost::shared_ptr<ARDOUR::ExportProfileManager> manager)
|
||||||
{
|
{
|
||||||
profile_manager = manager;
|
profile_manager = manager;
|
||||||
|
current = profile_manager->preset ();
|
||||||
sync_with_manager ();
|
sync_with_manager ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -79,17 +89,37 @@ ExportPresetSelector::sync_with_manager ()
|
||||||
|
|
||||||
if (*it == current) {
|
if (*it == current) {
|
||||||
select_connection.block (true);
|
select_connection.block (true);
|
||||||
entry.set_active (tree_it);
|
combo.set_active (tree_it);
|
||||||
select_connection.block (false);
|
select_connection.block (false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
ExportPresetSelector::selection_changed ()
|
||||||
|
{
|
||||||
|
Gtk::ListStore::iterator it = combo.get_active ();
|
||||||
|
if (!it) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
assert (list->iter_is_valid (it));
|
||||||
|
current = it->get_value (cols.preset);
|
||||||
|
if (!profile_manager->load_preset (current)) {
|
||||||
|
Gtk::MessageDialog dialog (_("The selected preset did not load successfully!\nPerhaps it references a format that has been removed?"),
|
||||||
|
false, Gtk::MESSAGE_WARNING);
|
||||||
|
dialog.run ();
|
||||||
|
}
|
||||||
|
|
||||||
|
sync_with_manager ();
|
||||||
|
CriticalSelectionChanged ();
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
ExportPresetSelector::update_selection ()
|
ExportPresetSelector::update_selection ()
|
||||||
{
|
{
|
||||||
Gtk::ListStore::iterator it = entry.get_active ();
|
Gtk::ListStore::iterator it = combo.get_active ();
|
||||||
std::string text = entry.get_entry ()->get_text ();
|
std::string text = combo.get_entry ()->get_text ();
|
||||||
bool preset_name_exists = false;
|
bool preset_name_exists = false;
|
||||||
|
|
||||||
for (PresetList::const_iterator it = profile_manager->get_presets ().begin (); it != profile_manager->get_presets ().end (); ++it) {
|
for (PresetList::const_iterator it = profile_manager->get_presets ().begin (); it != profile_manager->get_presets ().end (); ++it) {
|
||||||
|
|
@ -111,8 +141,8 @@ ExportPresetSelector::update_selection ()
|
||||||
/* Make an edit, so that signal changed will be emitted on re-selection */
|
/* Make an edit, so that signal changed will be emitted on re-selection */
|
||||||
|
|
||||||
select_connection.block (true);
|
select_connection.block (true);
|
||||||
entry.get_entry ()->set_text ("");
|
combo.get_entry ()->set_text ("");
|
||||||
entry.get_entry ()->set_text (text);
|
combo.get_entry ()->set_text (text);
|
||||||
select_connection.block (false);
|
select_connection.block (false);
|
||||||
|
|
||||||
} else { // Text has been edited, this should not make any changes in the profile manager
|
} else { // Text has been edited, this should not make any changes in the profile manager
|
||||||
|
|
@ -135,7 +165,7 @@ ExportPresetSelector::create_new ()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
previous = current = profile_manager->new_preset (entry.get_entry ()->get_text ());
|
previous = current = profile_manager->new_preset (combo.get_entry ()->get_text ());
|
||||||
sync_with_manager ();
|
sync_with_manager ();
|
||||||
update_selection (); // Update preset widget states
|
update_selection (); // Update preset widget states
|
||||||
}
|
}
|
||||||
|
|
@ -147,7 +177,7 @@ ExportPresetSelector::save_current ()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
previous = current = profile_manager->save_preset (entry.get_entry ()->get_text ());
|
previous = current = profile_manager->save_preset (combo.get_entry ()->get_text ());
|
||||||
sync_with_manager ();
|
sync_with_manager ();
|
||||||
update_selection (); // Update preset widget states
|
update_selection (); // Update preset widget states
|
||||||
}
|
}
|
||||||
|
|
@ -172,6 +202,6 @@ ExportPresetSelector::remove_current ()
|
||||||
}
|
}
|
||||||
|
|
||||||
profile_manager->remove_preset ();
|
profile_manager->remove_preset ();
|
||||||
entry.get_entry ()->set_text ("");
|
combo.get_entry ()->set_text ("");
|
||||||
sync_with_manager ();
|
sync_with_manager ();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -25,7 +25,7 @@
|
||||||
|
|
||||||
#include <gtkmm/box.h>
|
#include <gtkmm/box.h>
|
||||||
#include <gtkmm/button.h>
|
#include <gtkmm/button.h>
|
||||||
#include <gtkmm/comboboxentry.h>
|
#include <gtkmm/comboboxtext.h>
|
||||||
#include <gtkmm/label.h>
|
#include <gtkmm/label.h>
|
||||||
#include <gtkmm/liststore.h>
|
#include <gtkmm/liststore.h>
|
||||||
#include <gtkmm/treemodel.h>
|
#include <gtkmm/treemodel.h>
|
||||||
|
|
@ -35,12 +35,14 @@
|
||||||
class ExportPresetSelector : public Gtk::HBox
|
class ExportPresetSelector : public Gtk::HBox
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ExportPresetSelector ();
|
ExportPresetSelector (bool readonly = false);
|
||||||
|
|
||||||
void set_manager (boost::shared_ptr<ARDOUR::ExportProfileManager> manager);
|
void set_manager (boost::shared_ptr<ARDOUR::ExportProfileManager> manager);
|
||||||
|
|
||||||
sigc::signal<void> CriticalSelectionChanged;
|
sigc::signal<void> CriticalSelectionChanged;
|
||||||
|
|
||||||
|
Gtk::ComboBox& the_combo () { return combo; }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
typedef boost::shared_ptr<ARDOUR::ExportProfileManager> ManagerPtr;
|
typedef boost::shared_ptr<ARDOUR::ExportProfileManager> ManagerPtr;
|
||||||
typedef ARDOUR::ExportPresetPtr PresetPtr;
|
typedef ARDOUR::ExportPresetPtr PresetPtr;
|
||||||
|
|
@ -51,18 +53,19 @@ private:
|
||||||
void create_new ();
|
void create_new ();
|
||||||
void save_current ();
|
void save_current ();
|
||||||
void remove_current ();
|
void remove_current ();
|
||||||
|
void selection_changed ();
|
||||||
|
|
||||||
ManagerPtr profile_manager;
|
ManagerPtr profile_manager;
|
||||||
|
|
||||||
struct PresetCols : public Gtk::TreeModelColumnRecord {
|
struct PresetCols : public Gtk::TreeModelColumnRecord {
|
||||||
public:
|
public:
|
||||||
Gtk::TreeModelColumn<PresetPtr> preset;
|
|
||||||
Gtk::TreeModelColumn<std::string> label;
|
Gtk::TreeModelColumn<std::string> label;
|
||||||
|
Gtk::TreeModelColumn<PresetPtr> preset;
|
||||||
|
|
||||||
PresetCols ()
|
PresetCols ()
|
||||||
{
|
{
|
||||||
add (preset);
|
|
||||||
add (label);
|
add (label);
|
||||||
|
add (preset);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -71,8 +74,8 @@ private:
|
||||||
PresetPtr current;
|
PresetPtr current;
|
||||||
PresetPtr previous;
|
PresetPtr previous;
|
||||||
|
|
||||||
Gtk::Label label;
|
Gtk::Label label;
|
||||||
Gtk::ComboBoxEntry entry;
|
Gtk::ComboBox combo;
|
||||||
|
|
||||||
Gtk::Button save_button;
|
Gtk::Button save_button;
|
||||||
Gtk::Button remove_button;
|
Gtk::Button remove_button;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue