X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Feditor_cursors.cc;h=5dd1eb075bf9f6052f77027830eec1625d8587b1;hb=ce6c41c060c700489a9ac9fc5080bf2920c17ae2;hp=0afbee4fdd8b67bd13b0813f52c6ee0185828b0a;hpb=209d967b1bb80a9735d690d8f4f0455ecb9970ca;p=ardour.git diff --git a/gtk2_ardour/editor_cursors.cc b/gtk2_ardour/editor_cursors.cc index 0afbee4fdd..5dd1eb075b 100644 --- a/gtk2_ardour/editor_cursors.cc +++ b/gtk2_ardour/editor_cursors.cc @@ -21,47 +21,37 @@ #include #include -#include +#include #include "utils.h" #include "editor.h" -using namespace SigC; +using namespace sigc; using namespace ARDOUR; using namespace Gtk; -Editor::Cursor::Cursor (Editor& ed, const string& color, GtkSignalFunc callbck) - : editor (ed), callback (callbck), length(1.0) +Editor::Cursor::Cursor (Editor& ed, const string& color, bool (Editor::*callbck)(GdkEvent*,ArdourCanvas::Item*)) + : editor (ed), + canvas_item (*editor.cursor_group), + length(1.0) { - GtkCanvasGroup *group; - points = gtk_canvas_points_new (2); /* "randomly" initialize coords */ + + points.push_back(Gnome::Art::Point(-9383839.0, 0.0)); + points.push_back(Gnome::Art::Point(1.0, 0.0)); - points->coords[0] = -9383839.0; - points->coords[1] = 0.0; - points->coords[2] = 1.0; - points->coords[3] = 0.0; - - group = GTK_CANVAS_GROUP (editor.cursor_group); - - // cerr << "set cursor points, nc = " << points->num_points << endl; - canvas_item = gtk_canvas_item_new (group, - gtk_canvas_line_get_type(), - "points", points, - "fill_color", color.c_str(), - "width_pixels", 1, - "first_arrowhead", (gboolean) TRUE, - "last_arrowhead", (gboolean) TRUE, - "arrow_shape_a", 11.0, - "arrow_shape_b", 0.0, - "arrow_shape_c", 9.0, - NULL); - - // cerr << "cursor line @ " << canvas_item << endl; + canvas_item.property_points() = points; + canvas_item.property_fill_color() = color; //.c_str()); + 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; - gtk_object_set_data (GTK_OBJECT(canvas_item), "cursor", this); - gtk_signal_connect (GTK_OBJECT(canvas_item), "event", callback, &editor); + canvas_item.set_data ("cursor", this); + canvas_item.signal_event().connect (bind (mem_fun (ed, callbck), &canvas_item)); current_frame = 1; /* force redraw at 0 */ } @@ -69,8 +59,6 @@ Editor::Cursor::Cursor (Editor& ed, const string& color, GtkSignalFunc callbck) Editor::Cursor::~Cursor () { - gtk_object_destroy (GTK_OBJECT(canvas_item)); - gtk_canvas_points_unref (points); } void @@ -79,43 +67,38 @@ Editor::Cursor::set_position (jack_nframes_t frame) double new_pos = editor.frame_to_unit (frame); if (editor.session == 0) { - gtk_canvas_item_hide (canvas_item); + canvas_item.hide(); } else { - gtk_canvas_item_show (canvas_item); + canvas_item.show(); } current_frame = frame; - if (new_pos == points->coords[0]) { + if (new_pos != points.front().get_x()) { + + points.front().set_x (new_pos); + points.back().set_x (new_pos); - /* change in position is not visible, so just raise it */ - - gtk_canvas_item_raise_to_top (canvas_item); - return; - } + canvas_item.property_points() = points; - points->coords[0] = new_pos; - points->coords[2] = new_pos; + ArdourCanvas::Points p = canvas_item.property_points(); + } - // cerr << "set cursor2 al points, nc = " << points->num_points << endl; - gtk_canvas_item_set (canvas_item, "points", points, NULL); - gtk_canvas_item_raise_to_top (canvas_item); + canvas_item.raise_to_top(); } void Editor::Cursor::set_length (double units) { length = units; - points->coords[3] = points->coords[1] + length; - // cerr << "set cursor3 al points, nc = " << points->num_points << endl; - gtk_canvas_item_set (canvas_item, "points", points, NULL); + points.back().set_y (points.front().get_y() + length); + canvas_item.property_points() = points; } void Editor::Cursor::set_y_axis (double position) { - points->coords[1] = position; - points->coords[3] = position + length; - // cerr << "set cursor4 al points, nc = " << points->num_points << endl; - gtk_canvas_item_set (canvas_item, "points", points, NULL); + points.front().set_y (position); + points.back().set_y (position + length); + canvas_item.property_points() = points; }