X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fengineer%2Fengineer.h;h=944c39047a967ae0344b13bb3d216871e427b082;hb=2d44923e135a119fde31a7a50e5fcd3e400e4f41;hp=5fa05871973e302872b589589df060b3c29680d3;hpb=651698847d5293cfb15b6fb23a394701388c0151;p=r2c2.git diff --git a/source/engineer/engineer.h b/source/engineer/engineer.h index 5fa0587..944c390 100644 --- a/source/engineer/engineer.h +++ b/source/engineer/engineer.h @@ -1,7 +1,7 @@ /* $Id$ -This file is part of the MSP Märklin suite -Copyright © 2006-2010 Mikkosoft Productions, Mikko Rasa +This file is part of R²C² +Copyright © 2006-2011 Mikkosoft Productions, Mikko Rasa Distributed under the GPL */ @@ -16,19 +16,23 @@ Distributed under the GPL #include #include #include -#include "libmarklin/catalogue.h" -#include "libmarklin/train.h" +#include "libr2c2/catalogue.h" +#include "libr2c2/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; @@ -36,13 +40,13 @@ private: Msp::GLtk::Resources ui_res; Msp::GLtk::Root *root; - Marklin::Catalogue catalogue; - Marklin::Layout layout; - Marklin::Layout3D layout_3d; - Marklin::Server *server; + R2C2::Catalogue catalogue; + R2C2::Layout layout; + R2C2::Layout3D layout_3d; + R2C2::Server *server; Msp::IO::EventDispatcher event_disp; - Marklin::Overlay3D *overlay; - std::list new_trains; + R2C2::Overlay3D *overlay; + std::map train_colors; Msp::GL::Camera camera; Msp::GL::Lighting lighting; @@ -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; + R2C2::Track *picking_track; + int picking_entry; + R2C2::Path3D *picking_path; + int pointer_x; + int pointer_y; + bool pointer_moved; public: Engineer(int argc, char **argv); @@ -62,9 +72,15 @@ public: const Msp::GLtk::Resources &get_ui_resources() const { return ui_res; } 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 &); + const R2C2::Catalogue &get_catalogue() const { return catalogue; } + R2C2::Layout &get_layout() { return layout; } + R2C2::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: @@ -72,12 +88,12 @@ private: void button_press(int, int, unsigned, unsigned); void pointer_motion(int, int); void view_all(); - void set_block_color(const Marklin::Block &, const Msp::GL::Color &); - void reset_block_color(const Marklin::Block &); + void set_block_color(const R2C2::Block &, const Msp::GL::Color &); + void reset_block_color(const R2C2::Block &); void sensor_event(unsigned, bool); - void block_reserved(const Marklin::Block &, const Marklin::Train *); - Marklin::Track3D *pick_track(int, int); - void train_added(Marklin::Train &); + void block_reserved(const R2C2::Block &, const R2C2::Train *); + R2C2::Track *pick_track(int, int); + void train_added(R2C2::Train &); virtual void sighandler(int); static Msp::Application::RegApp reg;