X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Fobject.h;h=dea389e4b8ae4d0d841ccbea333341bbc2a40ef9;hb=c0b7d6ee4a7478f5aecb1504429ec1fc846d64ed;hp=c97e951c16d04d7186d8c6bdeca2902041e05669;hpb=233dff2a6c552e08da832496aecd88ef4f8948f1;p=libs%2Fgl.git diff --git a/source/render/object.h b/source/render/object.h index c97e951c..dea389e4 100644 --- a/source/render/object.h +++ b/source/render/object.h @@ -2,19 +2,16 @@ #define MSP_GL_OBJECT_H_ #include -#include "bindable.h" #include "renderable.h" -#include "renderpass.h" +#include "rendermethod.h" #include "resourceobserver.h" namespace Msp { namespace GL { -class Material; class Mesh; class ObjectInstance; class Technique; -class Texture; /** Combines a Mesh with a Technique to give it an appearance. The Technique will @@ -53,10 +50,10 @@ public: class Loader: public LodLoader { public: - Loader(Object &); - Loader(Object &, Collection &); + Loader(Object &o): Loader(o, 0) { } + Loader(Object &o, Collection &c): Loader(o, &c) { } private: - void init(); + Loader(Object &, Collection *); virtual void finish(); void bounding_sphere_hint(float, float, float, float); @@ -66,15 +63,15 @@ public: private: struct LevelOfDetail { - RefPtr mesh; - RefPtr technique; + const Mesh *mesh; + const Technique *technique; }; std::vector lods; Geometry::BoundingSphere bounding_sphere; bool lod0_watched; - static Matrix identity_matrix; + static const Matrix identity_matrix; public: Object(); @@ -121,7 +118,7 @@ protected: virtual void finish_render(Renderer &, Tag) const { } private: - const RenderPass *get_pass(Tag, unsigned) const; + const RenderMethod *get_method(Tag, unsigned) const; virtual void resource_loaded(Resource &); virtual void resource_removed(Resource &);