OSC: Changed gainVCA to gainfader as VCA is already used.
[ardour.git] / gtk2_ardour / editor.h
index c38e355c05bd39a0a914d5f6e29b9776ef26cd65..5778a3cbbbb40d64e9b9ab51727a1d008418de03 100644 (file)
@@ -62,7 +62,6 @@
 #include "selection_memento.h"
 
 namespace Gtkmm2ext {
-       class TearOff;
        class Bindings;
 }
 
@@ -74,6 +73,7 @@ namespace ARDOUR {
        class Filter;
        class Location;
        class MidiOperator;
+       class MidiRegion;
        class MidiTrack;
        class Playlist;
        class Region;
@@ -113,6 +113,7 @@ class GroupedButtons;
 class GUIObjectState;
 class ArdourMarker;
 class MidiRegionView;
+class MidiExportDialog;
 class MixerStrip;
 class MouseCursors;
 class NoteBase;
@@ -141,6 +142,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void             set_session (ARDOUR::Session *);
        ARDOUR::Session* session() const { return _session; }
 
+       Gtk::Window* use_own_window (bool and_fill_it);
+
        void             first_idle ();
        virtual bool     have_idled () const { return _have_idled; }
 
@@ -271,8 +274,11 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        /* analysis window */
 
-       void analyze_region_selection();
-       void analyze_range_selection();
+       void loudness_analyze_region_selection();
+       void loudness_analyze_range_selection();
+
+       void spectral_analyze_region_selection();
+       void spectral_analyze_range_selection();
 
        /* export */
 
@@ -282,15 +288,14 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void export_range ();
        void export_region ();
 
-       void add_transport_frame (Gtk::Container&);
-       void add_toplevel_menu (Gtk::Container&);
-       Gtk::HBox& get_status_bar_packer()  { return status_bar_hpacker; }
+       bool process_midi_export_dialog (MidiExportDialog& dialog, boost::shared_ptr<ARDOUR::MidiRegion> midi_region);
 
        void               set_zoom_focus (Editing::ZoomFocus);
        Editing::ZoomFocus get_zoom_focus () const { return zoom_focus; }
        framecnt_t         get_current_zoom () const { return samples_per_pixel; }
        void               cycle_zoom_focus ();
        void temporal_zoom_step (bool coarser);
+       void temporal_zoom_step_mouse_focus (bool coarser);
        void ensure_time_axis_view_is_visible (TimeAxisView const & tav, bool at_top);
        void tav_zoom_step (bool coarser);
        void tav_zoom_smooth (bool coarser, bool force_all);
@@ -347,7 +352,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void set_summary ();
        void set_group_tabs ();
        void toggle_measure_visibility ();
-       void toggle_logo_visibility ();
 
        /* fades */
 
@@ -362,23 +366,24 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void ensure_float (Gtk::Window&);
 
-       void show_window ();
-
        void scroll_tracks_down_line ();
        void scroll_tracks_up_line ();
 
        bool scroll_up_one_track (bool skip_child_views = false);
        bool scroll_down_one_track (bool skip_child_views = false);
 
+       void scroll_left_step ();
+       void scroll_right_step ();
+
+       void scroll_left_half_page ();
+       void scroll_right_half_page ();
+
        void prepare_for_cleanup ();
        void finish_cleanup ();
 
        void maximise_editing_space();
        void restore_editing_space();
 
-       void update_tearoff_visibility();
-       void reattach_all_tearoffs ();
-
        double get_y_origin () const;
        void reset_x_origin (framepos_t);
        void reset_x_origin_to_follow_playhead ();
@@ -434,9 +439,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        TrackViewList axis_views_from_routes (boost::shared_ptr<ARDOUR::RouteList>) const;
 
-       Gtkmm2ext::TearOff* mouse_mode_tearoff () const { return _mouse_mode_tearoff; }
-       Gtkmm2ext::TearOff* tools_tearoff () const { return _tools_tearoff; }
-
        void snap_to (framepos_t&       first,
                      ARDOUR::RoundMode direction = ARDOUR::RoundNearest,
                      bool              for_mark  = false,
@@ -634,6 +636,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void remove_marker (ArdourCanvas::Item&, GdkEvent*);
        gint really_remove_marker (ARDOUR::Location* loc);
        void goto_nth_marker (int nth);
+       void trigger_script (int nth);
        void toggle_marker_lines ();
        void set_marker_line_visibility (bool);
 
@@ -771,9 +774,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void add_routes (ARDOUR::RouteList&);
        void timeaxisview_deleted (TimeAxisView *);
 
-       Gtk::HBox           global_hpacker;
-       Gtk::VBox           global_vpacker;
-       Gtk::VBox           vpacker;
+       Gtk::HBox global_hpacker;
+       Gtk::VBox global_vpacker;
 
        /* Cursor stuff.  Do not use directly, use via CursorContext. */
        friend class CursorContext;
@@ -808,15 +810,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Gtk::EventBox             time_bars_event_box;
        Gtk::VBox                 time_bars_vbox;
 
-       ArdourCanvas::Pixbuf     *logo_item;
-#if 0
-    /* these will be needed when we have canvas rulers */
-       ArdourCanvas::Container      *minsec_group;
-       ArdourCanvas::Container      *bbt_group;
-       ArdourCanvas::Container      *timecode_group;
-       ArdourCanvas::Container      *frame_group;
-#endif
-
        ArdourCanvas::Container      *tempo_group;
        ArdourCanvas::Container      *meter_group;
        ArdourCanvas::Container      *marker_group;
@@ -1181,8 +1174,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void register_region_actions ();
 
        void load_bindings ();
-       Gtkmm2ext::ActionMap editor_action_map;
-       Gtkmm2ext::Bindings  key_bindings;
 
        /* CUT/COPY/PASTE */
 
@@ -1283,7 +1274,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void naturalize_region ();
 
-       void reset_focus ();
+       void reset_focus (Gtk::Widget*);
 
        void split_region ();
 
@@ -1486,8 +1477,8 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void set_loop_start_from_edit_point ();
        void set_loop_end_from_edit_point ();
 
-       void keyboard_selection_begin ();
-       void keyboard_selection_finish (bool add);
+       void keyboard_selection_begin ( Editing::EditIgnoreOption = Editing::EDIT_IGNORE_NONE );
+       void keyboard_selection_finish (bool add, Editing::EditIgnoreOption = Editing::EDIT_IGNORE_NONE);
        bool have_pending_keyboard_selection;
        framepos_t pending_keyboard_selection_start;
 
@@ -1627,6 +1618,9 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void initialize_canvas ();
 
+       void manage_action_scripts ();
+       void set_script_action_name (int i, const std::string&);
+
        /* display control */
 
        bool _show_measures;
@@ -1741,7 +1735,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Gtk::Table               toolbar_selection_clock_table;
        Gtk::Label               toolbar_selection_cursor_label;
 
-       Gtkmm2ext::TearOff*      _mouse_mode_tearoff;
        ArdourButton mouse_select_button;
        ArdourButton mouse_draw_button;
        ArdourButton mouse_move_button;
@@ -1800,23 +1793,17 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        Glib::RefPtr<Gtk::RadioAction> zoom_focus_action (Editing::ZoomFocus);
 
        Gtk::HBox           _zoom_box;
-       Gtkmm2ext::TearOff* _zoom_tearoff;
        void                zoom_adjustment_changed();
 
        void setup_toolbar ();
 
        void setup_tooltips ();
 
-       Gtkmm2ext::TearOff*     _tools_tearoff;
        Gtk::HBox                toolbar_hbox;
        Gtk::EventBox            toolbar_base;
        Gtk::Frame               toolbar_frame;
        Gtk::Viewport           _toolbar_viewport;
 
-       /* midi toolbar */
-
-       Gtk::HBox                panic_box;
-
        void setup_midi_toolbar ();
 
        /* selection process */
@@ -1856,10 +1843,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        ArdourCanvas::Rectangle*  cd_marker_bar_drag_rect;
        ArdourCanvas::Rectangle*  range_bar_drag_rect;
        ArdourCanvas::Rectangle*  transport_bar_drag_rect;
-
-#ifdef GTKOSX
-       ArdourCanvas::Rectangle     *bogus_background_rect;
-#endif
        ArdourCanvas::Rectangle     *transport_bar_range_rect;
        ArdourCanvas::Rectangle     *transport_bar_preroll_rect;
        ArdourCanvas::Rectangle     *transport_bar_postroll_rect;
@@ -2039,9 +2022,7 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void cms_new (boost::shared_ptr<ARDOUR::Route>);
        void current_mixer_strip_hidden ();
 
-       void detach_tearoff (Gtk::Box* b, Gtk::Window* w);
-       void reattach_tearoff (Gtk::Box* b, Gtk::Window* w, int32_t n);
-#ifdef GTKOSX
+#ifdef __APPLE__
        void ensure_all_elements_drawn ();
 #endif
        /* nudging tracks */
@@ -2103,9 +2084,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        void toggle_gain_envelope_active ();
        void reset_region_gain_envelopes ();
 
-       bool on_key_press_event (GdkEventKey*);
-       bool on_key_release_event (GdkEventKey*);
-
        void session_state_saved (std::string);
 
        Glib::RefPtr<Gtk::Action>              undo_action;
@@ -2117,8 +2095,6 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
 
        void history_changed ();
 
-       Gtk::HBox      status_bar_hpacker;
-
        Editing::EditPoint _edit_point;
 
        ArdourDropdown edit_point_selector;
@@ -2259,6 +2235,14 @@ class Editor : public PublicEditor, public PBD::ScopedConnectionList, public ARD
        QuantizeDialog* quantize_dialog;
        MainMenuDisabler* _main_menu_disabler;
 
+       /* private helper functions to help with registering axis */
+
+       Glib::RefPtr<Gtk::Action> reg_sens (Glib::RefPtr<Gtk::ActionGroup> group, char const * name, char const * label, sigc::slot<void> slot);
+       void toggle_reg_sens (Glib::RefPtr<Gtk::ActionGroup> group, char const * name, char const * label, sigc::slot<void> slot);
+       void radio_reg_sens (Glib::RefPtr<Gtk::ActionGroup> action_group, Gtk::RadioAction::Group& radio_group, char const * name, char const * label, sigc::slot<void> slot);
+
+       Gtkmm2ext::ActionMap myactions;
+
        friend class Drag;
        friend class RegionDrag;
        friend class RegionMoveDrag;