/* $Id$
-This file is part of the MSP Märklin suite
+This file is part of R²C²
Copyright © 2009-2010 Mikkosoft Productions, Mikko Rasa
Distributed under the GPL
*/
#include <gtkmm/box.h>
#include <gtkmm/liststore.h>
-#include "libmarklin/locotype.h"
#include "remote.h"
#include "trainpanel.h"
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)
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);
{
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)
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)