X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Froutebar.cpp;h=ef9eb4891bda896d861f8de9fa2f9aaad9e10ae6;hb=abed4a255060d5a233ec0ac2dd60af9132e29201;hp=cebd1d76edabeb06d85dc85ce066306f278a9a02;hpb=eb9c7f5200da4f3f31b41233be8cee397cb6abb9;p=r2c2.git diff --git a/source/designer/routebar.cpp b/source/designer/routebar.cpp index cebd1d7..ef9eb48 100644 --- a/source/designer/routebar.cpp +++ b/source/designer/routebar.cpp @@ -7,68 +7,63 @@ using namespace std; using namespace Msp; using namespace R2C2; +string route_name(Route *const &route) +{ + return route ? route->get_name() : "(new route)"; +} + Routebar::Routebar(Designer &d): - Toolbar("Route", 370), - designer(d) + Toolbar("Route"), + designer(d), + routes(&route_name) { - pnl_content->add(*(drp_routes = new GLtk::Dropdown)); - drp_routes->set_geometry(GLtk::Geometry(0, 10, 250, 20)); + pnl_content->add(*(drp_routes = new GLtk::Dropdown(routes))); drp_routes->set_tooltip("Select route to edit"); - drp_routes->append("(new route)"); drp_routes->signal_item_selected.connect(sigc::mem_fun(this, &Routebar::route_selected)); GLtk::Button *btn; pnl_content->add(*(btn = new GLtk::Button("Del"))); - btn->set_geometry(GLtk::Geometry(250, 10, 40, 24)); btn->set_style("red"); btn->set_tooltip("Delete the current route"); btn->signal_clicked.connect(sigc::mem_fun(this, &Routebar::delete_route_clicked)); pnl_content->add(*(btn = new GLtk::Button("Name"))); - btn->set_geometry(GLtk::Geometry(290, 10, 40, 24)); btn->set_tooltip("Rename the current route"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::rename_route)); pnl_content->add(*(btn = new GLtk::Button("Add"))); - btn->set_geometry(GLtk::Geometry(330, 10, 40, 24)); btn->set_tooltip("Add selected tracks to current route (A)"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::add_selection_to_route)); designer.get_layout().signal_track_chain_added.connect(sigc::mem_fun(this, &Routebar::track_chain_added)); - designer.get_layout().signal_track_chain_removed.connect(sigc::hide(sigc::mem_fun(this, &Routebar::update_routes))); + designer.get_layout().signal_track_chain_removed.connect(sigc::mem_fun(this, &Routebar::track_chain_removed)); - const set &routes = designer.get_layout().get_all(); - for(set::const_iterator i=routes.begin(); i!=routes.end(); ++i) - (*i)->signal_name_changed.connect(sigc::hide(sigc::mem_fun(this, &Routebar::update_routes))); + const set &lroutes = designer.get_layout().get_all(); + for(set::const_iterator i=lroutes.begin(); i!=lroutes.end(); ++i) + { + routes.append(*i); + (*i)->signal_name_changed.connect(sigc::bind(sigc::mem_fun(this, &Routebar::route_name_changed), *i)); + } - update_routes(); + routes.append(0); } -void Routebar::route_selected(unsigned index, const string &) +void Routebar::route_selected(unsigned index) { - if(index==drp_routes->get_n_items()-1) + if(index==routes.size()-1) { Layout &rlayout = designer.get_layout(); Route *route = new Route(rlayout); - const set &routes = rlayout.get_all(); - route->set_name(format("Route %d", routes.size())); + route->set_name(format("Route %d", index+1)); designer.edit_route(route); - int selected = -1; - unsigned n = 0; - for(set::const_iterator i=routes.begin(); (selected<0 && i!=routes.end()); ++i, ++n) - if(*i==route) - selected = n; - drp_routes->set_selected_index(selected); + for(unsigned i=0; iset_selected_index(i); } else - { - const set &routes = designer.get_layout().get_all(); - set::const_iterator i = routes.begin(); - advance(i, index); - designer.edit_route(*i); - } + designer.edit_route(routes.get(index)); } void Routebar::delete_route_clicked() @@ -82,23 +77,25 @@ void Routebar::track_chain_added(TrackChain &tc) { if(Route *r = dynamic_cast(&tc)) { - r->signal_name_changed.connect(sigc::hide(sigc::mem_fun(this, &Routebar::update_routes))); - update_routes(); + r->signal_name_changed.connect(sigc::bind(sigc::mem_fun(this, &Routebar::route_name_changed), r)); + routes.insert(routes.size()-1, r); } } -void Routebar::update_routes() +void Routebar::track_chain_removed(TrackChain &tc) { - drp_routes->clear(); - const set &routes = designer.get_layout().get_all(); - int selected = -1; - unsigned n = 0; - for(set::const_iterator i=routes.begin(); i!=routes.end(); ++i, ++n) + if(Route *r = dynamic_cast(&tc)) { - drp_routes->append((*i)->get_name()); - if(*i==designer.get_current_route()) - selected = n; + for(unsigned i=0; iappend("(new route)"); - drp_routes->set_selected_index(selected); +} + +void Routebar::route_name_changed(const string &, Route *route) +{ + routes.refresh(route); }