X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Ftoolbar.cpp;h=629205c6ce89cba05f2f2b77eaaf1583e6cd99f8;hb=cd6686b4821de95505ac94115e0966e4ff7cdc57;hp=36b4882a00a7878730ff850589b2e695333d0683;hpb=651698847d5293cfb15b6fb23a394701388c0151;p=r2c2.git diff --git a/source/designer/toolbar.cpp b/source/designer/toolbar.cpp index 36b4882..629205c 100644 --- a/source/designer/toolbar.cpp +++ b/source/designer/toolbar.cpp @@ -20,7 +20,7 @@ Toolbar::Toolbar(Designer &d): GLtk::Panel(d.get_ui_resources()), designer(d) { - set_size(410, 40); + set_size(640, 40); GLtk::Button *btn; GLtk::Label *lbl; @@ -40,7 +40,7 @@ Toolbar::Toolbar(Designer &d): btn->set_tooltip("Exit Designer"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::quit)); - add(*(btn=new GLtk::Button(res, "NewT"))); + add(*(btn=new GLtk::Button(res, "+Trk"))); btn->set_geometry(GLtk::Geometry(135, 10, 40, 24)); btn->set_tooltip("Add a track piece"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::new_track)); @@ -59,18 +59,33 @@ Toolbar::Toolbar(Designer &d): lbl->set_geometry(GLtk::Geometry(265, 22, 40, 13)); add(*(drp_routes=new GLtk::Dropdown(res))); - drp_routes->set_geometry(GLtk::Geometry(265, 5, 100, 17)); + drp_routes->set_geometry(GLtk::Geometry(265, 5, 250, 17)); drp_routes->set_tooltip("Select route to edit"); drp_routes->append("(new route)"); drp_routes->signal_item_selected.connect(sigc::mem_fun(this, &Toolbar::route_selected)); - add(*(btn=new GLtk::Button(res, "AddT"))); - btn->set_geometry(GLtk::Geometry(365, 10, 40, 24)); + add(*(btn=new GLtk::Button(res, "Del"))); + btn->set_geometry(GLtk::Geometry(515, 10, 40, 24)); + btn->set_tooltip("Delete the current route"); + btn->signal_clicked.connect(sigc::mem_fun(this, &Toolbar::delete_route_clicked)); + + add(*(btn=new GLtk::Button(res, "Name"))); + btn->set_geometry(GLtk::Geometry(555, 10, 40, 24)); + btn->set_tooltip("Rename the current route"); + btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::rename_route)); + + add(*(btn=new GLtk::Button(res, "Add"))); + btn->set_geometry(GLtk::Geometry(595, 10, 40, 24)); btn->set_tooltip("Add selected tracks to current route"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::add_selection_to_route)); - designer.get_layout()->signal_route_added.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes))); - designer.get_layout()->signal_route_removed.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes))); + designer.get_layout().signal_route_added.connect(sigc::mem_fun(this, &Toolbar::route_added)); + designer.get_layout().signal_route_removed.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes))); + + const set &routes = designer.get_layout().get_routes(); + for(set::const_iterator i=routes.begin(); i!=routes.end(); ++i) + (*i)->signal_name_changed.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes))); + update_routes(); } @@ -78,38 +93,51 @@ void Toolbar::route_selected(unsigned index, const string &) { if(index==drp_routes->get_n_items()-1) { - Layout &layout = *designer.get_layout(); - Route *route = new Route(layout, format("Route %d", layout.get_routes().size()+1)); - designer.get_layout()->add_route(*route); - designer.edit_route(*route); + Layout &layout = designer.get_layout(); + const set &routes = layout.get_routes(); + Route *route = new Route(layout); + route->set_name(format("Route %d", routes.size())); + designer.edit_route(route); - const map &routes = designer.get_layout()->get_routes(); int selected = -1; unsigned n = 0; - for(map::const_iterator i=routes.begin(); (selected<0 && i!=routes.end()); ++i, ++n) - if(i->second==route) + 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); } else { - const map &routes = designer.get_layout()->get_routes(); - map::const_iterator i = routes.begin(); + const set &routes = designer.get_layout().get_routes(); + set::const_iterator i = routes.begin(); advance(i, index); - designer.edit_route(*i->second); + designer.edit_route(*i); } } +void Toolbar::delete_route_clicked() +{ + Route *route = designer.get_current_route(); + designer.edit_route(0); + delete route; +} + +void Toolbar::route_added(Route &r) +{ + r.signal_name_changed.connect(sigc::hide(sigc::mem_fun(this, &Toolbar::update_routes))); + update_routes(); +} + void Toolbar::update_routes() { drp_routes->clear(); - const map &routes = designer.get_layout()->get_routes(); + const set &routes = designer.get_layout().get_routes(); int selected = -1; unsigned n = 0; - for(map::const_iterator i=routes.begin(); i!=routes.end(); ++i, ++n) + for(set::const_iterator i=routes.begin(); i!=routes.end(); ++i, ++n) { - drp_routes->append(i->second->get_name()); - if(i->second==designer.get_current_route()) + drp_routes->append((*i)->get_name()); + if(*i==designer.get_current_route()) selected = n; } drp_routes->append("(new route)");