r228@gwythaint (orig r768): fugalh | 2006-08-09 08:14:55 -0600
[ardour.git] / gtk2_ardour / public_editor.h
index 9e73596b9f5fe1d07a86ee8db30faca05fd4dff6..f70e4c20bd5ee163f2bbf7ea2ccfe581d21194bc 100644 (file)
@@ -7,6 +7,7 @@
 #include <glib.h>
 #include <gdk/gdktypes.h>
 #include <gtkmm/window.h>
+#include <gtkmm/actiongroup.h>
 #include <jack/types.h>
 #include <sigc++/signal.h>
 
@@ -38,7 +39,7 @@ class AutomationLine;
 class ControlPoint;
 class SelectionRect;
 class CrossfadeView;
-class AudioTimeAxisView;
+class RouteTimeAxisView;
 class AudioRegionView;
 class TempoMarker;
 class MeterMarker;
@@ -68,11 +69,11 @@ class PublicEditor : public Gtk::Window, public Stateful {
        virtual void set_mouse_mode (Editing::MouseMode, bool force = false) = 0;
        virtual void step_mouse_mode (bool next) = 0;
        virtual Editing::MouseMode current_mouse_mode () = 0;
-       virtual void add_imageframe_time_axis(std::string track_name, void*)  = 0;
-       virtual void add_imageframe_marker_time_axis(std::string track_name, TimeAxisView* marked_track, void*)  = 0;
+       virtual void add_imageframe_time_axis(const string & track_name, void*)  = 0;
+       virtual void add_imageframe_marker_time_axis(const string & track_name, TimeAxisView* marked_track, void*)  = 0;
        virtual void connect_to_image_compositor()  = 0;
        virtual void scroll_timeaxis_to_imageframe_item(const TimeAxisViewItem* item)  = 0;
-       virtual TimeAxisView* get_named_time_axis(std::string name)  = 0;
+       virtual TimeAxisView* get_named_time_axis(const string & name)  = 0;
        virtual void consider_auditioning (ARDOUR::Region&) = 0;
        virtual void set_show_waveforms (bool yn) = 0;
        virtual bool show_waveforms() const = 0;
@@ -94,6 +95,7 @@ class PublicEditor : public Gtk::Window, public Stateful {
        virtual bool show_measures () const = 0;
        virtual void export_session() = 0;
        virtual void export_selection() = 0;
+       virtual void export_range_markers() = 0;
        virtual void register_actions() = 0;
        virtual void add_toplevel_controls (Gtk::Container&) = 0;
        virtual void      set_zoom_focus (Editing::ZoomFocus) = 0;
@@ -102,14 +104,14 @@ class PublicEditor : public Gtk::Window, public Stateful {
        virtual PlaylistSelector& playlist_selector() const = 0;
        virtual void route_name_changed (TimeAxisView *) = 0;
        virtual void clear_playlist (ARDOUR::Playlist&) = 0;
+       virtual void new_playlists () = 0;
+       virtual void copy_playlists () = 0;
+       virtual void clear_playlists () = 0;
        virtual void set_selected_mixer_strip (TimeAxisView&) = 0;
-       virtual void unselect_strip_in_display (TimeAxisView& tv) = 0;
+       virtual void hide_track_in_display (TimeAxisView& tv) = 0;
        virtual void set_follow_playhead (bool yn) = 0;
        virtual void toggle_follow_playhead () = 0;
        virtual bool follow_playhead() const = 0;
-       virtual void toggle_xfade_visibility () = 0;
-       virtual void set_xfade_visibility (bool yn) = 0;
-       virtual bool xfade_visibility() const = 0;
        virtual void ensure_float (Gtk::Window&) = 0;
        virtual void show_window () = 0;
        virtual TrackViewList* get_valid_views (TimeAxisView*, ARDOUR::RouteGroup* grp = 0) = 0;
@@ -122,14 +124,16 @@ class PublicEditor : public Gtk::Window, public Stateful {
        virtual void prepare_for_cleanup () = 0;
        virtual void reposition_x_origin (jack_nframes_t frame) = 0;
        virtual void remove_last_capture () = 0;
+       virtual void maximise_editing_space() = 0;
+       virtual void restore_editing_space() = 0;
 
        sigc::signal<void,Editing::DisplayControl> DisplayControlChanged;
        sigc::signal<void> ZoomFocusChanged;
        sigc::signal<void> ZoomChanged;
-       sigc::signal<void> XOriginChanged;
        sigc::signal<void> Resized;
+       sigc::signal<void> Realized;
 
-       // FIXED FOR GTK2
+       Glib::RefPtr<Gtk::ActionGroup> editor_actions;
 
        virtual bool canvas_control_point_event (GdkEvent* event,ArdourCanvas::Item*, ControlPoint*) = 0;
        virtual bool canvas_line_event (GdkEvent* event,ArdourCanvas::Item*, AutomationLine*) = 0;
@@ -141,10 +145,10 @@ class PublicEditor : public Gtk::Window, public Stateful {
        virtual bool canvas_fade_in_handle_event (GdkEvent* event,ArdourCanvas::Item*, AudioRegionView*) = 0;
        virtual bool canvas_fade_out_event (GdkEvent* event,ArdourCanvas::Item*, AudioRegionView*) = 0;
        virtual bool canvas_fade_out_handle_event (GdkEvent* event,ArdourCanvas::Item*, AudioRegionView*) = 0;
-       virtual bool canvas_region_view_event (GdkEvent* event,ArdourCanvas::Item*, AudioRegionView*) = 0;
-       virtual bool canvas_region_view_name_highlight_event (GdkEvent* event,ArdourCanvas::Item*, AudioRegionView*) = 0;
-       virtual bool canvas_region_view_name_event (GdkEvent* event,ArdourCanvas::Item*, AudioRegionView*) = 0;
-       virtual bool canvas_stream_view_event (GdkEvent* event,ArdourCanvas::Item*, AudioTimeAxisView*) = 0;
+       virtual bool canvas_region_view_event (GdkEvent* event,ArdourCanvas::Item*, RegionView*) = 0;
+       virtual bool canvas_region_view_name_highlight_event (GdkEvent* event,ArdourCanvas::Item*, RegionView*) = 0;
+       virtual bool canvas_region_view_name_event (GdkEvent* event,ArdourCanvas::Item*, RegionView*) = 0;
+       virtual bool canvas_stream_view_event (GdkEvent* event,ArdourCanvas::Item*, RouteTimeAxisView*) = 0;
        virtual bool canvas_marker_event (GdkEvent* event,ArdourCanvas::Item*, Marker*) = 0;
        virtual bool canvas_zoom_rect_event (GdkEvent* event,ArdourCanvas::Item*) = 0;
        virtual bool canvas_tempo_marker_event (GdkEvent* event,ArdourCanvas::Item*, TempoMarker*) = 0;
@@ -169,4 +173,4 @@ class PublicEditor : public Gtk::Window, public Stateful {
        static PublicEditor* _instance;
 };
 
-#endif // __gtk_ardour_public_editor_h__ 
+#endif // __gtk_ardour_public_editor_h__