Remove ardour_ui.h header inclusion
[ardour.git] / gtk2_ardour / editor_summary.h
index 6746849fe3700c3d60143a54569ba369ddfbc70b..588f7c0ed2fd691782a42c5a0cf48dd21e2ff5e9 100644 (file)
@@ -36,12 +36,16 @@ class EditorSummary : public CairoWidget, public EditorComponent, public ARDOUR:
 {
 public:
        EditorSummary (Editor *);
+       ~EditorSummary ();
 
        void set_session (ARDOUR::Session *);
        void set_overlays_dirty ();
+       void set_background_dirty ();
        void routes_added (std::list<RouteTimeAxisView*> const &);
 
 private:
+       void parameter_changed (std::string);
+       void on_size_allocate (Gtk::Allocation& alloc);
 
        enum Position {
                LEFT,
@@ -57,16 +61,19 @@ private:
                TO_LEFT_OR_RIGHT,
                OTHERWISE_OUTSIDE
        };
-
-       bool on_expose_event (GdkEventExpose *);
+      
        void on_size_request (Gtk::Requisition *);
        bool on_button_press_event (GdkEventButton *);
        bool on_button_release_event (GdkEventButton *);
        bool on_motion_notify_event (GdkEventMotion *);
        bool on_scroll_event (GdkEventScroll *);
+        bool on_key_press_event (GdkEventKey*);
+        bool on_key_release_event (GdkEventKey*);
+        bool on_enter_notify_event (GdkEventCrossing*); 
+        bool on_leave_notify_event (GdkEventCrossing*); 
 
        void centre_on_click (GdkEventButton *);
-       void render (cairo_t *);
+       void render (cairo_t *, cairo_rectangle_t*);
        void render_region (RegionView*, cairo_t*, double) const;
        void get_editor (std::pair<double, double> *, std::pair<double, double> *) const;
        void set_editor (double, double);
@@ -83,6 +90,9 @@ private:
        void set_cursor (Position);
        void route_gui_changed (std::string);
        bool suspending_editor_updates () const;
+       double playhead_frame_to_position (framepos_t) const;
+        framepos_t position_to_playhead_frame_to_position (double pos) const;
+       void set_overlays_dirty (int, int, int, int);
 
        framepos_t _start; ///< start frame of the overview
        framepos_t _end; ///< end frame of the overview
@@ -114,8 +124,12 @@ private:
        Position _zoom_position;
 
        bool _old_follow_playhead;
+       cairo_surface_t* _image;
+       void render_background_image ();
+       bool _background_dirty;
 
        PBD::ScopedConnectionList position_connection;
+       PBD::ScopedConnection route_ctrl_id_connection;
        PBD::ScopedConnectionList region_property_connection;
 };