X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2F3d%2Flayout.h;h=d5aad2634fbbe2343f4f2d38027347b531957f2b;hb=a882f35842c819e011c5fdf6104852c2b6ab3eef;hp=8456fa8e7404d62fbcec19a0792e3b35cc56e56a;hpb=e214fd389b9819eac0379cfb78e0f446e267b839;p=r2c2.git diff --git a/source/3d/layout.h b/source/3d/layout.h index 8456fa8..d5aad26 100644 --- a/source/3d/layout.h +++ b/source/3d/layout.h @@ -11,23 +11,19 @@ namespace R2C2 { -class Signal3D; -class Track3D; -class Vehicle3D; +class Object3D; +class Utility3D; class Layout3D: public sigc::trackable { public: - typedef std::map TrackMap; - typedef std::map VehicleMap; - typedef std::map SignalMap; + typedef std::map ObjectMap; private: Layout &layout; Catalogue3D catalogue; - TrackMap tracks; - VehicleMap vehicles; - SignalMap signals; + ObjectMap objects; + std::set utilities; Msp::GL::InstanceScene scene; Msp::GL::SimpleScene ep_scene; Msp::GL::InstanceScene path_scene; @@ -39,21 +35,21 @@ public: ~Layout3D(); Layout &get_layout() const { return layout; } + Catalogue3D &get_catalogue() { return catalogue; } const Catalogue3D &get_catalogue() const { return catalogue; } void get_bounds(Vector &, Vector &) const; - void add_track(Track3D &); - void remove_track(Track3D &); - const TrackMap &get_tracks() const { return tracks; } - Track3D &get_track(Track &) const; + void add(Object3D &); + Object3D &get(Object &) const; + const ObjectMap &get_all() const { return objects; } + void remove(Object3D &); - void add_vehicle(Vehicle3D &); - void remove_vehicle(Vehicle3D &); - Vehicle3D &get_vehicle(Vehicle &) const; + template + T &get(Object &o) const + { return dynamic_cast(get(o)); } - void add_signal(Signal3D &); - void remove_signal(Signal3D &); - Signal3D &get_signal(Signal &) const; + void add(Utility3D &); + void remove(Utility3D &); Msp::GL::Scene &get_scene() { return scene; } Msp::GL::Scene &get_endpoint_scene() { return ep_scene; }