X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Froutebar.cpp;h=9726b2e88f8c853a05f995483e68eafefe67cc4f;hb=0a370f46322b0d6b804801bed042817fb8f98408;hp=0a2b9799d2d41171aea67fe7ce7f77cfb253c50c;hpb=c6b9a38300cc2ecfc0df66af162620b9ea5a1e3e;p=r2c2.git diff --git a/source/designer/routebar.cpp b/source/designer/routebar.cpp index 0a2b979..9726b2e 100644 --- a/source/designer/routebar.cpp +++ b/source/designer/routebar.cpp @@ -1,11 +1,4 @@ -/* $Id$ - -This file is part of R²C² -Copyright © 2010 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - -#include +#include #include "libr2c2/route.h" #include "designer.h" #include "routebar.h" @@ -15,11 +8,10 @@ using namespace Msp; using namespace R2C2; Routebar::Routebar(Designer &d): - Toolbar("Route", 370), + Toolbar("Route"), designer(d) { pnl_content->add(*(drp_routes = new GLtk::Dropdown)); - drp_routes->set_geometry(GLtk::Geometry(0, 10, 250, 20)); 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)); @@ -27,24 +19,22 @@ Routebar::Routebar(Designer &d): 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"); + 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_route_added.connect(sigc::mem_fun(this, &Routebar::route_added)); - designer.get_layout().signal_route_removed.connect(sigc::hide(sigc::mem_fun(this, &Routebar::update_routes))); + 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))); - const set &routes = designer.get_layout().get_routes(); + 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))); @@ -55,9 +45,9 @@ void Routebar::route_selected(unsigned index, const string &) { if(index==drp_routes->get_n_items()-1) { - Layout &layout = designer.get_layout(); - const set &routes = layout.get_routes(); - Route *route = new Route(layout); + Layout &rlayout = designer.get_layout(); + Route *route = new Route(rlayout); + const set &routes = rlayout.get_all(); route->set_name(format("Route %d", routes.size())); designer.edit_route(route); @@ -70,7 +60,7 @@ void Routebar::route_selected(unsigned index, const string &) } else { - const set &routes = designer.get_layout().get_routes(); + const set &routes = designer.get_layout().get_all(); set::const_iterator i = routes.begin(); advance(i, index); designer.edit_route(*i); @@ -84,16 +74,19 @@ void Routebar::delete_route_clicked() delete route; } -void Routebar::route_added(Route &r) +void Routebar::track_chain_added(TrackChain &tc) { - r.signal_name_changed.connect(sigc::hide(sigc::mem_fun(this, &Routebar::update_routes))); - update_routes(); + if(Route *r = dynamic_cast(&tc)) + { + r->signal_name_changed.connect(sigc::hide(sigc::mem_fun(this, &Routebar::update_routes))); + update_routes(); + } } void Routebar::update_routes() { drp_routes->clear(); - const set &routes = designer.get_layout().get_routes(); + 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)