X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=synfig-studio%2Ftrunk%2Fsrc%2Fgtkmm%2Fdock_timetrack.cpp;h=f08152065672f399fc4c149458aa42aba5d10bd6;hb=cf8349439dd89fa8a149283b00d525ebf96f1124;hp=8b1e3129ce04e363b3cd75b2819eee000c031dd3;hpb=8ef042c40521681cea99944097c4f90a5ac6cf74;p=synfig.git diff --git a/synfig-studio/trunk/src/gtkmm/dock_timetrack.cpp b/synfig-studio/trunk/src/gtkmm/dock_timetrack.cpp index 8b1e312..f081520 100644 --- a/synfig-studio/trunk/src/gtkmm/dock_timetrack.cpp +++ b/synfig-studio/trunk/src/gtkmm/dock_timetrack.cpp @@ -6,7 +6,7 @@ ** ** \legal ** Copyright (c) 2002-2005 Robert B. Quattlebaum Jr., Adrian Bentley -** Copyright (c) 2007 Chris Moore +** Copyright (c) 2007, 2008 Chris Moore ** ** This package is free software; you can redistribute it and/or ** modify it under the terms of the GNU General Public License as @@ -45,6 +45,7 @@ #include "widget_timeslider.h" #include "layerparamtreestore.h" #include "general.h" +#include #endif @@ -68,7 +69,7 @@ class TimeTrackView : public Gtk::TreeView Gtk::TreeView *mimic_tree_view; public: - sigc::signal signal_waypoint_clicked; + sigc::signal >,int,synfig::Waypoint::Side> signal_waypoint_clicked_timetrackview; LayerParamTreeStore::Model model; @@ -88,7 +89,7 @@ public: // Set up the value-node cell-renderer cellrenderer_time_track=LayerParamTreeStore::add_cell_renderer_value_node(column); cellrenderer_time_track->property_mode()=Gtk::CELL_RENDERER_MODE_ACTIVATABLE; - cellrenderer_time_track->signal_waypoint_clicked().connect(sigc::mem_fun(*this, &TimeTrackView::on_waypoint_clicked) ); + cellrenderer_time_track->signal_waypoint_clicked_cellrenderer().connect(sigc::mem_fun(*this, &TimeTrackView::on_waypoint_clicked_timetrackview) ); cellrenderer_time_track->signal_waypoint_changed().connect(sigc::mem_fun(*this, &TimeTrackView::on_waypoint_changed) ); column->add_attribute(cellrenderer_time_track->property_value_desc(), model.value_desc); column->add_attribute(cellrenderer_time_track->property_canvas(), model.canvas); @@ -365,32 +366,29 @@ public: } void - on_waypoint_clicked(const Glib::ustring &/*path_string*/, synfig::Waypoint waypoint,int button) + on_waypoint_clicked_timetrackview(const etl::handle& node, + const synfig::Time& time, + const synfig::Time& time_offset __attribute__ ((unused)), + int button, + synfig::Waypoint::Side side) { -/* - Gtk::TreePath path(path_string); + std::set > waypoint_set; + synfig::waypoint_collect(waypoint_set,time,node); - const Gtk::TreeRow row = *(get_model()->get_iter(path)); - if(!row) - return; -*/ - - ValueNode::Handle value_node(waypoint.get_parent_value_node()); - assert(value_node); + synfigapp::ValueDesc value_desc; - Gtk::TreeRow row; - if(!param_tree_store_->find_first_value_node(value_node, row)) + if (waypoint_set.size() == 1) { - synfig::error(__FILE__":%d: Unable to find the valuenode",__LINE__); - return; - } + ValueNode::Handle value_node(waypoint_set.begin()->get_parent_value_node()); + assert(value_node); - if(!row) - return; - - synfigapp::ValueDesc value_desc(static_cast(row[model.value_desc])); + Gtk::TreeRow row; + if (param_tree_store_->find_first_value_node(value_node, row) && row) + value_desc = static_cast(row[model.value_desc]); + } - signal_waypoint_clicked(value_desc,waypoint,button); + if (!waypoint_set.empty()) + signal_waypoint_clicked_timetrackview(value_desc,waypoint_set,button,side); } }; @@ -442,7 +440,7 @@ Dock_Timetrack::init_canvas_view_vfunc(etl::loose_handle canvas_view Gtk::TreeView* param_tree_view(dynamic_cast(canvas_view->get_ext_widget("params"))); tree_view->mimic(param_tree_view); - tree_view->signal_waypoint_clicked.connect(sigc::mem_fun(*canvas_view, &studio::CanvasView::on_waypoint_clicked)); + tree_view->signal_waypoint_clicked_timetrackview.connect(sigc::mem_fun(*canvas_view, &studio::CanvasView::on_waypoint_clicked_canvasview)); canvas_view->time_adjustment().signal_value_changed().connect(sigc::mem_fun(*tree_view,&Gtk::TreeView::queue_draw));