aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/pipeline.cpp
diff options
context:
space:
mode:
authorJacek Antonelli2008-08-15 23:45:44 -0500
committerJacek Antonelli2008-08-15 23:45:44 -0500
commitacfdcf2b1deeb04698174c78e8cb22b093445bb1 (patch)
tree811293650bcf81d01ea7c54d7c2cf263110aa329 /linden/indra/newview/pipeline.cpp
parentSecond Life viewer sources 1.20.2 (diff)
downloadmeta-impy-acfdcf2b1deeb04698174c78e8cb22b093445bb1.zip
meta-impy-acfdcf2b1deeb04698174c78e8cb22b093445bb1.tar.gz
meta-impy-acfdcf2b1deeb04698174c78e8cb22b093445bb1.tar.bz2
meta-impy-acfdcf2b1deeb04698174c78e8cb22b093445bb1.tar.xz
Second Life viewer sources 1.20.3
Diffstat (limited to 'linden/indra/newview/pipeline.cpp')
-rw-r--r--linden/indra/newview/pipeline.cpp58
1 files changed, 33 insertions, 25 deletions
diff --git a/linden/indra/newview/pipeline.cpp b/linden/indra/newview/pipeline.cpp
index 5f45e26..92a9811 100644
--- a/linden/indra/newview/pipeline.cpp
+++ b/linden/indra/newview/pipeline.cpp
@@ -168,7 +168,7 @@ glh::matrix4f glh_get_current_projection()
168 return glh_copy_matrix(gGLProjection); 168 return glh_copy_matrix(gGLProjection);
169} 169}
170 170
171void glh_copy_matrix(glh::matrix4f& src, GLdouble* dst) 171void glh_copy_matrix(const glh::matrix4f& src, GLdouble* dst)
172{ 172{
173 for (U32 i = 0; i < 16; i++) 173 for (U32 i = 0; i < 16; i++)
174 { 174 {
@@ -176,7 +176,7 @@ void glh_copy_matrix(glh::matrix4f& src, GLdouble* dst)
176 } 176 }
177} 177}
178 178
179void glh_set_current_modelview(glh::matrix4f& mat) 179void glh_set_current_modelview(const glh::matrix4f& mat)
180{ 180{
181 glh_copy_matrix(mat, gGLModelView); 181 glh_copy_matrix(mat, gGLModelView);
182} 182}
@@ -2144,9 +2144,9 @@ void render_hud_elements()
2144 LLViewerParcelMgr::getInstance()->renderParcelCollision(); 2144 LLViewerParcelMgr::getInstance()->renderParcelCollision();
2145 2145
2146 // Render debugging beacons. 2146 // Render debugging beacons.
2147 gObjectList.renderObjectBeacons(); 2147 //gObjectList.renderObjectBeacons();
2148 LLHUDObject::renderAll(); 2148 //LLHUDObject::renderAll();
2149 gObjectList.resetObjectBeacons(); 2149 //gObjectList.resetObjectBeacons();
2150 } 2150 }
2151 else if (gForceRenderLandFence) 2151 else if (gForceRenderLandFence)
2152 { 2152 {
@@ -2253,11 +2253,11 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate)
2253 // 2253 //
2254 // 2254 //
2255 2255
2256 glEnableClientState(GL_VERTEX_ARRAY);
2257
2258 stop_glerror(); 2256 stop_glerror();
2259 gFrameStats.start(LLFrameStats::RENDER_SYNC); 2257 gFrameStats.start(LLFrameStats::RENDER_SYNC);
2260 2258
2259 glEnableClientState(GL_VERTEX_ARRAY);
2260
2261 // Do verification of GL state 2261 // Do verification of GL state
2262#ifndef LL_RELEASE_FOR_DOWNLOAD 2262#ifndef LL_RELEASE_FOR_DOWNLOAD
2263 LLGLState::checkStates(); 2263 LLGLState::checkStates();
@@ -2377,10 +2377,10 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate)
2377 break; 2377 break;
2378 } 2378 }
2379 2379
2380 p->resetTrianglesDrawn();
2381 p->render(i); 2380 p->render(i);
2382 } 2381 }
2383 poolp->endRenderPass(i); 2382 poolp->endRenderPass(i);
2383 LLVertexBuffer::unbind();
2384#ifndef LL_RELEASE_FOR_DOWNLOAD 2384#ifndef LL_RELEASE_FOR_DOWNLOAD
2385# if LL_DEBUG_GL 2385# if LL_DEBUG_GL
2386 GLint depth; 2386 GLint depth;
@@ -2413,6 +2413,7 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate)
2413 } 2413 }
2414 } 2414 }
2415 2415
2416 LLVertexBuffer::unbind();
2416#ifndef LL_RELEASE_FOR_DOWNLOAD 2417#ifndef LL_RELEASE_FOR_DOWNLOAD
2417 LLGLState::checkStates(); 2418 LLGLState::checkStates();
2418 LLGLState::checkTextureChannels(); 2419 LLGLState::checkTextureChannels();
@@ -2452,6 +2453,15 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate)
2452 LLVertexBuffer::stopRender(); 2453 LLVertexBuffer::stopRender();
2453 LLVertexBuffer::unbind(); 2454 LLVertexBuffer::unbind();
2454 2455
2456 if (!LLPipeline::sReflectionRender && gPipeline.hasRenderDebugFeatureMask(LLPipeline::RENDER_DEBUG_FEATURE_UI))
2457 {
2458 gGL.start();
2459 // Render debugging beacons.
2460 gObjectList.renderObjectBeacons();
2461 LLHUDObject::renderAll();
2462 gObjectList.resetObjectBeacons();
2463 gGL.stop();
2464 }
2455 2465
2456 //HACK: preserve/restore matrices around HUD render 2466 //HACK: preserve/restore matrices around HUD render
2457 if (gPipeline.hasRenderType(LLPipeline::RENDER_TYPE_HUD)) 2467 if (gPipeline.hasRenderType(LLPipeline::RENDER_TYPE_HUD))
@@ -2472,15 +2482,9 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate)
2472 2482
2473void LLPipeline::renderGeomDeferred() 2483void LLPipeline::renderGeomDeferred()
2474{ 2484{
2475 glEnableClientState(GL_TEXTURE_COORD_ARRAY);
2476 glEnableClientState(GL_NORMAL_ARRAY);
2477 glEnableClientState(GL_COLOR_ARRAY);
2478 gDeferredDiffuseProgram.bind(); 2485 gDeferredDiffuseProgram.bind();
2479 gPipeline.renderObjects(LLRenderPass::PASS_SIMPLE, LLVertexBuffer::MAP_VERTEX | LLVertexBuffer::MAP_TEXCOORD | LLVertexBuffer::MAP_COLOR | LLVertexBuffer::MAP_NORMAL, TRUE); 2486 gPipeline.renderObjects(LLRenderPass::PASS_SIMPLE, LLVertexBuffer::MAP_VERTEX | LLVertexBuffer::MAP_TEXCOORD | LLVertexBuffer::MAP_COLOR | LLVertexBuffer::MAP_NORMAL, TRUE);
2480 gDeferredDiffuseProgram.unbind(); 2487 gDeferredDiffuseProgram.unbind();
2481 glDisableClientState(GL_COLOR_ARRAY);
2482 glDisableClientState(GL_NORMAL_ARRAY);
2483 glDisableClientState(GL_TEXTURE_COORD_ARRAY);
2484} 2488}
2485 2489
2486void LLPipeline::addTrianglesDrawn(S32 count) 2490void LLPipeline::addTrianglesDrawn(S32 count)
@@ -2506,11 +2510,6 @@ void LLPipeline::renderDebug()
2506 2510
2507 gGL.start(); 2511 gGL.start();
2508 2512
2509 // Disable all client state
2510 //glDisableClientState(GL_TEXTURE_COORD_ARRAY);
2511 //glDisableClientState(GL_NORMAL_ARRAY);
2512 //glDisableClientState(GL_COLOR_ARRAY);
2513
2514 gGLLastMatrix = NULL; 2513 gGLLastMatrix = NULL;
2515 glLoadMatrixd(gGLModelView); 2514 glLoadMatrixd(gGLModelView);
2516 glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE); 2515 glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE);
@@ -2603,8 +2602,6 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects)
2603 LLGLDepthTest gls_depth(GL_TRUE,GL_TRUE); 2602 LLGLDepthTest gls_depth(GL_TRUE,GL_TRUE);
2604 disableLights(); 2603 disableLights();
2605 2604
2606 glEnableClientState ( GL_VERTEX_ARRAY );
2607
2608 //for each drawpool 2605 //for each drawpool
2609#ifndef LL_RELEASE_FOR_DOWNLOAD 2606#ifndef LL_RELEASE_FOR_DOWNLOAD
2610 LLGLState::checkStates(); 2607 LLGLState::checkStates();
@@ -2619,7 +2616,7 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects)
2619 { 2616 {
2620 LLFacePool* face_pool = (LLFacePool*) poolp; 2617 LLFacePool* face_pool = (LLFacePool*) poolp;
2621 face_pool->renderForSelect(); 2618 face_pool->renderForSelect();
2622 2619 LLVertexBuffer::unbind();
2623 gGLLastMatrix = NULL; 2620 gGLLastMatrix = NULL;
2624 glLoadMatrixd(gGLModelView); 2621 glLoadMatrixd(gGLModelView);
2625 2622
@@ -2635,7 +2632,6 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects)
2635 } 2632 }
2636 } 2633 }
2637 2634
2638 glEnableClientState(GL_TEXTURE_COORD_ARRAY);
2639 LLGLEnable alpha_test(GL_ALPHA_TEST); 2635 LLGLEnable alpha_test(GL_ALPHA_TEST);
2640 if (gPickTransparent) 2636 if (gPickTransparent)
2641 { 2637 {
@@ -2759,10 +2755,10 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects)
2759 } 2755 }
2760 2756
2761 glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); 2757 glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
2762 glDisableClientState( GL_TEXTURE_COORD_ARRAY );
2763 2758
2759 LLVertexBuffer::unbind();
2764 LLVertexBuffer::stopRender(); 2760 LLVertexBuffer::stopRender();
2765 2761
2766 glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); 2762 glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
2767} 2763}
2768 2764
@@ -4866,6 +4862,12 @@ void LLPipeline::generateWaterReflection(LLCamera& camera_in)
4866{ 4862{
4867 if (LLPipeline::sWaterReflections && assertInitialized() && LLDrawPoolWater::sNeedsReflectionUpdate) 4863 if (LLPipeline::sWaterReflections && assertInitialized() && LLDrawPoolWater::sNeedsReflectionUpdate)
4868 { 4864 {
4865#ifndef LL_RELEASE_FOR_DOWNLOAD
4866 LLGLState::checkStates();
4867 LLGLState::checkTextureChannels();
4868 LLGLState::checkClientArrays();
4869#endif
4870
4869 LLCamera camera = camera_in; 4871 LLCamera camera = camera_in;
4870 camera.setFar(camera.getFar()*0.87654321f); 4872 camera.setFar(camera.getFar()*0.87654321f);
4871 LLPipeline::sReflectionRender = TRUE; 4873 LLPipeline::sReflectionRender = TRUE;
@@ -5052,6 +5054,12 @@ void LLPipeline::generateWaterReflection(LLCamera& camera_in)
5052 LLDrawPoolWater::sNeedsDistortionUpdate = FALSE; 5054 LLDrawPoolWater::sNeedsDistortionUpdate = FALSE;
5053 LLViewerCamera::getInstance()->setUserClipPlane(LLPlane(-pnorm, -pd)); 5055 LLViewerCamera::getInstance()->setUserClipPlane(LLPlane(-pnorm, -pd));
5054 LLPipeline::sUseOcclusion = occlusion; 5056 LLPipeline::sUseOcclusion = occlusion;
5057
5058#ifndef LL_RELEASE_FOR_DOWNLOAD
5059 LLGLState::checkStates();
5060 LLGLState::checkTextureChannels();
5061 LLGLState::checkClientArrays();
5062#endif
5055 } 5063 }
5056} 5064}
5057 5065