X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Feditor_cursors.cc;h=ee8253fed8dee27feb9f9d617ea8a22e77e6c8c8;hb=9cdb0e2765df8fb12817df4367f503048be6f738;hp=b012b97fe983a8976ba5aadd91f40ae30fd070dd;hpb=d1a05240efc9816b4358cdeab458a54048abf9be;p=ardour.git diff --git a/gtk2_ardour/editor_cursors.cc b/gtk2_ardour/editor_cursors.cc index b012b97fe9..ee8253fed8 100644 --- a/gtk2_ardour/editor_cursors.cc +++ b/gtk2_ardour/editor_cursors.cc @@ -22,8 +22,8 @@ #include "canvas/canvas.h" #include "canvas/debug.h" +#include "canvas/scroll_group.h" -#include "utils.h" #include "editor_cursors.h" #include "editor.h" @@ -33,37 +33,45 @@ using namespace Gtk; EditorCursor::EditorCursor (Editor& ed, bool (Editor::*callbck)(GdkEvent*,ArdourCanvas::Item*)) : _editor (ed) - , _time_bars_canvas_item (_editor._time_bars_canvas->root ()) - , _track_canvas_item (_editor._track_canvas->root ()) - , _length (1.0) + , _track_canvas_item (new ArdourCanvas::Arrow (_editor.get_cursor_scroll_group())) { - CANVAS_DEBUG_NAME ((&_time_bars_canvas_item), "timebars editor cursor"); - CANVAS_DEBUG_NAME ((&_track_canvas_item), "track canvas editor cursor"); + CANVAS_DEBUG_NAME (_track_canvas_item, "track canvas editor cursor"); - _time_bars_canvas_item.set_outline_width (1); - _track_canvas_item.set_outline_width (1); + _track_canvas_item->set_show_head (0, true); + _track_canvas_item->set_head_height (0, 9); + _track_canvas_item->set_head_width (0, 16); + _track_canvas_item->set_head_outward (0, false); + _track_canvas_item->set_show_head (1, false); // head only + _track_canvas_item->set_data ("cursor", this); - _time_bars_canvas_item.set_show_head (0, true); - _time_bars_canvas_item.set_head_height (0, 9); - _time_bars_canvas_item.set_head_width (0, 16); - _time_bars_canvas_item.set_head_outward (0, false); - _time_bars_canvas_item.set_show_head (1, false); // head only + _track_canvas_item->Event.connect (sigc::bind (sigc::mem_fun (ed, callbck), _track_canvas_item)); - _time_bars_canvas_item.set_data ("cursor", this); - _track_canvas_item.set_data ("cursor", this); + _track_canvas_item->set_y1 (ArdourCanvas::COORD_MAX); - _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)); + _track_canvas_item->set_x (0); + + _current_frame = 1; /* force redraw at 0 */ +} - _time_bars_canvas_item.set_y1 (ArdourCanvas::COORD_MAX); - _track_canvas_item.set_y1 (ArdourCanvas::COORD_MAX); +EditorCursor::EditorCursor (Editor& ed) + : _editor (ed) + , _track_canvas_item (new ArdourCanvas::Arrow (_editor.get_hscroll_group())) +{ + CANVAS_DEBUG_NAME (_track_canvas_item, "track canvas cursor"); + + _track_canvas_item->set_show_head (0, false); + _track_canvas_item->set_show_head (1, false); + _track_canvas_item->set_y1 (ArdourCanvas::COORD_MAX); + _track_canvas_item->set_ignore_events (true); + _track_canvas_item->set_x (0); + _current_frame = 1; /* force redraw at 0 */ } EditorCursor::~EditorCursor () { - + delete _track_canvas_item; } void @@ -71,37 +79,35 @@ EditorCursor::set_position (framepos_t frame) { PositionChanged (frame); - double const new_pos = _editor.sample_to_pixel (frame); + double const new_pos = _editor.sample_to_pixel_unrounded (frame); - if (new_pos != _time_bars_canvas_item.x ()) { - _time_bars_canvas_item.set_x (new_pos); + if (new_pos != _track_canvas_item->x ()) { + _track_canvas_item->set_x (new_pos); } - if (new_pos != _track_canvas_item.x0 ()) { - _track_canvas_item.set_x0 (new_pos); - _track_canvas_item.set_x1 (new_pos); - } - _current_frame = frame; } void EditorCursor::show () { - _time_bars_canvas_item.show (); - _track_canvas_item.show (); + _track_canvas_item->show (); } void EditorCursor::hide () { - _time_bars_canvas_item.hide (); - _track_canvas_item.hide (); + _track_canvas_item->hide (); } void EditorCursor::set_color (ArdourCanvas::Color color) { - _time_bars_canvas_item.set_color (color); - _track_canvas_item.set_outline_color (color); + _track_canvas_item->set_color (color); +} + +void +EditorCursor::set_sensitive (bool yn) +{ + _track_canvas_item->set_ignore_events (!yn); }