]> git.tdb.fi Git - r2c2.git/blobdiff - source/remote/trainpanel.cpp
Export routes over network
[r2c2.git] / source / remote / trainpanel.cpp
index e3db1badb3cfcd0c5451216c5497daf09ef7110c..ce46fa19dffaa86634df6553609c8a28f086878e 100644 (file)
@@ -6,17 +6,21 @@ Distributed under the GPL
 */
 
 #include <gtkmm/box.h>
+#include <gtkmm/liststore.h>
 #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<unsigned, string> &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<Gtk::ListStore> 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<string> &routes = client.get_routes();
+       for(list<string>::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<unsigned, Gtk::CheckButton *>::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<unsigned>(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<unsigned, Gtk::CheckButton *>::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);
+}