Remove ugly shader hacks that are no more needed (and now even harmful) with latest irrlicht svn. You will need to update irrlicht
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@11408 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
178ec7eb18
commit
aa2f831ca0
@ -56,13 +56,11 @@ public:
|
|||||||
irr::video::IMaterialRendererServices *services,
|
irr::video::IMaterialRendererServices *services,
|
||||||
s32 userData)
|
s32 userData)
|
||||||
{
|
{
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 decaltex = 0;
|
||||||
int decaltex = 0;
|
services->setPixelShaderConstant("DecalTex", &decaltex, 1);
|
||||||
services->setPixelShaderConstant("DecalTex", (float*)&decaltex, 1);
|
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 bumptex = 1;
|
||||||
int bumptex = 1;
|
services->setPixelShaderConstant("BumpTex", &bumptex, 1);
|
||||||
services->setPixelShaderConstant("BumpTex", (float*)&bumptex, 1);
|
|
||||||
|
|
||||||
// We could calculate light direction as coming from the sun (then we'd need to
|
// We could calculate light direction as coming from the sun (then we'd need to
|
||||||
// transform it into camera space). But I find that pretending light
|
// transform it into camera space). But I find that pretending light
|
||||||
@ -120,17 +118,14 @@ public:
|
|||||||
if (m_dx_2 > 1.0f) m_dx_2 -= 1.0f;
|
if (m_dx_2 > 1.0f) m_dx_2 -= 1.0f;
|
||||||
if (m_dy_2 < 0.0f) m_dy_2 += 1.0f;
|
if (m_dy_2 < 0.0f) m_dy_2 += 1.0f;
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 decaltex = 0;
|
||||||
int decaltex = 0;
|
services->setPixelShaderConstant("DecalTex", &decaltex, 1);
|
||||||
services->setPixelShaderConstant("DecalTex", (float*)&decaltex, 1);
|
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 bumptex = 1;
|
||||||
int bumptex = 1;
|
services->setPixelShaderConstant("BumpTex1", &bumptex, 1);
|
||||||
services->setPixelShaderConstant("BumpTex1", (float*)&bumptex, 1);
|
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
|
||||||
bumptex = 2;
|
bumptex = 2;
|
||||||
services->setPixelShaderConstant("BumpTex2", (float*)&bumptex, 1);
|
services->setPixelShaderConstant("BumpTex2", &bumptex, 1);
|
||||||
|
|
||||||
// We could calculate light direction as coming from the sun (then we'd need to
|
// We could calculate light direction as coming from the sun (then we'd need to
|
||||||
// transform it into camera space). But I find that pretending light
|
// transform it into camera space). But I find that pretending light
|
||||||
@ -146,10 +141,10 @@ public:
|
|||||||
Track* t = World::getWorld()->getTrack();
|
Track* t = World::getWorld()->getTrack();
|
||||||
|
|
||||||
float fogStart = t->getFogStart();
|
float fogStart = t->getFogStart();
|
||||||
services->setPixelShaderConstant("fogFrom", (float*)&fogStart, 1);
|
services->setPixelShaderConstant("fogFrom", &fogStart, 1);
|
||||||
|
|
||||||
float fogEnd = t->getFogEnd();
|
float fogEnd = t->getFogEnd();
|
||||||
services->setPixelShaderConstant("fogTo", (float*)&fogEnd, 1);
|
services->setPixelShaderConstant("fogTo", &fogEnd, 1);
|
||||||
|
|
||||||
video::SColor fogColor = t->getFogColor();
|
video::SColor fogColor = t->getFogColor();
|
||||||
float fogColorVec[] = {fogColor.getRed()/255.0f,
|
float fogColorVec[] = {fogColor.getRed()/255.0f,
|
||||||
@ -190,25 +185,20 @@ public:
|
|||||||
m_light_direction = -World::getWorld()->getTrack()->getSunRotation().rotationToDirection();
|
m_light_direction = -World::getWorld()->getTrack()->getSunRotation().rotationToDirection();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 tex_layout = 0;
|
||||||
int tex_layout = 0;
|
services->setPixelShaderConstant("tex_layout", &tex_layout, 1);
|
||||||
services->setPixelShaderConstant("tex_layout", (float*)&tex_layout, 1);
|
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 tex_detail0 = 1;
|
||||||
int tex_detail0 = 1;
|
services->setPixelShaderConstant("tex_detail0", &tex_detail0, 1);
|
||||||
services->setPixelShaderConstant("tex_detail0", (float*)&tex_detail0, 1);
|
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 tex_detail1 = 2;
|
||||||
int tex_detail1 = 2;
|
services->setPixelShaderConstant("tex_detail1", &tex_detail1, 1);
|
||||||
services->setPixelShaderConstant("tex_detail1", (float*)&tex_detail1, 1);
|
|
||||||
|
s32 tex_detail2 = 3;
|
||||||
|
services->setPixelShaderConstant("tex_detail2", &tex_detail2, 1);
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 tex_detail3 = 4;
|
||||||
int tex_detail2 = 3;
|
services->setPixelShaderConstant("tex_detail3", &tex_detail3, 1);
|
||||||
services->setPixelShaderConstant("tex_detail2", (float*)&tex_detail2, 1);
|
|
||||||
|
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
|
||||||
int tex_detail3 = 4;
|
|
||||||
services->setPixelShaderConstant("tex_detail3", (float*)&tex_detail3, 1);
|
|
||||||
|
|
||||||
services->setVertexShaderConstant("lightdir", &m_light_direction.X, 3);
|
services->setVertexShaderConstant("lightdir", &m_light_direction.X, 3);
|
||||||
}
|
}
|
||||||
@ -237,9 +227,8 @@ public:
|
|||||||
irr::video::IMaterialRendererServices *services,
|
irr::video::IMaterialRendererServices *services,
|
||||||
s32 userData)
|
s32 userData)
|
||||||
{
|
{
|
||||||
// Irrlicht knows this is actually a GLint and makes the conversion
|
s32 texture = 0;
|
||||||
int texture = 0;
|
services->setPixelShaderConstant("texture", &texture, 1);
|
||||||
services->setPixelShaderConstant("texture", (float*)&texture, 1);
|
|
||||||
|
|
||||||
services->setVertexShaderConstant("lightdir", &m_light_direction.X, 3);
|
services->setVertexShaderConstant("lightdir", &m_light_direction.X, 3);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user