IMaterialRendererServices.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. // Copyright (C) 2002-2012 Nikolaus Gebhardt
  2. // This file is part of the "Irrlicht Engine".
  3. // For conditions of distribution and use, see copyright notice in irrlicht.h
  4. #ifndef __I_MATERIAL_RENDERER_SERVICES_H_INCLUDED__
  5. #define __I_MATERIAL_RENDERER_SERVICES_H_INCLUDED__
  6. #include "SMaterial.h"
  7. #include "S3DVertex.h"
  8. namespace irr
  9. {
  10. namespace video
  11. {
  12. class IVideoDriver;
  13. //! Interface providing some methods for changing advanced, internal states of a IVideoDriver.
  14. class IMaterialRendererServices
  15. {
  16. public:
  17. //! Destructor
  18. virtual ~IMaterialRendererServices() {}
  19. //! Can be called by an IMaterialRenderer to make its work easier.
  20. /** Sets all basic renderstates if needed.
  21. Basic render states are diffuse, ambient, specular, and emissive color,
  22. specular power, bilinear and trilinear filtering, wireframe mode,
  23. grouraudshading, lighting, zbuffer, zwriteenable, backfaceculling and
  24. fog enabling.
  25. \param material The new material to be used.
  26. \param lastMaterial The material used until now.
  27. \param resetAllRenderstates Set to true if all renderstates should be
  28. set, regardless of their current state. */
  29. virtual void setBasicRenderStates(const SMaterial& material,
  30. const SMaterial& lastMaterial,
  31. bool resetAllRenderstates) = 0;
  32. //! Return an index constant for the vertex shader based on a name.
  33. virtual s32 getVertexShaderConstantID(const c8* name) = 0;
  34. //! Sets a constant for the vertex shader based on a name.
  35. /** This can be used if you used a high level shader language like GLSL
  36. or HLSL to create a shader. Example: If you created a shader which has
  37. variables named 'mWorldViewProj' (containing the WorldViewProjection
  38. matrix) and another one named 'fTime' containing one float, you can set
  39. them in your IShaderConstantSetCallBack derived class like this:
  40. \code
  41. virtual void OnSetConstants(video::IMaterialRendererServices* services, s32 userData)
  42. {
  43. video::IVideoDriver* driver = services->getVideoDriver();
  44. f32 time = (f32)os::Timer::getTime()/100000.0f;
  45. services->setVertexShaderConstant("fTime", &time, 1);
  46. core::matrix4 worldViewProj(driver->getTransform(video::ETS_PROJECTION));
  47. worldViewProj *= driver->getTransform(video::ETS_VIEW);
  48. worldViewProj *= driver->getTransform(video::ETS_WORLD);
  49. services->setVertexShaderConstant("mWorldViewProj", worldViewProj.M, 16);
  50. }
  51. \endcode
  52. \param index Index of the variable
  53. \param floats Pointer to array of floats
  54. \param count Amount of floats in array.
  55. \return True if successful.
  56. */
  57. virtual bool setVertexShaderConstant(s32 index, const f32* floats, int count) = 0;
  58. //! Int interface for the above.
  59. virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) = 0;
  60. //! Uint interface for the above.
  61. /* NOTE: UINT only works with GLSL, not supported for other shaders */
  62. virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) = 0;
  63. //! Sets a vertex shader constant.
  64. /** Can be used if you created a shader using pixel/vertex shader
  65. assembler or ARB_fragment_program or ARB_vertex_program.
  66. \param data: Data to be set in the constants
  67. \param startRegister: First register to be set
  68. \param constantAmount: Amount of registers to be set. One register consists of 4 floats. */
  69. virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) = 0;
  70. //! Return an index constant for the pixel shader based on a name.
  71. virtual s32 getPixelShaderConstantID(const c8* name) = 0;
  72. //! Sets a constant for the pixel shader based on a name.
  73. /** This can be used if you used a high level shader language like GLSL
  74. or HLSL to create a shader. See setVertexShaderConstant() for an
  75. example on how to use this.
  76. \param index Index of the variable
  77. \param floats Pointer to array of floats
  78. \param count Amount of floats in array.
  79. \return True if successful. */
  80. virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) = 0;
  81. //! Int interface for the above.
  82. virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) = 0;
  83. //! Uint interface for the above.
  84. /* NOTE: UINT only works with GLSL, not supported for other shaders */
  85. virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) = 0;
  86. //! Sets a pixel shader constant.
  87. /** Can be used if you created a shader using pixel/vertex shader
  88. assembler or ARB_fragment_program or ARB_vertex_program.
  89. \param data Data to be set in the constants
  90. \param startRegister First register to be set.
  91. \param constantAmount Amount of registers to be set. One register consists of 4 floats. */
  92. virtual void setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) = 0;
  93. //! \deprecated. This method may be removed by Irrlicht 2.0
  94. _IRR_DEPRECATED_ bool setVertexShaderConstant(const c8* name, const f32* floats, int count)
  95. {
  96. return setVertexShaderConstant(getVertexShaderConstantID(name), floats, count);
  97. }
  98. //! \deprecated. This method may be removed by Irrlicht 2.0
  99. _IRR_DEPRECATED_ bool setVertexShaderConstant(const c8* name, const s32* ints, int count)
  100. {
  101. return setVertexShaderConstant(getVertexShaderConstantID(name), ints, count);
  102. }
  103. //! \deprecated. This method may be removed by Irrlicht 2.0
  104. _IRR_DEPRECATED_ bool setPixelShaderConstant(const c8* name, const f32* floats, int count)
  105. {
  106. return setPixelShaderConstant(getPixelShaderConstantID(name), floats, count);
  107. }
  108. //! \deprecated. This method may be removed by Irrlicht 2.0
  109. _IRR_DEPRECATED_ bool setPixelShaderConstant(const c8* name, const s32* ints, int count)
  110. {
  111. return setPixelShaderConstant(getPixelShaderConstantID(name), ints, count);
  112. }
  113. //! Get pointer to the IVideoDriver interface
  114. /** \return Pointer to the IVideoDriver interface */
  115. virtual IVideoDriver* getVideoDriver() = 0;
  116. };
  117. } // end namespace video
  118. } // end namespace irr
  119. #endif