summaryrefslogtreecommitdiff
path: root/gtk2_ardour/editor_cursors.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2013-04-04 00:32:52 -0400
committerPaul Davis <paul@linuxaudiosystems.com>2013-04-04 00:32:52 -0400
commitaaea166135ace01709f7e0be64f40be80f4107ec (patch)
tree0e794ef7a723e4aaf909b841a6816e405b4ceca1 /gtk2_ardour/editor_cursors.cc
parent1d8bac08c0c00d44e22c581768a275e1b21a99a7 (diff)
initial commit of hand merging, plus getting "ancient" waf script to work correctly
Diffstat (limited to 'gtk2_ardour/editor_cursors.cc')
-rw-r--r--gtk2_ardour/editor_cursors.cc82
1 files changed, 48 insertions, 34 deletions
diff --git a/gtk2_ardour/editor_cursors.cc b/gtk2_ardour/editor_cursors.cc
index ccacda210f..4a123f1e79 100644
--- a/gtk2_ardour/editor_cursors.cc
+++ b/gtk2_ardour/editor_cursors.cc
@@ -20,7 +20,7 @@
#include <cstdlib>
#include <cmath>
-#include <libgnomecanvas/libgnomecanvas.h>
+#include "canvas/canvas.h"
#include "utils.h"
#include "editor_cursors.h"
@@ -31,29 +31,36 @@ using namespace PBD;
using namespace Gtk;
EditorCursor::EditorCursor (Editor& ed, bool (Editor::*callbck)(GdkEvent*,ArdourCanvas::Item*))
- : editor (ed),
- canvas_item (*editor.cursor_group),
- length(1.0)
+ : _editor (ed)
+ , _time_bars_canvas_item (_editor._time_bars_canvas->root ())
+ , _track_canvas_item (_editor._track_canvas->root ())
+ , _length (1.0)
{
- points.push_back(Gnome::Art::Point(-1.0, 0.0)); // first x-coord needs to be a non-normal value
- points.push_back(Gnome::Art::Point(1.0, 1.0));
-
- canvas_item.property_points() = points;
- canvas_item.property_width_pixels() = 1;
- canvas_item.property_first_arrowhead() = TRUE;
- canvas_item.property_last_arrowhead() = TRUE;
- canvas_item.property_arrow_shape_a() = 11.0;
- canvas_item.property_arrow_shape_b() = 0.0;
- canvas_item.property_arrow_shape_c() = 9.0;
-
- canvas_item.set_data ("cursor", this);
- canvas_item.signal_event().connect (sigc::bind (sigc::mem_fun (ed, callbck), &canvas_item));
- current_frame = 1; /* force redraw at 0 */
+ _time_bars_canvas_item.set_outline_width (1);
+ _track_canvas_item.set_outline_width (1);
+
+ for (int i = 0; i < 2; ++i) {
+ _time_bars_canvas_item.set_show_head (i, true);
+ _time_bars_canvas_item.set_head_height (i, 18);
+ _time_bars_canvas_item.set_head_width (i, 15);
+ _time_bars_canvas_item.set_head_outward (i, false);
+ }
+
+ _time_bars_canvas_item.set_data ("cursor", this);
+ _track_canvas_item.set_data ("cursor", this);
+
+ _time_bars_canvas_item.Event.connect (sigc::bind (sigc::mem_fun (ed, callbck), &_time_bars_canvas_item));
+ _track_canvas_item.Event.connect (sigc::bind (sigc::mem_fun (ed, callbck), &_track_canvas_item));
+
+ _time_bars_canvas_item.set_y1 (ArdourCanvas::COORD_MAX);
+ _track_canvas_item.set_y1 (ArdourCanvas::COORD_MAX);
+
+ _current_frame = 1; /* force redraw at 0 */
}
EditorCursor::~EditorCursor ()
-
{
+
}
void
@@ -61,30 +68,37 @@ EditorCursor::set_position (framepos_t frame)
{
PositionChanged (frame);
- double new_pos = editor.frame_to_unit (frame);
-
- if (new_pos != points.front().get_x()) {
+ double const new_pos = _editor.frame_to_unit (frame);
- points.front().set_x (new_pos);
- points.back().set_x (new_pos);
+ if (new_pos != _time_bars_canvas_item.x ()) {
+ _time_bars_canvas_item.set_x (new_pos);
+ }
- canvas_item.property_points() = points;
+ if (new_pos != _track_canvas_item.x0 ()) {
+ _track_canvas_item.set_x0 (new_pos);
+ _track_canvas_item.set_x1 (new_pos);
}
- current_frame = frame;
+
+ _current_frame = frame;
+}
+
+void
+EditorCursor::show ()
+{
+ _time_bars_canvas_item.show ();
+ _track_canvas_item.show ();
}
void
-EditorCursor::set_length (double units)
+EditorCursor::hide ()
{
- length = units;
- points.back().set_y (points.front().get_y() + length);
- canvas_item.property_points() = points;
+ _time_bars_canvas_item.hide ();
+ _track_canvas_item.hide ();
}
void
-EditorCursor::set_y_axis (double position)
+EditorCursor::set_color (ArdourCanvas::Color color)
{
- points.front().set_y (position);
- points.back().set_y (position + length);
- canvas_item.property_points() = points;
+ _time_bars_canvas_item.set_color (color);
+ _track_canvas_item.set_outline_color (color);
}