X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fobjectinstance.h;h=906ba2f32785093237c8dbf108e500a655fe3454;hp=6a8749766f39ca08223c07d8971435c3abe1eebb;hb=c5f011ef508d580f332e4bd6065a013b24de8840;hpb=46921b54c8252bb535a3b2cb7be97eb38e66eaed diff --git a/source/objectinstance.h b/source/objectinstance.h index 6a874976..906ba2f3 100644 --- a/source/objectinstance.h +++ b/source/objectinstance.h @@ -3,22 +3,20 @@ #include #include "object.h" -#include "renderable.h" +#include "placeable.h" namespace Msp { namespace GL { -class ProgramData; - /** -Represents a single instance of an Object. A derived class can overload the -hook functions to specify a model matrix and other instance-specific parameters -for the rendered objects. +Represents a single instance of an Object. Thanks to being derived from +Placeable in can be positioned without additional effort. Other instance +parameters can be set by overriding the hook functions. ObjectInstances can benefit from being put in an InstanceScene, which will render all instances of the same object consecutively. */ -class ObjectInstance: public Renderable +class ObjectInstance: public PlacedRenderable { protected: const Object &object; @@ -36,7 +34,7 @@ public: /** Hook function, called from Object just before rendering the mesh. Renderer state will have been pushed before this is called. */ - virtual void setup_render(Renderer &, const Tag &) const { } + virtual void setup_render(Renderer &, const Tag &) const; /** Hook function, called from Object right after rendering the mesh. Since Object takes care of pushing Renderer state, this rarely needs to do