X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fdesigner%2Ftoolbar.cpp;h=36b4882a00a7878730ff850589b2e695333d0683;hb=651698847d5293cfb15b6fb23a394701388c0151;hp=12c8388acd718270641aa799e2f368827c2c6e29;hpb=1ba0bd68483b900a702c7a38f41250b33770503d;p=r2c2.git diff --git a/source/designer/toolbar.cpp b/source/designer/toolbar.cpp index 12c8388..36b4882 100644 --- a/source/designer/toolbar.cpp +++ b/source/designer/toolbar.cpp @@ -1,12 +1,13 @@ /* $Id$ This file is part of the MSP Märklin suite -Copyright © 2009 Mikkosoft Productions, Mikko Rasa +Copyright © 2009-2010 Mikkosoft Productions, Mikko Rasa Distributed under the GPL */ #include #include +#include "libmarklin/route.h" #include "designer.h" #include "toolbar.h" @@ -19,39 +20,53 @@ Toolbar::Toolbar(Designer &d): GLtk::Panel(d.get_ui_resources()), designer(d) { - set_size(370, 40); + set_size(410, 40); GLtk::Button *btn; GLtk::Label *lbl; add(*(btn=new GLtk::Button(res, "Load"))); btn->set_geometry(GLtk::Geometry(5, 10, 40, 24)); + btn->set_tooltip("Load layout (not implemented)"); add(*(btn=new GLtk::Button(res, "Save"))); btn->set_geometry(GLtk::Geometry(45, 10, 40, 24)); + btn->set_tooltip("Save current layout"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::save)); add(*(btn=new GLtk::Button(res, "Quit"))); btn->set_geometry(GLtk::Geometry(85, 10, 40, 24)); btn->set_style("red"); + btn->set_tooltip("Exit Designer"); btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::quit)); - add(*(btn=new GLtk::Button(res, "Trnt"))); + add(*(btn=new GLtk::Button(res, "NewT"))); 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)); - add(*(btn=new GLtk::Button(res, "Sens"))); + add(*(btn=new GLtk::Button(res, "Trnt"))); btn->set_geometry(GLtk::Geometry(175, 10, 40, 24)); + btn->set_tooltip("Set turnout ID of selected track"); + btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::set_turnout_id)); + + add(*(btn=new GLtk::Button(res, "Sens"))); + btn->set_geometry(GLtk::Geometry(215, 10, 40, 24)); + btn->set_tooltip("Set sensor ID of selected tracks"); + btn->signal_clicked.connect(sigc::mem_fun(&designer, &Designer::set_sensor_id)); add(*(lbl=new GLtk::Label(res, "Routes:"))); - lbl->set_geometry(GLtk::Geometry(225, 22, 40, 13)); + lbl->set_geometry(GLtk::Geometry(265, 22, 40, 13)); add(*(drp_routes=new GLtk::Dropdown(res))); - drp_routes->set_geometry(GLtk::Geometry(225, 5, 100, 17)); + drp_routes->set_geometry(GLtk::Geometry(265, 5, 100, 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(325, 10, 40, 24)); + btn->set_geometry(GLtk::Geometry(365, 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))); @@ -68,33 +83,33 @@ void Toolbar::route_selected(unsigned index, const string &) designer.get_layout()->add_route(*route); designer.edit_route(*route); - const set &routes = designer.get_layout()->get_routes(); + const map &routes = designer.get_layout()->get_routes(); int selected = -1; unsigned n = 0; - for(set::const_iterator i=routes.begin(); (selected<0 && i!=routes.end()); ++i, ++n) - if(*i==route) + for(map::const_iterator i=routes.begin(); (selected<0 && i!=routes.end()); ++i, ++n) + if(i->second==route) selected = n; drp_routes->set_selected_index(selected); } else { - const set &routes = designer.get_layout()->get_routes(); - set::const_iterator i = routes.begin(); + const map &routes = designer.get_layout()->get_routes(); + map::const_iterator i = routes.begin(); advance(i, index); - designer.edit_route(**i); + designer.edit_route(*i->second); } } void Toolbar::update_routes() { drp_routes->clear(); - const set &routes = designer.get_layout()->get_routes(); + const map &routes = designer.get_layout()->get_routes(); int selected = -1; unsigned n = 0; - for(set::const_iterator i=routes.begin(); i!=routes.end(); ++i, ++n) + for(map::const_iterator i=routes.begin(); i!=routes.end(); ++i, ++n) { - drp_routes->append((*i)->get_name()); - if(*i==designer.get_current_route()) + drp_routes->append(i->second->get_name()); + if(i->second==designer.get_current_route()) selected = n; } drp_routes->append("(new route)");