X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Foption_editor.h;h=c6f13049b0adae59ce81463f82d5424531861bba;hb=ed990de6040215412baf8f448b1876d78bd9cc19;hp=7754b0555dc747b9e25dc23f616c84199800a424;hpb=99904735e066804358f1d0bd138a84f1e9ecda91;p=ardour.git diff --git a/gtk2_ardour/option_editor.h b/gtk2_ardour/option_editor.h index 7754b0555d..c6f13049b0 100644 --- a/gtk2_ardour/option_editor.h +++ b/gtk2_ardour/option_editor.h @@ -1,5 +1,8 @@ +#ifndef __gtk_ardour_option_editor_h__ +#define __gtk_ardour_option_editor_h__ + /* - Copyright (C) 2001 Paul Davis + Copyright (C) 2001 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,8 +20,7 @@ */ -#ifndef __gtk_ardour_option_editor_h__ -#define __gtk_ardour_option_editor_h__ +#include #include #include @@ -45,7 +47,7 @@ class IOSelector; class GainMeter; class PannerUI; -class OptionEditor : public Gtk::Dialog +class OptionEditor : public ArdourDialog { public: OptionEditor (ARDOUR_UI&, PublicEditor&, Mixer_UI&); @@ -66,6 +68,7 @@ class OptionEditor : public Gtk::Dialog gint wm_close (GdkEventAny *); bool focus_out_event_handler (GdkEventFocus*, void (OptionEditor::*pmf)()); + void parameter_changed (const char* name); /* paths */ @@ -77,18 +80,32 @@ class OptionEditor : public Gtk::Dialog void remove_session_paths (); void raid_path_changed (); - /* fades */ + /* misc */ + + Gtk::VBox misc_packer; - Gtk::VBox fade_packer; Gtk::Adjustment short_xfade_adjustment; Gtk::HScale short_xfade_slider; Gtk::Adjustment destructo_xfade_adjustment; Gtk::HScale destructo_xfade_slider; - void setup_fade_options(); + void setup_misc_options(); + void short_xfade_adjustment_changed (); void destructo_xfade_adjustment_changed (); + Gtk::Adjustment history_depth; + Gtk::Adjustment saved_history_depth; + Gtk::SpinButton history_depth_spinner; + Gtk::SpinButton saved_history_depth_spinner; + Gtk::CheckButton limit_history_button; + Gtk::CheckButton save_history_button; + + void history_depth_changed(); + void saved_history_depth_changed(); + void save_history_toggled (); + void limit_history_toggled (); + /* Sync */ Gtk::VBox sync_packer; @@ -96,11 +113,13 @@ class OptionEditor : public Gtk::Dialog Gtk::ComboBoxText slave_type_combo; AudioClock smpte_offset_clock; Gtk::CheckButton smpte_offset_negative_button; + Gtk::CheckButton synced_timecode_button; void setup_sync_options (); void smpte_offset_chosen (); void smpte_offset_negative_clicked (); + void synced_timecode_toggled (); /* MIDI */ @@ -109,19 +128,32 @@ class OptionEditor : public Gtk::Dialog Gtk::RadioButton::Group mtc_button_group; Gtk::RadioButton::Group mmc_button_group; Gtk::RadioButton::Group midi_button_group; + Gtk::RadioButton::Group midi_clock_button_group; + + Gtk::Table midi_port_table; + std::vector midi_port_table_widgets; + Gtk::Adjustment mmc_receive_device_id_adjustment; + Gtk::SpinButton mmc_receive_device_id_spinner; + Gtk::Adjustment mmc_send_device_id_adjustment; + Gtk::SpinButton mmc_send_device_id_spinner; + Gtk::Button add_midi_port_button; - Gtk::Adjustment mmc_device_id_adjustment; - Gtk::SpinButton mmc_device_id_spinner; + void add_midi_port (); + void remove_midi_port (MIDI::Port*); + void redisplay_midi_ports (); void port_online_toggled (MIDI::Port*,Gtk::ToggleButton*); void port_trace_in_toggled (MIDI::Port*,Gtk::ToggleButton*); void port_trace_out_toggled (MIDI::Port*,Gtk::ToggleButton*); - - void mmc_port_chosen (MIDI::Port*,Gtk::RadioButton*); - void mtc_port_chosen (MIDI::Port*,Gtk::RadioButton*); - void midi_port_chosen (MIDI::Port*,Gtk::RadioButton*); - void mmc_device_id_adjusted (); + void mmc_port_chosen (MIDI::Port*,Gtk::RadioButton*, Gtk::Button*); + void mtc_port_chosen (MIDI::Port*,Gtk::RadioButton*, Gtk::Button*); + void midi_port_chosen (MIDI::Port*,Gtk::RadioButton*, Gtk::Button*); + void midi_clock_port_chosen (MIDI::Port*,Gtk::RadioButton*, Gtk::Button*); + bool port_removable (MIDI::Port*); + + void mmc_receive_device_id_adjusted (); + void mmc_send_device_id_adjusted (); void map_port_online (MIDI::Port*, Gtk::ToggleButton*); @@ -130,7 +162,8 @@ class OptionEditor : public Gtk::Dialog enum PortIndex { MtcIndex = 0, MmcIndex = 1, - MidiIndex = 2 + MidiIndex = 2, + MidiClockIndex = 3 }; std::map > port_toggle_buttons; @@ -155,7 +188,7 @@ class OptionEditor : public Gtk::Dialog void click_browse_clicked (); void click_emphasis_browse_clicked (); - + void click_sound_changed (); void click_emphasis_sound_changed (); @@ -175,6 +208,7 @@ class OptionEditor : public Gtk::Dialog /* keyboard/mouse */ Gtk::Table keyboard_mouse_table; + Gtk::ComboBoxText keyboard_layout_selector; Gtk::ComboBoxText edit_modifier_combo; Gtk::ComboBoxText delete_modifier_combo; Gtk::ComboBoxText snap_modifier_combo; @@ -183,12 +217,15 @@ class OptionEditor : public Gtk::Dialog Gtk::Adjustment edit_button_adjustment; Gtk::SpinButton edit_button_spin; + std::map bindings_files; + void setup_keyboard_options (); void delete_modifier_chosen (); void edit_modifier_chosen (); void snap_modifier_chosen (); void edit_button_changed (); void delete_button_changed (); + void bindings_changed (); void fixup_combo_size (Gtk::ComboBoxText&, std::vector& strings); };