X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fremote%2Ftrainpanel.cpp;h=ce46fa19dffaa86634df6553609c8a28f086878e;hb=f42183985c65e1e12f19e9246dee90b8e7e44a34;hp=e3db1badb3cfcd0c5451216c5497daf09ef7110c;hpb=010d8321e982d1684fcbff5bf6fc2bdec7cb7bae;p=r2c2.git diff --git a/source/remote/trainpanel.cpp b/source/remote/trainpanel.cpp index e3db1ba..ce46fa1 100644 --- a/source/remote/trainpanel.cpp +++ b/source/remote/trainpanel.cpp @@ -6,17 +6,21 @@ Distributed under the GPL */ #include +#include #include "libmarklin/locotype.h" #include "trainpanel.h" using namespace std; -TrainPanel::TrainPanel(Marklin::NetTrain &t): +TrainPanel::TrainPanel(Marklin::Client &c, Marklin::NetTrain &t): + client(c), train(t) { train.signal_name_changed.connect(sigc::mem_fun(this, &TrainPanel::name_changed)); train.signal_speed_changed.connect(sigc::mem_fun(this, &TrainPanel::speed_changed)); + train.signal_reverse_changed.connect(sigc::mem_fun(this, &TrainPanel::reverse_changed)); train.signal_function_changed.connect(sigc::mem_fun(this, &TrainPanel::function_changed)); + train.signal_route_changed.connect(sigc::mem_fun(this, &TrainPanel::route_changed)); train.signal_status_changed.connect(sigc::mem_fun(this, &TrainPanel::status_changed)); set_label(train.get_name()); @@ -25,13 +29,19 @@ TrainPanel::TrainPanel(Marklin::NetTrain &t): add(*manage(vbox)); vbox->set_border_width(5); - vbox->add(*manage(scl_speed = new Gtk::HScale)); + Gtk::HBox *hbox = new Gtk::HBox(false, 5); + vbox->add(*manage(hbox)); + + hbox->add(*manage(scl_speed = new Gtk::HScale)); scl_speed->set_digits(0); scl_speed->set_range(0, 14); scl_speed->set_increments(1, 1); - scl_speed->set_size_request(280, -1); + scl_speed->set_size_request(210, -1); scl_speed->signal_value_changed().connect(sigc::mem_fun(this, &TrainPanel::ui_speed_changed)); + hbox->add(*manage(chk_reverse = new Gtk::CheckButton("Rev"))); + chk_reverse->signal_toggled().connect(sigc::mem_fun(this, &TrainPanel::ui_reverse_changed)); + Gtk::HBox *func_box = new Gtk::HBox(false, 5); vbox->add(*manage(func_box)); const std::map &funcs = train.get_loco_type().get_functions(); @@ -43,6 +53,18 @@ TrainPanel::TrainPanel(Marklin::NetTrain &t): chk->signal_toggled().connect(sigc::bind(sigc::mem_fun(this, &TrainPanel::ui_function_changed), i->first)); } + Glib::RefPtr route_store = Gtk::ListStore::create(route_columns); + vbox->add(*manage(cmb_route = new Gtk::ComboBox(route_store))); + cmb_route->pack_start(route_columns.name); + route_store->append(); + const list &routes = client.get_routes(); + for(list::const_iterator i=routes.begin(); i!=routes.end(); ++i) + { + Gtk::TreeIter iter = route_store->append(); + (*iter)[route_columns.name] = *i; + } + cmb_route->signal_changed().connect(sigc::mem_fun(this, &TrainPanel::ui_route_changed)); + vbox->add(*manage(lbl_status = new Gtk::Label)); show_all(); @@ -63,6 +85,11 @@ void TrainPanel::speed_changed(unsigned speed) scl_speed->set_value(speed); } +void TrainPanel::reverse_changed(bool rev) +{ + chk_reverse->set_active(rev); +} + void TrainPanel::function_changed(unsigned func, bool set) { std::map::iterator i = chk_funcs.find(func); @@ -70,14 +97,42 @@ void TrainPanel::function_changed(unsigned func, bool set) i->second->set_active(set); } +void TrainPanel::route_changed(const string &route) +{ + Gtk::TreeNodeChildren children = cmb_route->get_model()->children(); + for(Gtk::TreeIter i=children.begin(); i!=children.end(); ++i) + if((*i)[route_columns.name]==route) + { + cmb_route->set_active(i); + break; + } +} + void TrainPanel::ui_speed_changed() { train.set_speed(static_cast(scl_speed->get_value())); } +void TrainPanel::ui_reverse_changed() +{ + train.set_reverse(chk_reverse->get_active()); +} + void TrainPanel::ui_function_changed(unsigned func) { std::map::iterator i = chk_funcs.find(func); if(i!=chk_funcs.end()) train.set_function(func, i->second->get_active()); } + +void TrainPanel::ui_route_changed() +{ + Gtk::TreeIter iter = cmb_route->get_active(); + train.set_route(Glib::ustring((*iter)[route_columns.name])); +} + + +TrainPanel::RouteRecord::RouteRecord() +{ + add(name); +}