Add water shader for the overworld. Feedback ewlcome

git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/trunk@10743 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
auria 2012-01-29 16:39:30 +00:00
parent 652e3180f0
commit 71118f24cf
2 changed files with 8 additions and 9 deletions

View File

@ -47,13 +47,13 @@ void main()
{ {
// weak specular // weak specular
specular = specular*specular; specular = specular*specular;
float specular_weak = specular*0.1; specular = specular*specular;
float specular_weak = specular*0.05;
gl_FragColor += vec4(specular_weak, specular_weak, specular_weak, 0.0); gl_FragColor += vec4(specular_weak, specular_weak, specular_weak, 0.0);
// strong specular // strong specular
specular = specular*specular; specular = specular*specular;
specular = specular*specular; float specular_strong = specular*0.3;
float specular_strong = specular*0.4;
gl_FragColor += vec4(specular_strong, specular_strong, specular_strong, 0.0); gl_FragColor += vec4(specular_strong, specular_strong, specular_strong, 0.0);
} }
} }

View File

@ -92,11 +92,11 @@ public:
irr::video::IMaterialRendererServices *services, irr::video::IMaterialRendererServices *services,
s32 userData) s32 userData)
{ {
m_dx_1 += GUIEngine::getLatestDt()/6.0f; m_dx_1 += GUIEngine::getLatestDt()/15.0f;
m_dy_1 += GUIEngine::getLatestDt()/6.0f; m_dy_1 += GUIEngine::getLatestDt()/15.0f;
m_dx_2 += GUIEngine::getLatestDt()/15.0f; m_dx_2 += GUIEngine::getLatestDt()/25.0f;
m_dy_2 -= GUIEngine::getLatestDt()/15.0f; m_dy_2 -= GUIEngine::getLatestDt()/25.0f;
if (m_dx_1 > 1.0f) m_dx_1 -= 1.0f; if (m_dx_1 > 1.0f) m_dx_1 -= 1.0f;
if (m_dy_1 > 1.0f) m_dy_1 -= 1.0f; if (m_dy_1 > 1.0f) m_dy_1 -= 1.0f;
@ -118,7 +118,7 @@ public:
// 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
// comes from the camera gives good results // comes from the camera gives good results
const float lightdir[] = {0.0f, 0.95f, -0.312f}; const float lightdir[] = {-0.315f, 0.91f, -0.3f};
services->setVertexShaderConstant("lightdir", lightdir, 3); services->setVertexShaderConstant("lightdir", lightdir, 3);
services->setVertexShaderConstant("delta1", &m_dx_1, 2); services->setVertexShaderConstant("delta1", &m_dx_1, 2);
@ -976,7 +976,6 @@ void Material::setMaterialProperties(video::SMaterial *m, scene::IMeshBuffer* m
if (m_water_shader) if (m_water_shader)
{ {
printf("==== WATER SHADER ====\n");
if (m_shaders[WATER_SHADER] == NULL) if (m_shaders[WATER_SHADER] == NULL)
{ {
m_shaders[WATER_SHADER] = new WaterShaderProvider(); m_shaders[WATER_SHADER] = new WaterShaderProvider();