X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmarker.h;h=e9ff0501edc1fdc28ac908953d284355f8135978;hb=8dd31447be22c20a51f019c8ea77c27ba975815c;hp=77d2976dd1742d2ebbd16732b5c5915880e5a036;hpb=14d43ca9fe28a8309b4a52fa85e2b0c64a92248b;p=ardour.git diff --git a/gtk2_ardour/marker.h b/gtk2_ardour/marker.h index 77d2976dd1..e9ff0501ed 100644 --- a/gtk2_ardour/marker.h +++ b/gtk2_ardour/marker.h @@ -1,5 +1,5 @@ /* - 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 @@ -15,7 +15,6 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #ifndef __gtk_ardour_marker_h__ @@ -23,10 +22,15 @@ #include #include -#include -#include + +#include #include +#include "ardour/ardour.h" +#include "pbd/signals.h" + +#include "canvas.h" + namespace ARDOUR { class TempoSection; class MeterSection; @@ -41,48 +45,69 @@ class Marker : public sigc::trackable Mark, Tempo, Meter, - Start, - End, + Start, ///< session start + End, ///< session end LoopStart, LoopEnd, PunchIn, PunchOut }; - Marker (PublicEditor& editor, GnomeCanvasGroup *parent, guint32 rgba, const string& text, Type, - gint (*callback)(GnomeCanvasItem *, GdkEvent *, gpointer), jack_nframes_t frame = 0); + + Marker (PublicEditor& editor, ArdourCanvas::Group& parent, guint32 rgba, const std::string& text, Type, + nframes_t frame = 0, bool handle_events = true); + virtual ~Marker (); - void set_position (jack_nframes_t); - void set_name (const string&); + static PBD::Signal1 CatchDeletion; + + ArdourCanvas::Item& the_item() const; + + void add_line (ArdourCanvas::Group*, double y_origin, double initial_height); + void show_line (); + void hide_line (); + void set_line_vpos (double y_origin, double height); + + void set_position (nframes64_t); + void set_name (const std::string&); void set_color_rgba (uint32_t rgba); + nframes64_t position() const { return frame_position; } + + ArdourCanvas::Group * get_parent() { return _parent; } + void reparent (ArdourCanvas::Group & parent); + void hide (); void show (); Type type () { return _type; } - + protected: PublicEditor& editor; - GnomeCanvasItem *group; - GnomeCanvasItem *mark; - GnomeCanvasItem *text; - GnomeCanvasPoints *points; + Pango::FontDescription* name_font; + + ArdourCanvas::Group * _parent; + ArdourCanvas::Group *group; + ArdourCanvas::Polygon *mark; + ArdourCanvas::Pixbuf *name_pixbuf; + ArdourCanvas::Points *points; + ArdourCanvas::SimpleLine *line; + ArdourCanvas::Points *line_points; + + double unit_position; + nframes64_t frame_position; + unsigned char shift; /* should be double, but its always small and integral */ + Type _type; + int name_height; - double unit_position; - jack_nframes_t frame_position; - unsigned char shift; /* should be double, but its always small and integral */ - Type _type; - void reposition (); }; class TempoMarker : public Marker { public: - TempoMarker (PublicEditor& editor, GnomeCanvasGroup *parent, guint32 rgba, const string& text, ARDOUR::TempoSection&, - gint (*callback)(GnomeCanvasItem *, GdkEvent *, gpointer)); + TempoMarker (PublicEditor& editor, ArdourCanvas::Group& parent, guint32 rgba, const std::string& text, ARDOUR::TempoSection&); ~TempoMarker (); ARDOUR::TempoSection& tempo() const { return _tempo; } @@ -94,8 +119,7 @@ class TempoMarker : public Marker class MeterMarker : public Marker { public: - MeterMarker (PublicEditor& editor, GnomeCanvasGroup *parent, guint32 rgba, const string& text, ARDOUR::MeterSection&, - gint (*callback)(GnomeCanvasItem *, GdkEvent *, gpointer)); + MeterMarker (PublicEditor& editor, ArdourCanvas::Group& parent, guint32 rgba, const std::string& text, ARDOUR::MeterSection&); ~MeterMarker (); ARDOUR::MeterSection& meter() const { return _meter; }