X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fremote%2Ftrainpanel.cpp;h=26963a0537d6200af841108449669d1eba32c31b;hb=df88ff837468c32986c73740b4fc8279bc152e47;hp=45435d56fa1ebd4d8a65748a0843aecc1c00fa1b;hpb=378f04522aa762729c0d5651fb60ad7e4d8ba9f3;p=r2c2.git diff --git a/source/remote/trainpanel.cpp b/source/remote/trainpanel.cpp index 45435d5..26963a0 100644 --- a/source/remote/trainpanel.cpp +++ b/source/remote/trainpanel.cpp @@ -1,10 +1,3 @@ -/* $Id$ - -This file is part of the MSP Märklin suite -Copyright © 2009-2010 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - #include #include #include "remote.h" @@ -12,7 +5,7 @@ Distributed under the GPL using namespace std; -TrainPanel::TrainPanel(Remote &r, Marklin::Client &c, Marklin::NetTrain &t): +TrainPanel::TrainPanel(Remote &r, R2C2::Client &c, R2C2::NetTrain &t): remote(r), client(c), train(t) @@ -32,20 +25,20 @@ TrainPanel::TrainPanel(Remote &r, Marklin::Client &c, Marklin::NetTrain &t): Gtk::HBox *hbox = new Gtk::HBox(false, 5); vbox->add(*manage(hbox)); - hbox->add(*manage(scl_speed = new Gtk::HScale)); + hbox->pack_start(*manage(scl_speed = new Gtk::HScale), true, true); scl_speed->set_digits(0); scl_speed->set_range(0, 200); scl_speed->set_increments(5, 5); 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"))); + hbox->pack_start(*manage(chk_reverse = new Gtk::CheckButton("Rev")), false, true); 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(); - for(std::map::const_iterator i=funcs.begin(); i!=funcs.end(); ++i) + const R2C2::VehicleType::FunctionMap &funcs = train.get_loco_type().get_functions(); + for(R2C2::VehicleType::FunctionMap::const_iterator i=funcs.begin(); i!=funcs.end(); ++i) { Gtk::CheckButton *&chk = chk_funcs[i->first]; chk = new Gtk::CheckButton(i->second); @@ -54,7 +47,7 @@ TrainPanel::TrainPanel(Remote &r, Marklin::Client &c, Marklin::NetTrain &t): } Glib::RefPtr route_store = Gtk::ListStore::create(route_columns); - vbox->add(*manage(cmb_route = new Gtk::ComboBox(route_store))); + vbox->add(*manage(cmb_route = new Gtk::ComboBox(static_cast &>(route_store)))); cmb_route->pack_start(route_columns.name); route_store->append(); const list &routes = client.get_routes(); @@ -84,10 +77,11 @@ void TrainPanel::control_changed(const string &control, float value) { if(control=="speed") { - // XXX It would be better to make the LocoType give us the catalogue - scl_speed->set_value(abs(value)*3.6/remote.get_catalogue().get_scale()); - chk_reverse->set_active(value<0); + // XXX It would be better to make the VehicleType give us the catalogue + scl_speed->set_value(value*3.6/remote.get_catalogue().get_scale()); } + else if(control=="reverse") + chk_reverse->set_active(value); } void TrainPanel::function_changed(unsigned func, bool set) @@ -111,14 +105,18 @@ void TrainPanel::route_changed(const string &route) void TrainPanel::ui_speed_changed() { float speed = scl_speed->get_value()/3.6*remote.get_catalogue().get_scale(); - if(chk_reverse->get_active()) - speed = -speed; train.set_control("speed", speed); } void TrainPanel::ui_reverse_changed() { - train.set_control("speed", 0); + if(train.get_control("speed")) + { + train.set_control("speed", 0); + chk_reverse->set_active(train.get_control("reverse")); + } + else + train.set_control("reverse", chk_reverse->get_active()); } void TrainPanel::ui_function_changed(unsigned func)