X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Fobject.h;h=b7b549536f4b92bd97c0ee9506e8ab3c48d42111;hb=e92de029768eef5f0fd744329e589161b46d0762;hp=48e3045930559fd354af6d868a935100a2fab09d;hpb=7aaec9a70b8d7733429bec043f8e33e02956f266;p=libs%2Fgl.git diff --git a/source/render/object.h b/source/render/object.h index 48e30459..b7b54953 100644 --- a/source/render/object.h +++ b/source/render/object.h @@ -2,7 +2,6 @@ #define MSP_GL_OBJECT_H_ #include -#include "bindable.h" #include "renderable.h" #include "renderpass.h" #include "resourceobserver.h" @@ -66,8 +65,8 @@ public: private: struct LevelOfDetail { - RefPtr mesh; - RefPtr technique; + const Mesh *mesh; + const Technique *technique; }; std::vector lods; @@ -110,18 +109,18 @@ public: virtual const Matrix *get_matrix() const { return &identity_matrix; } virtual const Geometry::BoundingSphere *get_bounding_sphere() const { return &bounding_sphere; } - virtual void render(Renderer &, const Tag & = Tag()) const; + virtual void render(Renderer &, Tag = Tag()) const; /** Renders an instance of the object. The instance's hook functions are called before and after drawing the mesh. */ - virtual void render(Renderer &, const ObjectInstance &, const Tag & = Tag()) const; + virtual void render(Renderer &, const ObjectInstance &, Tag = Tag()) const; protected: - virtual void setup_render(Renderer &, const Tag &) const { } - virtual void finish_render(Renderer &, const Tag &) const { } + virtual void setup_render(Renderer &, Tag) const { } + virtual void finish_render(Renderer &, Tag) const { } private: - const RenderPass *get_pass(const Tag &, unsigned) const; + const RenderPass *get_pass(Tag, unsigned) const; virtual void resource_loaded(Resource &); virtual void resource_removed(Resource &);