]> git.tdb.fi Git - r2c2.git/blobdiff - source/3d/catalogue.h
Convert Catalogue to a Collection
[r2c2.git] / source / 3d / catalogue.h
index 07f1535f2b30583d72ce554124cb4a9195ad5d09..d82529f9fec47e5ebb58a2912941aa8447474a4d 100644 (file)
@@ -15,28 +15,35 @@ class ObjectType3D;
 class Catalogue3D: public Msp::GL::Resources
 {
 private:
+       typedef std::map<const ObjectType *, ObjectType3D *> ObjectMap;
+       typedef std::map<const TrackAppearance *, Msp::GL::Mesh *> EndpointMap;
+
        Catalogue &catalogue;
        Msp::DataFile::DirectorySource src;
-       std::map<const ObjectType *, ObjectType3D *> objects;
-       std::map<const TrackAppearance *, Msp::GL::Mesh *> endpoint_meshes;
+       ObjectMap objects;
+       EndpointMap endpoint_meshes;
 
 public:
        Catalogue3D(Catalogue &);
        ~Catalogue3D();
 
        const Catalogue &get_catalogue() const { return catalogue; }
-private:
-       void object_added(const ObjectType &);
-public:
+
+       const ObjectType3D &get_3d(const ObjectType &);
        const ObjectType3D &get_3d(const ObjectType &) const;
 
        template<typename T>
        const typename TypeMap3D<T>::Type3D &get_3d(const T &ot) const
        { return dynamic_cast<const typename TypeMap3D<T>::Type3D &>(get_3d(static_cast<const ObjectType &>(ot))); }
 
+       template<typename T>
+       const typename TypeMap3D<T>::Type3D &get_3d(const T &ot)
+       { return dynamic_cast<const typename TypeMap3D<T>::Type3D &>(get_3d(static_cast<const ObjectType &>(ot))); }
+
 private:
        void build_endpoint_mesh(const TrackAppearance &);
 public:
+       const Msp::GL::Mesh &get_endpoint_mesh(const TrackAppearance &);
        const Msp::GL::Mesh &get_endpoint_mesh(const TrackAppearance &) const;
 };