aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/lldrawpoolwater.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/lldrawpoolwater.cpp')
-rw-r--r--linden/indra/newview/lldrawpoolwater.cpp40
1 files changed, 20 insertions, 20 deletions
diff --git a/linden/indra/newview/lldrawpoolwater.cpp b/linden/indra/newview/lldrawpoolwater.cpp
index d8303bd..5914ffc 100644
--- a/linden/indra/newview/lldrawpoolwater.cpp
+++ b/linden/indra/newview/lldrawpoolwater.cpp
@@ -4,7 +4,7 @@
4 * 4 *
5 * $LicenseInfo:firstyear=2002&license=viewergpl$ 5 * $LicenseInfo:firstyear=2002&license=viewergpl$
6 * 6 *
7 * Copyright (c) 2002-2008, Linden Research, Inc. 7 * Copyright (c) 2002-2009, Linden Research, Inc.
8 * 8 *
9 * Second Life Viewer Source Code 9 * Second Life Viewer Source Code
10 * The source code in this file ("Source Code") is provided by Linden Lab 10 * The source code in this file ("Source Code") is provided by Linden Lab
@@ -68,11 +68,11 @@ LLDrawPoolWater::LLDrawPoolWater() :
68 LLFacePool(POOL_WATER) 68 LLFacePool(POOL_WATER)
69{ 69{
70 mHBTex[0] = gImageList.getImage(gSunTextureID, TRUE, TRUE); 70 mHBTex[0] = gImageList.getImage(gSunTextureID, TRUE, TRUE);
71 mHBTex[0]->bind(); 71 gGL.getTexUnit(0)->bind(mHBTex[0].get());
72 mHBTex[0]->setClamp(TRUE, TRUE); 72 mHBTex[0]->setClamp(TRUE, TRUE);
73 73
74 mHBTex[1] = gImageList.getImage(gMoonTextureID, TRUE, TRUE); 74 mHBTex[1] = gImageList.getImage(gMoonTextureID, TRUE, TRUE);
75 mHBTex[1]->bind(); 75 gGL.getTexUnit(0)->bind(mHBTex[1].get());
76 mHBTex[1]->setClamp(TRUE, TRUE); 76 mHBTex[1]->setClamp(TRUE, TRUE);
77 77
78 mWaterImagep = gImageList.getImage(WATER_TEST); 78 mWaterImagep = gImageList.getImage(WATER_TEST);
@@ -166,10 +166,9 @@ void LLDrawPoolWater::render(S32 pass)
166 166
167 // Set up second pass first 167 // Set up second pass first
168 mWaterImagep->addTextureStats(1024.f*1024.f); 168 mWaterImagep->addTextureStats(1024.f*1024.f);
169 mWaterImagep->bind(1);
170 gGL.getTexUnit(1)->activate(); 169 gGL.getTexUnit(1)->activate();
171 170 gGL.getTexUnit(1)->enable(LLTexUnit::TT_TEXTURE);
172 glEnable(GL_TEXTURE_2D); // Texture unit 1 171 gGL.getTexUnit(1)->bind(mWaterImagep.get());
173 172
174 LLVector3 camera_up = LLViewerCamera::getInstance()->getUpAxis(); 173 LLVector3 camera_up = LLViewerCamera::getInstance()->getUpAxis();
175 F32 up_dot = camera_up * LLVector3::z_axis; 174 F32 up_dot = camera_up * LLVector3::z_axis;
@@ -218,20 +217,20 @@ void LLDrawPoolWater::render(S32 pass)
218 { 217 {
219 continue; 218 continue;
220 } 219 }
221 face->bindTexture(); 220 gGL.getTexUnit(0)->bind(face->getTexture());
222 face->renderIndexed(); 221 face->renderIndexed();
223 } 222 }
224 223
225 // Now, disable texture coord generation on texture state 1 224 // Now, disable texture coord generation on texture state 1
226 gGL.getTexUnit(1)->activate(); 225 gGL.getTexUnit(1)->activate();
227 glDisable(GL_TEXTURE_2D); // Texture unit 1 226 gGL.getTexUnit(1)->unbind(LLTexUnit::TT_TEXTURE);
227 gGL.getTexUnit(1)->disable();
228 glDisable(GL_TEXTURE_GEN_S); //texture unit 1 228 glDisable(GL_TEXTURE_GEN_S); //texture unit 1
229 glDisable(GL_TEXTURE_GEN_T); //texture unit 1 229 glDisable(GL_TEXTURE_GEN_T); //texture unit 1
230 LLImageGL::unbindTexture(1, GL_TEXTURE_2D);
231 230
232 // Disable texture coordinate and color arrays 231 // Disable texture coordinate and color arrays
233 gGL.getTexUnit(0)->activate(); 232 gGL.getTexUnit(0)->activate();
234 LLImageGL::unbindTexture(0, GL_TEXTURE_2D); 233 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
235 234
236 stop_glerror(); 235 stop_glerror();
237 236
@@ -275,8 +274,9 @@ void LLDrawPoolWater::render(S32 pass)
275 { 274 {
276 gSky.mVOSkyp->getCubeMap()->disable(); 275 gSky.mVOSkyp->getCubeMap()->disable();
277 } 276 }
278 LLImageGL::unbindTexture(0, GL_TEXTURE_2D); 277
279 glEnable(GL_TEXTURE_2D); 278 gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE);
279 gGL.getTexUnit(0)->enable(LLTexUnit::TT_TEXTURE);
280 glMatrixMode(GL_TEXTURE); 280 glMatrixMode(GL_TEXTURE);
281 glLoadIdentity(); 281 glLoadIdentity();
282 glMatrixMode(GL_MODELVIEW); 282 glMatrixMode(GL_MODELVIEW);
@@ -316,7 +316,7 @@ void LLDrawPoolWater::renderReflection(LLFace* face)
316 316
317 LLGLSNoFog noFog; 317 LLGLSNoFog noFog;
318 318
319 LLViewerImage::bindTexture(mHBTex[dr]); 319 gGL.getTexUnit(0)->bind(mHBTex[dr].get());
320 320
321 LLOverrideFaceColor override(this, face->getFaceColor().mV); 321 LLOverrideFaceColor override(this, face->getFaceColor().mV);
322 face->renderIndexed(); 322 face->renderIndexed();
@@ -390,7 +390,7 @@ void LLDrawPoolWater::shade()
390 if (reftex > -1) 390 if (reftex > -1)
391 { 391 {
392 gGL.getTexUnit(reftex)->activate(); 392 gGL.getTexUnit(reftex)->activate();
393 gPipeline.mWaterRef.bindTexture(); 393 gGL.getTexUnit(reftex)->bind(&gPipeline.mWaterRef);
394 gGL.getTexUnit(0)->activate(); 394 gGL.getTexUnit(0)->activate();
395 } 395 }
396 396
@@ -406,7 +406,7 @@ void LLDrawPoolWater::shade()
406 } 406 }
407 407
408 mWaterNormp->addTextureStats(1024.f*1024.f); 408 mWaterNormp->addTextureStats(1024.f*1024.f);
409 mWaterNormp->bind(bumpTex); 409 gGL.getTexUnit(bumpTex)->bind(mWaterNormp.get());
410 mWaterNormp->setMipFilterNearest (mWaterNormp->getMipFilterNearest(), 410 mWaterNormp->setMipFilterNearest (mWaterNormp->getMipFilterNearest(),
411 !gSavedSettings.getBOOL("RenderWaterMipNormal")); 411 !gSavedSettings.getBOOL("RenderWaterMipNormal"));
412 412
@@ -421,8 +421,8 @@ void LLDrawPoolWater::shade()
421 shader->uniform1f(LLViewerShaderMgr::WATER_FOGDENSITY, 421 shader->uniform1f(LLViewerShaderMgr::WATER_FOGDENSITY,
422 param_mgr->getFogDensity()); 422 param_mgr->getFogDensity());
423 } 423 }
424 424
425 gPipeline.mWaterDis.bindTexture(); 425 gGL.getTexUnit(screentex)->bind(&gPipeline.mWaterDis);
426 426
427 if (mVertexShaderLevel == 1) 427 if (mVertexShaderLevel == 1)
428 { 428 {
@@ -502,7 +502,7 @@ void LLDrawPoolWater::shade()
502 } 502 }
503 503
504 LLVOWater* water = (LLVOWater*) face->getViewerObject(); 504 LLVOWater* water = (LLVOWater*) face->getViewerObject();
505 face->bindTexture(diffTex); 505 gGL.getTexUnit(diffTex)->bind(face->getTexture());
506 506
507 sNeedsReflectionUpdate = TRUE; 507 sNeedsReflectionUpdate = TRUE;
508 508
@@ -527,7 +527,7 @@ void LLDrawPoolWater::shade()
527 } 527 }
528 } 528 }
529 529
530 shader->disableTexture(LLViewerShaderMgr::ENVIRONMENT_MAP, GL_TEXTURE_CUBE_MAP_ARB); 530 shader->disableTexture(LLViewerShaderMgr::ENVIRONMENT_MAP, LLTexUnit::TT_CUBE_MAP);
531 shader->disableTexture(LLViewerShaderMgr::WATER_SCREENTEX); 531 shader->disableTexture(LLViewerShaderMgr::WATER_SCREENTEX);
532 shader->disableTexture(LLViewerShaderMgr::BUMP_MAP); 532 shader->disableTexture(LLViewerShaderMgr::BUMP_MAP);
533 shader->disableTexture(LLViewerShaderMgr::DIFFUSE_MAP); 533 shader->disableTexture(LLViewerShaderMgr::DIFFUSE_MAP);
@@ -536,7 +536,7 @@ void LLDrawPoolWater::shade()
536 shader->unbind(); 536 shader->unbind();
537 537
538 gGL.getTexUnit(0)->activate(); 538 gGL.getTexUnit(0)->activate();
539 glEnable(GL_TEXTURE_2D); 539 gGL.getTexUnit(0)->enable(LLTexUnit::TT_TEXTURE);
540 gGL.setColorMask(true, false); 540 gGL.setColorMask(true, false);
541 541
542} 542}