X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2F3d%2Flayout.h;h=f2de127a0cc19d96117b4a63f3fb3be8c042921c;hb=9abaa89f495307c7e90cbef51ae0fedbaff001db;hp=ba590dd37e2d8482d5180138f2ab6f663a7a6554;hpb=651698847d5293cfb15b6fb23a394701388c0151;p=r2c2.git diff --git a/source/3d/layout.h b/source/3d/layout.h index ba590dd..f2de127 100644 --- a/source/3d/layout.h +++ b/source/3d/layout.h @@ -12,20 +12,26 @@ Distributed under the GPL #include #include "libmarklin/layout.h" #include "catalogue.h" -#include "track.h" -#include "train.h" namespace Marklin { +class Track3D; +class Vehicle3D; + class Layout3D: public sigc::trackable { +public: + typedef std::map TrackMap; + typedef std::map VehicleMap; + private: Layout &layout; Catalogue3D catalogue; - std::list tracks; - std::list trains; + TrackMap tracks; + VehicleMap vehicles; Msp::GL::Scene scene; Msp::GL::Scene ep_scene; + Msp::GL::Scene path_scene; public: Layout3D(Layout &); @@ -35,21 +41,22 @@ public: void add_track(Track3D &); void remove_track(Track3D &); - const std::list &get_tracks() const { return tracks; } - Track3D &get_track(const Track &) const; + const TrackMap &get_tracks() const { return tracks; } + Track3D &get_track(Track &) const; Track3D *pick_track(float, float, float) const; - void add_train(Train3D &); - void remove_train(Train3D &); - Train3D &get_train(const Train &) const; + void add_vehicle(Vehicle3D &); + void remove_vehicle(Vehicle3D &); + Vehicle3D &get_vehicle(Vehicle &) const; Msp::GL::Scene &get_scene() { return scene; } Msp::GL::Scene &get_endpoint_scene() { return ep_scene; } + Msp::GL::Scene &get_path_scene() { return path_scene; } private: void track_added(Track &); void track_removed(Track &); - void train_added(Train &); + void vehicle_added(Vehicle &); }; } // namespace Marklin