X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fengineer%2Fengineer.h;h=61a2f59e37730c53e88a87bccbfd26bda1ea6abc;hb=f74ce147edde73319e55475433adb8e1d87b7201;hp=48d60a2df9ae82679c75615852ed86d6f3c9aaf3;hpb=c87c4200e105a21c1d1f9faec20c4c08ddbb53ee;p=r2c2.git diff --git a/source/engineer/engineer.h b/source/engineer/engineer.h index 48d60a2..61a2f59 100644 --- a/source/engineer/engineer.h +++ b/source/engineer/engineer.h @@ -20,15 +20,19 @@ Distributed under the GPL #include "libmarklin/train.h" #include "3d/layout.h" #include "3d/overlay.h" +#include "3d/path.h" #include "network/server.h" #include "options.h" class MainPanel; class TrainPanel; -class TrainProperties; +class TrainView; class Engineer: public Msp::Application { +public: + sigc::signal signal_pick_done; + private: Options options; @@ -52,9 +56,15 @@ private: MainPanel *main_panel; std::list train_panels; - Marklin::Train *placing_train; - Marklin::Block *placing_block; - unsigned placing_entry; + std::list train_views; + Msp::Time::TimeStamp status_timeout; + bool picking; + Marklin::Track *picking_track; + int picking_entry; + Marklin::Path3D *picking_path; + int pointer_x; + int pointer_y; + bool pointer_moved; public: Engineer(int argc, char **argv); @@ -64,7 +74,13 @@ public: Msp::GLtk::Root &get_root() const { return *root; } const Marklin::Catalogue &get_catalogue() const { return catalogue; } Marklin::Layout &get_layout() { return layout; } - void place_train(Marklin::Train &); + Marklin::Layout3D &get_layout_3d() { return layout_3d; } + const Msp::GL::Lighting &get_lighting() const { return lighting; } + void set_status(const std::string &); + void rearrange_panels(); + void add_train_view(TrainView &); + void remove_train_view(TrainView &); + void pick(bool); int main(); void quit() { exit(0); } private: