+ engineer.pick(true);
+ pick_conn = engineer.signal_pick_done.connect(sigc::mem_fun(this, &TrainPanel::place));
+}
+
+void TrainPanel::take_clicked()
+{
+ train.unplace();
+}
+
+void TrainPanel::edit_clicked()
+{
+ TrainProperties *dialog = new TrainProperties(engineer, res, &train);
+ engineer.get_root().add(*dialog);
+ dialog->set_position(geom.x+geom.w, geom.y+geom.h-dialog->get_geometry().h);
+}
+
+void TrainPanel::route_clicked()
+{
+ RouteSelect *dialog = new RouteSelect(engineer, res, train);
+ engineer.get_root().add(*dialog);
+ dialog->set_position(geom.x+geom.w, geom.y+geom.h-dialog->get_geometry().h);
+}
+
+void TrainPanel::goto_clicked()
+{
+ engineer.pick(false);
+ pick_conn = engineer.signal_pick_done.connect(sigc::mem_fun(this, &TrainPanel::go_to));
+}
+
+void TrainPanel::timetable_clicked()
+{
+ Timetable *timetable = train.get_timetable();
+ if(!timetable)
+ {
+ timetable = new Timetable(train);
+ train.set_timetable(timetable);
+ }
+
+ TimetableDialog *dialog = new TimetableDialog(res, *timetable);
+ engineer.get_root().add(*dialog);
+ dialog->set_position(geom.x+geom.w, geom.y+geom.h-dialog->get_geometry().h);
+}
+
+void TrainPanel::view_clicked()
+{
+ TrainView *dialog = new TrainView(engineer, train);
+ engineer.get_root().add(*dialog);
+ dialog->set_position(geom.x+geom.w, geom.y+geom.h-dialog->get_geometry().h);
+}
+
+void TrainPanel::expand_clicked()
+{
+ expand(!expanded);
+}
+
+void TrainPanel::speed_slider_changed(double value)
+{
+ float speed = value/3.6*engineer.get_layout().get_catalogue().get_scale();
+ train.set_control("speed", speed);