Interface for material rendering. More...
#include <IMaterialRenderer.h>
Interface for material rendering.
Can be used to extend the engine with new materials. Refer to IVideoDriver::addMaterialRenderer() for more informations on how to extend the engine with new materials.
Definition at line 24 of file IMaterialRenderer.h.
virtual s32 irr::video::IMaterialRenderer::getRenderCapability | ( | ) | const [inline, virtual] |
Returns the render capability of the material.
Because some more complex materials are implemented in multiple ways and need special hardware capabilities, it is possible to query how the current material renderer is performing on the current hardware with this function.
Definition at line 93 of file IMaterialRenderer.h.
virtual bool irr::video::IMaterialRenderer::isTransparent | ( | ) | const [inline, virtual] |
Returns if the material is transparent.
The scene managment needs to know this for being able to sort the materials by opaque and transparent.
Definition at line 81 of file IMaterialRenderer.h.
virtual bool irr::video::IMaterialRenderer::OnRender | ( | IMaterialRendererServices * | service, |
E_VERTEX_TYPE | vtxtype | ||
) | [inline, virtual] |
Called every time before a new bunch of geometry is being drawn using this material with for example drawIndexedTriangleList() call.
OnSetMaterial should normally only be called if the renderer decides that the renderstates should be changed, it won't be called if for example two drawIndexedTriangleList() will be called with the same material set. This method will be called every time. This is useful for example for materials with shaders, which don't only set new renderstates but also shader constants.
service,: | Pointer to interface providing methos for setting constants and other things. |
vtxtype,: | Vertex type with which the next rendering will be done. This can be used by the material renderer to set some specific optimized shaders or if this is an incompatible vertex type for this renderer, to refuse rendering for example. |
Definition at line 71 of file IMaterialRenderer.h.
virtual void irr::video::IMaterialRenderer::OnSetMaterial | ( | const SMaterial & | material, |
const SMaterial & | lastMaterial, | ||
bool | resetAllRenderstates, | ||
IMaterialRendererServices * | services | ||
) | [inline, virtual] |
Called by the IVideoDriver implementation the let the renderer set its needed render states.
This is called during the IVideoDriver::setMaterial() call. When overriding this, you can set some renderstates or for example a vertex or pixel shader if you like.
material,: | The new material parameters to be set. The renderer may change the material flags in this material. For example if this material does not accept the zbuffer = true, it can set it to false. This is useful, because in the next lastMaterial will be just the material in this call. |
lastMaterial,: | The material parameters which have been set before this material. |
resetAllRenderstates,: | True if all renderstates should really be reset. This is usually true if the last rendering mode was not a usual 3d rendering mode, but for example a 2d rendering mode. You should reset really all renderstates if this is true, no matter if the lastMaterial had some similar settings. This is used because in most cases, some common renderstates are not changed if they are already there, for example bilinear filtering, wireframe, gouraudshading, lighting, zbuffer, zwriteenable, backfaceculling and fogenable. |
services,: | Interface providing some methods for changing advanced, internal states of a IVideoDriver. |
Definition at line 50 of file IMaterialRenderer.h.
virtual void irr::video::IMaterialRenderer::OnUnsetMaterial | ( | ) | [inline, virtual] |
Called by the IVideoDriver to unset this material.
Called during the IVideoDriver::setMaterial() call before the new material will get the OnSetMaterial() call.
Definition at line 76 of file IMaterialRenderer.h.