forked from Mirrorlandia_minetest/irrlicht
Merging r6073 through r6074 from trunk to ogl-es branch.
The support for UINT shader constants added in this is just returning warnings in GLES drivers as this would need ES 3.0 git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/branches/ogl-es@6115 dfc29bdd-3216-0410-991c-e03cc46cb475
This commit is contained in:
parent
cb62c685de
commit
084e0e669a
@ -71,6 +71,12 @@ public:
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) = 0;
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) = 0;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
/* NOTE: UINT only works with GLSL, not supported for other shaders.
|
||||||
|
Also GLES drivers in Irrlicht do not support it as this needs at least GLES 3.0.
|
||||||
|
*/
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) = 0;
|
||||||
|
|
||||||
//! Sets a vertex shader constant.
|
//! Sets a vertex shader constant.
|
||||||
/** Can be used if you created a shader using pixel/vertex shader
|
/** Can be used if you created a shader using pixel/vertex shader
|
||||||
assembler or ARB_fragment_program or ARB_vertex_program.
|
assembler or ARB_fragment_program or ARB_vertex_program.
|
||||||
@ -95,6 +101,12 @@ public:
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) = 0;
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) = 0;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
/* NOTE: UINT only works with GLSL, not supported for other shaders.
|
||||||
|
Also GLES drivers in Irrlicht do not support it as this needs at least GLES 3.0.
|
||||||
|
*/
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) = 0;
|
||||||
|
|
||||||
//! Sets a pixel shader constant.
|
//! Sets a pixel shader constant.
|
||||||
/** Can be used if you created a shader using pixel/vertex shader
|
/** Can be used if you created a shader using pixel/vertex shader
|
||||||
assembler or ARB_fragment_program or ARB_vertex_program.
|
assembler or ARB_fragment_program or ARB_vertex_program.
|
||||||
|
@ -3177,6 +3177,19 @@ bool CD3D9Driver::setVertexShaderConstant(s32 index, const s32* ints, int count)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
bool CD3D9Driver::setVertexShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
if (Material.MaterialType >= 0 && Material.MaterialType < (s32)MaterialRenderers.size())
|
||||||
|
{
|
||||||
|
CD3D9MaterialRenderer* r = (CD3D9MaterialRenderer*)MaterialRenderers[Material.MaterialType].Renderer;
|
||||||
|
return r->setVariable(true, index, ints, count);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
bool CD3D9Driver::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
bool CD3D9Driver::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
||||||
{
|
{
|
||||||
@ -3203,6 +3216,20 @@ bool CD3D9Driver::setPixelShaderConstant(s32 index, const s32* ints, int count)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
bool CD3D9Driver::setPixelShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
if (Material.MaterialType >= 0 && Material.MaterialType < (s32)MaterialRenderers.size())
|
||||||
|
{
|
||||||
|
CD3D9MaterialRenderer* r = (CD3D9MaterialRenderer*)MaterialRenderers[Material.MaterialType].Renderer;
|
||||||
|
return r->setVariable(false, index, ints, count);
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
//! Adds a new material renderer to the VideoDriver, using pixel and/or
|
//! Adds a new material renderer to the VideoDriver, using pixel and/or
|
||||||
//! vertex shaders to render geometry.
|
//! vertex shaders to render geometry.
|
||||||
s32 CD3D9Driver::addShaderMaterial(const c8* vertexShaderProgram,
|
s32 CD3D9Driver::addShaderMaterial(const c8* vertexShaderProgram,
|
||||||
|
@ -252,12 +252,18 @@ namespace video
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Returns a pointer to the IVideoDriver interface. (Implementation for
|
//! Returns a pointer to the IVideoDriver interface. (Implementation for
|
||||||
//! IMaterialRendererServices)
|
//! IMaterialRendererServices)
|
||||||
virtual IVideoDriver* getVideoDriver() _IRR_OVERRIDE_;
|
virtual IVideoDriver* getVideoDriver() _IRR_OVERRIDE_;
|
||||||
|
@ -370,6 +370,14 @@ bool CD3D9HLSLMaterialRenderer::setVariable(bool vertexShader, s32 index,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool CD3D9HLSLMaterialRenderer::setVariable(bool vertexShader, s32 index,
|
||||||
|
const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Error DirectX 9 does not support unsigned integer constants in shaders.", ELL_ERROR);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
bool CD3D9HLSLMaterialRenderer::OnRender(IMaterialRendererServices* service, E_VERTEX_TYPE vtxtype)
|
bool CD3D9HLSLMaterialRenderer::OnRender(IMaterialRendererServices* service, E_VERTEX_TYPE vtxtype)
|
||||||
{
|
{
|
||||||
if (VSConstantsTable)
|
if (VSConstantsTable)
|
||||||
|
@ -56,6 +56,9 @@ public:
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setVariable(bool vertexShader, s32 index, const s32* ints, int count);
|
virtual bool setVariable(bool vertexShader, s32 index, const s32* ints, int count);
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setVariable(bool vertexShader, s32 index, const u32* ints, int count);
|
||||||
|
|
||||||
bool OnRender(IMaterialRendererServices* service, E_VERTEX_TYPE vtxtype) _IRR_OVERRIDE_;
|
bool OnRender(IMaterialRendererServices* service, E_VERTEX_TYPE vtxtype) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -89,6 +89,13 @@ public:
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setVariable(bool vertexShader, s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Invalid material to set variable in.");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
IDirect3DDevice9* pID3DDevice;
|
IDirect3DDevice9* pID3DDevice;
|
||||||
|
@ -2299,14 +2299,21 @@ COGLES2Driver::~COGLES2Driver()
|
|||||||
//! Sets a constant for the vertex shader based on an index.
|
//! Sets a constant for the vertex shader based on an index.
|
||||||
bool COGLES2Driver::setVertexShaderConstant(s32 index, const f32* floats, int count)
|
bool COGLES2Driver::setVertexShaderConstant(s32 index, const f32* floats, int count)
|
||||||
{
|
{
|
||||||
//pass this along, as in GLSL the same routine is used for both vertex and fragment shaders
|
os::Printer::log("Error: Please call services->setVertexShaderConstant(), not VideoDriver->setVertexShaderConstant().");
|
||||||
return setPixelShaderConstant(index, floats, count);
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
bool COGLES2Driver::setVertexShaderConstant(s32 index, const s32* ints, int count)
|
bool COGLES2Driver::setVertexShaderConstant(s32 index, const s32* ints, int count)
|
||||||
{
|
{
|
||||||
return setPixelShaderConstant(index, ints, count);
|
os::Printer::log("Error: Please call services->setVertexShaderConstant(), not VideoDriver->setVertexShaderConstant().");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool COGLES2Driver::setVertexShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Error: Please call services->setVertexShaderConstant(), not VideoDriver->setVertexShaderConstant().");
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
@ -2323,6 +2330,11 @@ COGLES2Driver::~COGLES2Driver()
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COGLES2Driver::setPixelShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Error: Please call services->setPixelShaderConstant(), not VideoDriver->setPixelShaderConstant().");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
//! Adds a new material renderer to the VideoDriver, using pixel and/or
|
//! Adds a new material renderer to the VideoDriver, using pixel and/or
|
||||||
//! vertex shaders to render geometry.
|
//! vertex shaders to render geometry.
|
||||||
|
@ -230,12 +230,18 @@ namespace video
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Adds a new material renderer to the VideoDriver
|
//! Adds a new material renderer to the VideoDriver
|
||||||
virtual s32 addShaderMaterial(const c8* vertexShaderProgram, const c8* pixelShaderProgram,
|
virtual s32 addShaderMaterial(const c8* vertexShaderProgram, const c8* pixelShaderProgram,
|
||||||
IShaderConstantSetCallBack* callback, E_MATERIAL_TYPE baseMaterial, s32 userData) _IRR_OVERRIDE_;
|
IShaderConstantSetCallBack* callback, E_MATERIAL_TYPE baseMaterial, s32 userData) _IRR_OVERRIDE_;
|
||||||
|
@ -384,6 +384,11 @@ bool COGLES2MaterialRenderer::setVertexShaderConstant(s32 index, const s32* ints
|
|||||||
return setPixelShaderConstant(index, ints, count);
|
return setPixelShaderConstant(index, ints, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COGLES2MaterialRenderer::setVertexShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
return setPixelShaderConstant(index, ints, count);
|
||||||
|
}
|
||||||
|
|
||||||
bool COGLES2MaterialRenderer::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
bool COGLES2MaterialRenderer::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
||||||
{
|
{
|
||||||
if(index < 0 || UniformInfo[index].location < 0)
|
if(index < 0 || UniformInfo[index].location < 0)
|
||||||
@ -471,6 +476,12 @@ bool COGLES2MaterialRenderer::setPixelShaderConstant(s32 index, const s32* ints,
|
|||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COGLES2MaterialRenderer::setPixelShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Unsigned int support needs at least GLES 3.0", ELL_WARNING);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
IVideoDriver* COGLES2MaterialRenderer::getVideoDriver()
|
IVideoDriver* COGLES2MaterialRenderer::getVideoDriver()
|
||||||
{
|
{
|
||||||
return Driver;
|
return Driver;
|
||||||
|
@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
namespace video
|
namespace video
|
||||||
{
|
{
|
||||||
|
|
||||||
class COGLES2Driver;
|
class COGLES2Driver;
|
||||||
@ -30,8 +30,8 @@ class COGLES2MaterialRenderer : public IMaterialRenderer, public IMaterialRender
|
|||||||
public:
|
public:
|
||||||
|
|
||||||
COGLES2MaterialRenderer(
|
COGLES2MaterialRenderer(
|
||||||
COGLES2Driver* driver,
|
COGLES2Driver* driver,
|
||||||
s32& outMaterialTypeNr,
|
s32& outMaterialTypeNr,
|
||||||
const c8* vertexShaderProgram = 0,
|
const c8* vertexShaderProgram = 0,
|
||||||
const c8* pixelShaderProgram = 0,
|
const c8* pixelShaderProgram = 0,
|
||||||
IShaderConstantSetCallBack* callback = 0,
|
IShaderConstantSetCallBack* callback = 0,
|
||||||
@ -53,18 +53,20 @@ public:
|
|||||||
|
|
||||||
virtual s32 getRenderCapability() const;
|
virtual s32 getRenderCapability() const;
|
||||||
|
|
||||||
virtual void setBasicRenderStates(const SMaterial& material, const SMaterial& lastMaterial, bool resetAllRenderstates);
|
virtual void setBasicRenderStates(const SMaterial& material, const SMaterial& lastMaterial, bool resetAllRenderstates) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
virtual s32 getVertexShaderConstantID(const c8* name);
|
|
||||||
virtual s32 getPixelShaderConstantID(const c8* name);
|
|
||||||
virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1);
|
|
||||||
virtual void setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1);
|
|
||||||
virtual bool setVertexShaderConstant(s32 index, const f32* floats, int count);
|
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count);
|
|
||||||
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count);
|
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count);
|
|
||||||
|
|
||||||
virtual IVideoDriver* getVideoDriver();
|
virtual s32 getVertexShaderConstantID(const c8* name) _IRR_OVERRIDE_;
|
||||||
|
virtual s32 getPixelShaderConstantID(const c8* name) _IRR_OVERRIDE_;
|
||||||
|
virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) _IRR_OVERRIDE_;
|
||||||
|
virtual void setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
virtual IVideoDriver* getVideoDriver() _IRR_OVERRIDE_;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
@ -77,7 +79,7 @@ protected:
|
|||||||
|
|
||||||
bool createShader(GLenum shaderType, const char* shader);
|
bool createShader(GLenum shaderType, const char* shader);
|
||||||
bool linkProgram();
|
bool linkProgram();
|
||||||
|
|
||||||
COGLES2Driver* Driver;
|
COGLES2Driver* Driver;
|
||||||
IShaderConstantSetCallBack* CallBack;
|
IShaderConstantSetCallBack* CallBack;
|
||||||
|
|
||||||
|
@ -2602,6 +2602,11 @@ bool COGLES1Driver::setVertexShaderConstant(s32 index, const s32* ints, int coun
|
|||||||
return setPixelShaderConstant(index, ints, count);
|
return setPixelShaderConstant(index, ints, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COGLES1Driver::setVertexShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
return setPixelShaderConstant(index, ints, count);
|
||||||
|
}
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
bool COGLES1Driver::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
bool COGLES1Driver::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
||||||
{
|
{
|
||||||
@ -2616,6 +2621,12 @@ bool COGLES1Driver::setPixelShaderConstant(s32 index, const s32* ints, int count
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COGLES1Driver::setPixelShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Error: Please use IMaterialRendererServices from IShaderConstantSetCallBack::OnSetConstants not VideoDriver->setPixelShaderConstant().");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
//! Sets a vertex shader constant.
|
//! Sets a vertex shader constant.
|
||||||
void COGLES1Driver::setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount)
|
void COGLES1Driver::setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount)
|
||||||
{
|
{
|
||||||
|
@ -218,12 +218,18 @@ namespace video
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Sets a vertex shader constant.
|
//! Sets a vertex shader constant.
|
||||||
virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) _IRR_OVERRIDE_;
|
virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
@ -3667,19 +3667,15 @@ s32 COpenGLDriver::getPixelShaderConstantID(const c8* name)
|
|||||||
//! Sets a vertex shader constant.
|
//! Sets a vertex shader constant.
|
||||||
void COpenGLDriver::setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount)
|
void COpenGLDriver::setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount)
|
||||||
{
|
{
|
||||||
#ifdef GL_ARB_vertex_program
|
|
||||||
for (s32 i=0; i<constantAmount; ++i)
|
for (s32 i=0; i<constantAmount; ++i)
|
||||||
extGlProgramLocalParameter4fv(GL_VERTEX_PROGRAM_ARB, startRegister+i, &data[i*4]);
|
extGlProgramLocalParameter4fv(GL_VERTEX_PROGRAM_ARB, startRegister+i, &data[i*4]);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Sets a pixel shader constant.
|
//! Sets a pixel shader constant.
|
||||||
void COpenGLDriver::setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount)
|
void COpenGLDriver::setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount)
|
||||||
{
|
{
|
||||||
#ifdef GL_ARB_fragment_program
|
|
||||||
for (s32 i=0; i<constantAmount; ++i)
|
for (s32 i=0; i<constantAmount; ++i)
|
||||||
extGlProgramLocalParameter4fv(GL_FRAGMENT_PROGRAM_ARB, startRegister+i, &data[i*4]);
|
extGlProgramLocalParameter4fv(GL_FRAGMENT_PROGRAM_ARB, startRegister+i, &data[i*4]);
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Sets a constant for the vertex shader based on an index.
|
//! Sets a constant for the vertex shader based on an index.
|
||||||
@ -3695,6 +3691,12 @@ bool COpenGLDriver::setVertexShaderConstant(s32 index, const s32* ints, int coun
|
|||||||
return setPixelShaderConstant(index, ints, count);
|
return setPixelShaderConstant(index, ints, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
bool COpenGLDriver::setVertexShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
return setPixelShaderConstant(index, ints, count);
|
||||||
|
}
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
bool COpenGLDriver::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
bool COpenGLDriver::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
||||||
{
|
{
|
||||||
@ -3709,6 +3711,12 @@ bool COpenGLDriver::setPixelShaderConstant(s32 index, const s32* ints, int count
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COpenGLDriver::setPixelShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
os::Printer::log("Error: Please call services->setPixelShaderConstant(), not VideoDriver->setPixelShaderConstant().");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
//! Adds a new material renderer to the VideoDriver, using pixel and/or
|
//! Adds a new material renderer to the VideoDriver, using pixel and/or
|
||||||
//! vertex shaders to render geometry.
|
//! vertex shaders to render geometry.
|
||||||
|
@ -293,12 +293,18 @@ namespace video
|
|||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Sets a constant for the pixel shader based on an index.
|
//! Sets a constant for the pixel shader based on an index.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! Int interface for the above.
|
//! Int interface for the above.
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
|
//! Uint interface for the above.
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
|
||||||
//! disables all textures beginning with the optional fromStage parameter. Otherwise all texture stages are disabled.
|
//! disables all textures beginning with the optional fromStage parameter. Otherwise all texture stages are disabled.
|
||||||
//! Returns whether disabling was successful or not.
|
//! Returns whether disabling was successful or not.
|
||||||
bool disableTextures(u32 fromStage=0);
|
bool disableTextures(u32 fromStage=0);
|
||||||
|
@ -44,6 +44,7 @@ COpenGLExtensionHandler::COpenGLExtensionHandler() :
|
|||||||
pGlGetUniformLocationARB(0), pGlGetUniformLocation(0),
|
pGlGetUniformLocationARB(0), pGlGetUniformLocation(0),
|
||||||
pGlUniform1fvARB(0), pGlUniform2fvARB(0), pGlUniform3fvARB(0), pGlUniform4fvARB(0),
|
pGlUniform1fvARB(0), pGlUniform2fvARB(0), pGlUniform3fvARB(0), pGlUniform4fvARB(0),
|
||||||
pGlUniform1ivARB(0), pGlUniform2ivARB(0), pGlUniform3ivARB(0), pGlUniform4ivARB(0),
|
pGlUniform1ivARB(0), pGlUniform2ivARB(0), pGlUniform3ivARB(0), pGlUniform4ivARB(0),
|
||||||
|
pGlUniform1uiv(0), pGlUniform2uiv(0), pGlUniform3uiv(0), pGlUniform4uiv(0),
|
||||||
pGlUniformMatrix2fvARB(0), pGlUniformMatrix2x3fv(0), pGlUniformMatrix2x4fv(0),
|
pGlUniformMatrix2fvARB(0), pGlUniformMatrix2x3fv(0), pGlUniformMatrix2x4fv(0),
|
||||||
pGlUniformMatrix3x2fv(0), pGlUniformMatrix3fvARB(0), pGlUniformMatrix3x4fv(0),
|
pGlUniformMatrix3x2fv(0), pGlUniformMatrix3fvARB(0), pGlUniformMatrix3x4fv(0),
|
||||||
pGlUniformMatrix4x2fv(0), pGlUniformMatrix4x3fv(0), pGlUniformMatrix4fvARB(0),
|
pGlUniformMatrix4x2fv(0), pGlUniformMatrix4x3fv(0), pGlUniformMatrix4fvARB(0),
|
||||||
@ -87,7 +88,8 @@ COpenGLExtensionHandler::COpenGLExtensionHandler() :
|
|||||||
pGlBlendEquationIndexedAMD(0), pGlBlendEquationiARB(0), pGlBlendEquationSeparateIndexedAMD(0), pGlBlendEquationSeparateiARB(0),
|
pGlBlendEquationIndexedAMD(0), pGlBlendEquationiARB(0), pGlBlendEquationSeparateIndexedAMD(0), pGlBlendEquationSeparateiARB(0),
|
||||||
// DSA
|
// DSA
|
||||||
pGlTextureStorage2D(0), pGlTextureStorage3D(0), pGlTextureSubImage2D(0), pGlGetTextureImage(0), pGlNamedFramebufferTexture(0),
|
pGlTextureStorage2D(0), pGlTextureStorage3D(0), pGlTextureSubImage2D(0), pGlGetTextureImage(0), pGlNamedFramebufferTexture(0),
|
||||||
pGlTextureParameteri(0), pGlCreateTextures(0), pGlCreateFramebuffers(0), pGlBindTextures(0), pGlGenerateTextureMipmap(0),
|
pGlTextureParameteri(0), pGlTextureParameterf(0), pGlTextureParameteriv(0), pGlTextureParameterfv(0),
|
||||||
|
pGlCreateTextures(0), pGlCreateFramebuffers(0), pGlBindTextures(0), pGlGenerateTextureMipmap(0),
|
||||||
// DSA with EXT or functions to simulate it
|
// DSA with EXT or functions to simulate it
|
||||||
pGlTextureStorage2DEXT(0), pGlTexStorage2D(0), pGlTextureStorage3DEXT(0), pGlTexStorage3D(0), pGlTextureSubImage2DEXT(0), pGlGetTextureImageEXT(0),
|
pGlTextureStorage2DEXT(0), pGlTexStorage2D(0), pGlTextureStorage3DEXT(0), pGlTexStorage3D(0), pGlTextureSubImage2DEXT(0), pGlGetTextureImageEXT(0),
|
||||||
pGlNamedFramebufferTextureEXT(0), pGlFramebufferTexture(0), pGlGenerateTextureMipmapEXT(0)
|
pGlNamedFramebufferTextureEXT(0), pGlFramebufferTexture(0), pGlGenerateTextureMipmapEXT(0)
|
||||||
@ -466,6 +468,10 @@ void COpenGLExtensionHandler::initExtensions(bool stencilBuffer)
|
|||||||
pGlUniform2ivARB = (PFNGLUNIFORM2IVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniform2ivARB");
|
pGlUniform2ivARB = (PFNGLUNIFORM2IVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniform2ivARB");
|
||||||
pGlUniform3ivARB = (PFNGLUNIFORM3IVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniform3ivARB");
|
pGlUniform3ivARB = (PFNGLUNIFORM3IVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniform3ivARB");
|
||||||
pGlUniform4ivARB = (PFNGLUNIFORM4IVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniform4ivARB");
|
pGlUniform4ivARB = (PFNGLUNIFORM4IVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniform4ivARB");
|
||||||
|
pGlUniform1uiv = (PFNGLUNIFORM1UIVPROC) IRR_OGL_LOAD_EXTENSION("glUniform1uiv");
|
||||||
|
pGlUniform2uiv = (PFNGLUNIFORM2UIVPROC) IRR_OGL_LOAD_EXTENSION("glUniform2uiv");
|
||||||
|
pGlUniform3uiv = (PFNGLUNIFORM3UIVPROC) IRR_OGL_LOAD_EXTENSION("glUniform3uiv");
|
||||||
|
pGlUniform4uiv = (PFNGLUNIFORM4UIVPROC) IRR_OGL_LOAD_EXTENSION("glUniform4uiv");
|
||||||
pGlUniformMatrix2fvARB = (PFNGLUNIFORMMATRIX2FVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniformMatrix2fvARB");
|
pGlUniformMatrix2fvARB = (PFNGLUNIFORMMATRIX2FVARBPROC) IRR_OGL_LOAD_EXTENSION("glUniformMatrix2fvARB");
|
||||||
pGlUniformMatrix2x3fv = (PFNGLUNIFORMMATRIX2X3FVPROC) IRR_OGL_LOAD_EXTENSION("glUniformMatrix2x3fv");
|
pGlUniformMatrix2x3fv = (PFNGLUNIFORMMATRIX2X3FVPROC) IRR_OGL_LOAD_EXTENSION("glUniformMatrix2x3fv");
|
||||||
pGlUniformMatrix2x4fv = (PFNGLUNIFORMMATRIX2X4FVPROC)IRR_OGL_LOAD_EXTENSION("glUniformMatrix2x4fv");
|
pGlUniformMatrix2x4fv = (PFNGLUNIFORMMATRIX2X4FVPROC)IRR_OGL_LOAD_EXTENSION("glUniformMatrix2x4fv");
|
||||||
@ -581,6 +587,10 @@ void COpenGLExtensionHandler::initExtensions(bool stencilBuffer)
|
|||||||
pGlGetTextureImage = (PFNGLGETTEXTUREIMAGEPROC)IRR_OGL_LOAD_EXTENSION("glGetTextureImage");
|
pGlGetTextureImage = (PFNGLGETTEXTUREIMAGEPROC)IRR_OGL_LOAD_EXTENSION("glGetTextureImage");
|
||||||
pGlNamedFramebufferTexture = (PFNGLNAMEDFRAMEBUFFERTEXTUREPROC) IRR_OGL_LOAD_EXTENSION("glNamedFramebufferTexture");
|
pGlNamedFramebufferTexture = (PFNGLNAMEDFRAMEBUFFERTEXTUREPROC) IRR_OGL_LOAD_EXTENSION("glNamedFramebufferTexture");
|
||||||
pGlTextureParameteri = (PFNGLTEXTUREPARAMETERIPROC) IRR_OGL_LOAD_EXTENSION("glTextureParameteri");
|
pGlTextureParameteri = (PFNGLTEXTUREPARAMETERIPROC) IRR_OGL_LOAD_EXTENSION("glTextureParameteri");
|
||||||
|
pGlTextureParameterf = (PFNGLTEXTUREPARAMETERFPROC)IRR_OGL_LOAD_EXTENSION("glTextureParameterf");
|
||||||
|
pGlTextureParameteriv = (PFNGLTEXTUREPARAMETERIVPROC)IRR_OGL_LOAD_EXTENSION("glTextureParameteriv");
|
||||||
|
pGlTextureParameterfv = (PFNGLTEXTUREPARAMETERFVPROC)IRR_OGL_LOAD_EXTENSION("glTextureParameterfv");
|
||||||
|
|
||||||
pGlCreateTextures = (PFNGLCREATETEXTURESPROC) IRR_OGL_LOAD_EXTENSION("glCreateTextures");
|
pGlCreateTextures = (PFNGLCREATETEXTURESPROC) IRR_OGL_LOAD_EXTENSION("glCreateTextures");
|
||||||
pGlCreateFramebuffers = (PFNGLCREATEFRAMEBUFFERSPROC) IRR_OGL_LOAD_EXTENSION("glCreateFramebuffers");
|
pGlCreateFramebuffers = (PFNGLCREATEFRAMEBUFFERSPROC) IRR_OGL_LOAD_EXTENSION("glCreateFramebuffers");
|
||||||
pGlBindTextures = (PFNGLBINDTEXTURESPROC) IRR_OGL_LOAD_EXTENSION("glBindTextures");
|
pGlBindTextures = (PFNGLBINDTEXTURESPROC) IRR_OGL_LOAD_EXTENSION("glBindTextures");
|
||||||
|
@ -1127,6 +1127,10 @@ class COpenGLExtensionHandler
|
|||||||
void extGlUniform2iv(GLint loc, GLsizei count, const GLint *v);
|
void extGlUniform2iv(GLint loc, GLsizei count, const GLint *v);
|
||||||
void extGlUniform3iv(GLint loc, GLsizei count, const GLint *v);
|
void extGlUniform3iv(GLint loc, GLsizei count, const GLint *v);
|
||||||
void extGlUniform4iv(GLint loc, GLsizei count, const GLint *v);
|
void extGlUniform4iv(GLint loc, GLsizei count, const GLint *v);
|
||||||
|
void extGlUniform1uiv(GLint loc, GLsizei count, const GLuint *v);
|
||||||
|
void extGlUniform2uiv(GLint loc, GLsizei count, const GLuint *v);
|
||||||
|
void extGlUniform3uiv(GLint loc, GLsizei count, const GLuint *v);
|
||||||
|
void extGlUniform4uiv(GLint loc, GLsizei count, const GLuint *v);
|
||||||
void extGlUniformMatrix2fv(GLint loc, GLsizei count, GLboolean transpose, const GLfloat *v);
|
void extGlUniformMatrix2fv(GLint loc, GLsizei count, GLboolean transpose, const GLfloat *v);
|
||||||
void extGlUniformMatrix2x3fv(GLint loc, GLsizei count, GLboolean transpose, const GLfloat *v);
|
void extGlUniformMatrix2x3fv(GLint loc, GLsizei count, GLboolean transpose, const GLfloat *v);
|
||||||
void extGlUniformMatrix2x4fv(GLint loc, GLsizei count, GLboolean transpose, const GLfloat *v);
|
void extGlUniformMatrix2x4fv(GLint loc, GLsizei count, GLboolean transpose, const GLfloat *v);
|
||||||
@ -1199,6 +1203,9 @@ class COpenGLExtensionHandler
|
|||||||
void extGlGetTextureImage(GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void* pixels);
|
void extGlGetTextureImage(GLuint texture, GLenum target, GLint level, GLenum format, GLenum type, GLsizei bufSize, void* pixels);
|
||||||
void extGlNamedFramebufferTexture(GLuint framebuffer, GLenum attachment, GLuint texture, GLint level);
|
void extGlNamedFramebufferTexture(GLuint framebuffer, GLenum attachment, GLuint texture, GLint level);
|
||||||
void extGlTextureParameteri(GLuint texture, GLenum pname, GLint param);
|
void extGlTextureParameteri(GLuint texture, GLenum pname, GLint param);
|
||||||
|
void extGlTextureParameterf(GLuint texture, GLenum pname, GLfloat param);
|
||||||
|
void extGlTextureParameteriv(GLuint texture, GLenum pname, const GLint* params);
|
||||||
|
void extGlTextureParameterfv(GLuint texture, GLenum pname, const GLfloat* params);
|
||||||
void extGlCreateTextures(GLenum target, GLsizei n, GLuint* textures);
|
void extGlCreateTextures(GLenum target, GLsizei n, GLuint* textures);
|
||||||
void extGlCreateFramebuffers(GLsizei n, GLuint* framebuffers);
|
void extGlCreateFramebuffers(GLsizei n, GLuint* framebuffers);
|
||||||
void extGlBindTextures(GLuint first, GLsizei count, const GLuint *textures, const GLenum* targets);
|
void extGlBindTextures(GLuint first, GLsizei count, const GLuint *textures, const GLenum* targets);
|
||||||
@ -1262,6 +1269,10 @@ class COpenGLExtensionHandler
|
|||||||
PFNGLUNIFORM2IVARBPROC pGlUniform2ivARB;
|
PFNGLUNIFORM2IVARBPROC pGlUniform2ivARB;
|
||||||
PFNGLUNIFORM3IVARBPROC pGlUniform3ivARB;
|
PFNGLUNIFORM3IVARBPROC pGlUniform3ivARB;
|
||||||
PFNGLUNIFORM4IVARBPROC pGlUniform4ivARB;
|
PFNGLUNIFORM4IVARBPROC pGlUniform4ivARB;
|
||||||
|
PFNGLUNIFORM1UIVPROC pGlUniform1uiv;
|
||||||
|
PFNGLUNIFORM2UIVPROC pGlUniform2uiv;
|
||||||
|
PFNGLUNIFORM3UIVPROC pGlUniform3uiv;
|
||||||
|
PFNGLUNIFORM4UIVPROC pGlUniform4uiv;
|
||||||
PFNGLUNIFORMMATRIX2FVARBPROC pGlUniformMatrix2fvARB;
|
PFNGLUNIFORMMATRIX2FVARBPROC pGlUniformMatrix2fvARB;
|
||||||
PFNGLUNIFORMMATRIX2X3FVPROC pGlUniformMatrix2x3fv;
|
PFNGLUNIFORMMATRIX2X3FVPROC pGlUniformMatrix2x3fv;
|
||||||
PFNGLUNIFORMMATRIX2X4FVPROC pGlUniformMatrix2x4fv;
|
PFNGLUNIFORMMATRIX2X4FVPROC pGlUniformMatrix2x4fv;
|
||||||
@ -1365,6 +1376,10 @@ class COpenGLExtensionHandler
|
|||||||
PFNGLGETTEXTUREIMAGEPROC pGlGetTextureImage;
|
PFNGLGETTEXTUREIMAGEPROC pGlGetTextureImage;
|
||||||
PFNGLNAMEDFRAMEBUFFERTEXTUREPROC pGlNamedFramebufferTexture;
|
PFNGLNAMEDFRAMEBUFFERTEXTUREPROC pGlNamedFramebufferTexture;
|
||||||
PFNGLTEXTUREPARAMETERIPROC pGlTextureParameteri;
|
PFNGLTEXTUREPARAMETERIPROC pGlTextureParameteri;
|
||||||
|
PFNGLTEXTUREPARAMETERFPROC pGlTextureParameterf;
|
||||||
|
PFNGLTEXTUREPARAMETERIVPROC pGlTextureParameteriv;
|
||||||
|
PFNGLTEXTUREPARAMETERFVPROC pGlTextureParameterfv;
|
||||||
|
|
||||||
PFNGLCREATETEXTURESPROC pGlCreateTextures;
|
PFNGLCREATETEXTURESPROC pGlCreateTextures;
|
||||||
PFNGLCREATEFRAMEBUFFERSPROC pGlCreateFramebuffers;
|
PFNGLCREATEFRAMEBUFFERSPROC pGlCreateFramebuffers;
|
||||||
PFNGLBINDTEXTURESPROC pGlBindTextures;
|
PFNGLBINDTEXTURESPROC pGlBindTextures;
|
||||||
@ -1895,6 +1910,46 @@ inline void COpenGLExtensionHandler::extGlUniform4fv(GLint loc, GLsizei count, c
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlUniform1uiv(GLint loc, GLsizei count, const GLuint *v)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlUniform1uiv)
|
||||||
|
pGlUniform1uiv(loc, count, v);
|
||||||
|
#else
|
||||||
|
glUniform1uiv(loc, count, v);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlUniform2uiv(GLint loc, GLsizei count, const GLuint *v)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlUniform2uiv)
|
||||||
|
pGlUniform2uiv(loc, count, v);
|
||||||
|
#else
|
||||||
|
glUniform2uiv(loc, count, v);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlUniform3uiv(GLint loc, GLsizei count, const GLuint *v)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlUniform3uiv)
|
||||||
|
pGlUniform3uiv(loc, count, v);
|
||||||
|
#else
|
||||||
|
glUniform3uiv(loc, count, v);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlUniform4uiv(GLint loc, GLsizei count, const GLuint *v)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlUniform4uiv)
|
||||||
|
pGlUniform4uiv(loc, count, v);
|
||||||
|
#else
|
||||||
|
glUniform4uiv(loc, count, v);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
inline void COpenGLExtensionHandler::extGlUniform1iv(GLint loc, GLsizei count, const GLint *v)
|
inline void COpenGLExtensionHandler::extGlUniform1iv(GLint loc, GLsizei count, const GLint *v)
|
||||||
{
|
{
|
||||||
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
@ -3038,8 +3093,30 @@ inline void COpenGLExtensionHandler::extGlTextureParameteri(GLuint texture, GLen
|
|||||||
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
if (pGlTextureParameteri)
|
if (pGlTextureParameteri)
|
||||||
pGlTextureParameteri(texture, pname, param);
|
pGlTextureParameteri(texture, pname, param);
|
||||||
#else
|
#endif//_IRR_OPENGL_USE_EXTPOINTER_
|
||||||
// TODO
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlTextureParameterf(GLuint texture, GLenum pname, GLfloat param)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlTextureParameterf)
|
||||||
|
pGlTextureParameterf(texture, pname, param);
|
||||||
|
#endif//_IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlTextureParameteriv(GLuint texture, GLenum pname, const GLint* params)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlTextureParameteriv)
|
||||||
|
pGlTextureParameteriv(texture, pname, params);
|
||||||
|
#endif//_IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void COpenGLExtensionHandler::extGlTextureParameterfv(GLuint texture, GLenum pname, const GLfloat* params)
|
||||||
|
{
|
||||||
|
#ifdef _IRR_OPENGL_USE_EXTPOINTER_
|
||||||
|
if (pGlTextureParameterfv)
|
||||||
|
pGlTextureParameterfv(texture, pname, params);
|
||||||
#endif//_IRR_OPENGL_USE_EXTPOINTER_
|
#endif//_IRR_OPENGL_USE_EXTPOINTER_
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -608,9 +608,13 @@ bool COpenGLSLMaterialRenderer::setVertexShaderConstant(s32 index, const s32* in
|
|||||||
return setPixelShaderConstant(index, ints, count);
|
return setPixelShaderConstant(index, ints, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool COpenGLSLMaterialRenderer::setVertexShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
return setPixelShaderConstant(index, ints, count);
|
||||||
|
}
|
||||||
|
|
||||||
bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const f32* floats, int count)
|
||||||
{
|
{
|
||||||
#ifdef GL_ARB_shader_objects
|
|
||||||
if(index < 0 || UniformInfo[index].location < 0)
|
if(index < 0 || UniformInfo[index].location < 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -678,14 +682,10 @@ bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const f32* flo
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return status;
|
return status;
|
||||||
#else
|
|
||||||
return false;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const s32* ints, int count)
|
bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const s32* ints, int count)
|
||||||
{
|
{
|
||||||
#ifdef GL_ARB_shader_objects
|
|
||||||
if(index < 0 || UniformInfo[index].location < 0)
|
if(index < 0 || UniformInfo[index].location < 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -722,9 +722,34 @@ bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const s32* int
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return status;
|
return status;
|
||||||
#else
|
}
|
||||||
return false;
|
|
||||||
#endif
|
bool COpenGLSLMaterialRenderer::setPixelShaderConstant(s32 index, const u32* ints, int count)
|
||||||
|
{
|
||||||
|
if(index < 0 || UniformInfo[index].location < 0)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
bool status = true;
|
||||||
|
|
||||||
|
switch (UniformInfo[index].type)
|
||||||
|
{
|
||||||
|
case GL_UNSIGNED_INT:
|
||||||
|
Driver->extGlUniform1uiv(UniformInfo[index].location, count, reinterpret_cast<const GLuint*>(ints));
|
||||||
|
break;
|
||||||
|
case GL_UNSIGNED_INT_VEC2:
|
||||||
|
Driver->extGlUniform2uiv(UniformInfo[index].location, count/2, reinterpret_cast<const GLuint*>(ints));
|
||||||
|
break;
|
||||||
|
case GL_UNSIGNED_INT_VEC3:
|
||||||
|
Driver->extGlUniform3uiv(UniformInfo[index].location, count/3, reinterpret_cast<const GLuint*>(ints));
|
||||||
|
break;
|
||||||
|
case GL_UNSIGNED_INT_VEC4:
|
||||||
|
Driver->extGlUniform4uiv(UniformInfo[index].location, count/4, reinterpret_cast<const GLuint*>(ints));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
status = false;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
IVideoDriver* COpenGLSLMaterialRenderer::getVideoDriver()
|
IVideoDriver* COpenGLSLMaterialRenderer::getVideoDriver()
|
||||||
|
@ -79,8 +79,10 @@ public:
|
|||||||
virtual void setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) _IRR_OVERRIDE_;
|
virtual void setPixelShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) _IRR_OVERRIDE_;
|
||||||
virtual bool setVertexShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
virtual bool setVertexShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setVertexShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setVertexShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const f32* floats, int count) _IRR_OVERRIDE_;
|
||||||
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
virtual bool setPixelShaderConstant(s32 index, const s32* ints, int count) _IRR_OVERRIDE_;
|
||||||
|
virtual bool setPixelShaderConstant(s32 index, const u32* ints, int count) _IRR_OVERRIDE_;
|
||||||
virtual IVideoDriver* getVideoDriver() _IRR_OVERRIDE_;
|
virtual IVideoDriver* getVideoDriver() _IRR_OVERRIDE_;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
Tests finished. 72 tests of 72 passed.
|
Tests finished. 72 tests of 72 passed.
|
||||||
Compiled as DEBUG
|
Compiled as DEBUG
|
||||||
Test suite pass at GMT Fri Jan 3 17:05:41 2020
|
Test suite pass at GMT Mon Feb 10 14:59:56 2020
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user