X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2F3d%2Fcatalogue.h;h=586ee66758f617778af53d6a489b0c0bd1bd69bc;hb=0a2bd90a3d4f5e7333eba59f29e4a0fbcb11175e;hp=1cc096a67b9588ca3dbffb5867f43bc0129695aa;hpb=7c98e23312cf01ce1fa6c1ffd8e36c22d2fa6110;p=r2c2.git diff --git a/source/3d/catalogue.h b/source/3d/catalogue.h index 1cc096a..586ee66 100644 --- a/source/3d/catalogue.h +++ b/source/3d/catalogue.h @@ -2,9 +2,9 @@ #define R2C2_3D_CATALOGUE_H_ #include -#include -#include +#include #include +#include #include "libr2c2/catalogue.h" #include "typemap.h" @@ -12,40 +12,38 @@ namespace R2C2 { class ObjectType3D; -class Catalogue3D: public Msp::DataFile::Collection +class Catalogue3D: public Msp::GL::Resources { private: + typedef std::map ObjectMap; + typedef std::map EndpointMap; + Catalogue &catalogue; - std::map objects; - Msp::GL::Mesh endpoint_mesh; + 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 const typename TypeMap3D::Type3D &get_3d(const T &ot) const { return dynamic_cast::Type3D &>(get_3d(static_cast(ot))); } -private: - void build_endpoint_mesh(); -public: - const Msp::GL::Mesh &get_endpoint_mesh() const { return endpoint_mesh; } - -private: - Msp::FS::Path locate_file(const std::string &); - template - T *create(const std::string &); + const typename TypeMap3D::Type3D &get_3d(const T &ot) + { return dynamic_cast::Type3D &>(get_3d(static_cast(ot))); } - template - T *create2(const std::string &); +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; }; }