]> git.tdb.fi Git - r2c2.git/blobdiff - source/3d/layout.h
Fix some GL function calls
[r2c2.git] / source / 3d / layout.h
index 21686de5f9c8bbc4a19e1fdc21acffd2276b4267..f2de127a0cc19d96117b4a63f3fb3be8c042921c 100644 (file)
@@ -8,33 +8,55 @@ Distributed under the GPL
 #ifndef MARKLIN3D_LAYOUT_H_
 #define MARKLIN3D_LAYOUT_H_
 
+#include <sigc++/trackable.h>
+#include <msp/gl/scene.h>
 #include "libmarklin/layout.h"
 #include "catalogue.h"
-#include "track.h"
 
 namespace Marklin {
 
-class Layout3D
+class Track3D;
+class Vehicle3D;
+
+class Layout3D: public sigc::trackable
 {
+public:
+       typedef std::map<Track *, Track3D *> TrackMap;
+       typedef std::map<Vehicle *, Vehicle3D *> VehicleMap;
+
 private:
        Layout &layout;
        Catalogue3D catalogue;
-       std::list<Track3D *> tracks;
-       unsigned quality;
+       TrackMap tracks;
+       VehicleMap vehicles;
+       Msp::GL::Scene scene;
+       Msp::GL::Scene ep_scene;
+       Msp::GL::Scene path_scene;
 
 public:
        Layout3D(Layout &);
        ~Layout3D();
 
        const Catalogue3D &get_catalogue() const { return catalogue; }
-       void set_quality(unsigned);
-       const std::list<Track3D *> &get_tracks() const { return tracks; }
-       void render(bool =false) const;
-       Track3D &get_track(const Track &) const;
+
+       void add_track(Track3D &);
+       void remove_track(Track3D &);
+       const TrackMap &get_tracks() const { return tracks; }
+       Track3D &get_track(Track &) const;
        Track3D *pick_track(float, float, float) 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 vehicle_added(Vehicle &);
 };
 
 } // namespace Marklin