X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2F3d%2Fcatalogue.h;h=d82529f9fec47e5ebb58a2912941aa8447474a4d;hb=81ee4fbd16b472892b67b35ea85956423a2247ed;hp=1f33ebb808e7aec3a7af34bc042dd757ec118431;hpb=6968273080fa2a1cbcfc506610d5f249299611e9;p=r2c2.git diff --git a/source/3d/catalogue.h b/source/3d/catalogue.h index 1f33ebb..d82529f 100644 --- a/source/3d/catalogue.h +++ b/source/3d/catalogue.h @@ -1,46 +1,50 @@ -/* $Id$ +#ifndef R2C2_3D_CATALOGUE_H_ +#define R2C2_3D_CATALOGUE_H_ -This file is part of the MSP Märklin suite -Copyright © 2010 Mikkosoft Productions, Mikko Rasa -Distributed under the GPL -*/ - -#ifndef MARKLIN3D_CATALOGUE_H_ -#define MARKLIN3D_CATALOGUE_H_ - -#include +#include +#include #include -#include "libmarklin/catalogue.h" +#include +#include "libr2c2/catalogue.h" +#include "typemap.h" -namespace Marklin { +namespace R2C2 { -class TrackType3D; -class VehicleType3D; +class ObjectType3D; -class Catalogue3D +class Catalogue3D: public Msp::GL::Resources { private: + typedef std::map ObjectMap; + typedef std::map EndpointMap; + Catalogue &catalogue; - std::map tracks; - std::map vehicles; - Msp::GL::Material ballast_material; - Msp::GL::Material rail_material; - Msp::GL::Mesh endpoint_mesh; + Msp::DataFile::DirectorySource src; + ObjectMap objects; + EndpointMap endpoint_meshes; public: Catalogue3D(Catalogue &); ~Catalogue3D(); const Catalogue &get_catalogue() const { return catalogue; } - const TrackType3D &get_track(const TrackType &) const; - const VehicleType3D &get_vehicle(const VehicleType &) const; - const Msp::GL::Material &get_ballast_material() const { return ballast_material; } - const Msp::GL::Material &get_rail_material() const { return rail_material; } - const Msp::GL::Mesh &get_endpoint_mesh() const { return endpoint_mesh; } + + 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))); } + + template + const typename TypeMap3D::Type3D &get_3d(const T &ot) + { return dynamic_cast::Type3D &>(get_3d(static_cast(ot))); } + private: - void track_added(const TrackType &); - void vehicle_added(const VehicleType &); - void build_endpoint_mesh(); + 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; }; }