diff options
Diffstat (limited to 'linden/indra/newview/pipeline.cpp')
-rw-r--r-- | linden/indra/newview/pipeline.cpp | 185 |
1 files changed, 65 insertions, 120 deletions
diff --git a/linden/indra/newview/pipeline.cpp b/linden/indra/newview/pipeline.cpp index 5ec3310..20fd5a7 100644 --- a/linden/indra/newview/pipeline.cpp +++ b/linden/indra/newview/pipeline.cpp | |||
@@ -50,7 +50,7 @@ | |||
50 | #include "v3color.h" | 50 | #include "v3color.h" |
51 | #include "llui.h" | 51 | #include "llui.h" |
52 | #include "llglheaders.h" | 52 | #include "llglheaders.h" |
53 | #include "llglimmediate.h" | 53 | #include "llrender.h" |
54 | 54 | ||
55 | // newview includes | 55 | // newview includes |
56 | #include "llagent.h" | 56 | #include "llagent.h" |
@@ -125,6 +125,7 @@ extern S32 gBoxFrame; | |||
125 | extern BOOL gRenderLightGlows; | 125 | extern BOOL gRenderLightGlows; |
126 | extern BOOL gHideSelectedObjects; | 126 | extern BOOL gHideSelectedObjects; |
127 | extern BOOL gDisplaySwapBuffers; | 127 | extern BOOL gDisplaySwapBuffers; |
128 | extern BOOL gDebugGL; | ||
128 | 129 | ||
129 | // hack counter for rendering a fixed number of frames after toggling | 130 | // hack counter for rendering a fixed number of frames after toggling |
130 | // fullscreen to work around DEV-5361 | 131 | // fullscreen to work around DEV-5361 |
@@ -134,6 +135,7 @@ BOOL gAvatarBacklight = FALSE; | |||
134 | 135 | ||
135 | BOOL gRenderForSelect = FALSE; | 136 | BOOL gRenderForSelect = FALSE; |
136 | 137 | ||
138 | BOOL gDebugPipeline = FALSE; | ||
137 | LLPipeline gPipeline; | 139 | LLPipeline gPipeline; |
138 | const LLMatrix4* gGLLastMatrix = NULL; | 140 | const LLMatrix4* gGLLastMatrix = NULL; |
139 | 141 | ||
@@ -504,11 +506,7 @@ void LLPipeline::createGLBuffers() | |||
504 | res = 128; | 506 | res = 128; |
505 | mCubeBuffer = new LLCubeMap(); | 507 | mCubeBuffer = new LLCubeMap(); |
506 | mCubeBuffer->initGL(); | 508 | mCubeBuffer->initGL(); |
507 | glBindTexture(GL_TEXTURE_CUBE_MAP_ARB, mCubeBuffer->getGLName()); | 509 | mCubeBuffer->setReflection(); |
508 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR); | ||
509 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR); | ||
510 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); | ||
511 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); | ||
512 | 510 | ||
513 | for (U32 i = 0; i < 6; i++) | 511 | for (U32 i = 0; i < 6; i++) |
514 | { | 512 | { |
@@ -1178,7 +1176,7 @@ void LLPipeline::updateCull(LLCamera& camera, LLCullResult& result, S32 water_cl | |||
1178 | LLGLDisable test(GL_ALPHA_TEST); | 1176 | LLGLDisable test(GL_ALPHA_TEST); |
1179 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); | 1177 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); |
1180 | 1178 | ||
1181 | glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); | 1179 | gGL.setColorMask(false, false); |
1182 | LLGLDepthTest depth(GL_TRUE, GL_FALSE); | 1180 | LLGLDepthTest depth(GL_TRUE, GL_FALSE); |
1183 | 1181 | ||
1184 | for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->getRegionList().begin(); | 1182 | for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->getRegionList().begin(); |
@@ -1236,7 +1234,7 @@ void LLPipeline::updateCull(LLCamera& camera, LLCullResult& result, S32 water_cl | |||
1236 | sCull->pushDrawable(gSky.mVOGroundp->mDrawable); | 1234 | sCull->pushDrawable(gSky.mVOGroundp->mDrawable); |
1237 | } | 1235 | } |
1238 | 1236 | ||
1239 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE); | 1237 | gGL.setColorMask(true, false); |
1240 | glPopMatrix(); | 1238 | glPopMatrix(); |
1241 | 1239 | ||
1242 | if (to_texture) | 1240 | if (to_texture) |
@@ -1313,11 +1311,11 @@ void LLPipeline::doOcclusion(LLCamera& camera) | |||
1313 | LLVertexBuffer::unbind(); | 1311 | LLVertexBuffer::unbind(); |
1314 | if (hasRenderDebugMask(LLPipeline::RENDER_DEBUG_OCCLUSION)) | 1312 | if (hasRenderDebugMask(LLPipeline::RENDER_DEBUG_OCCLUSION)) |
1315 | { | 1313 | { |
1316 | glColorMask(GL_TRUE, GL_FALSE, GL_FALSE, GL_FALSE); | 1314 | gGL.setColorMask(true, false, false, false); |
1317 | } | 1315 | } |
1318 | else | 1316 | else |
1319 | { | 1317 | { |
1320 | glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_FALSE); | 1318 | gGL.setColorMask(false, false); |
1321 | } | 1319 | } |
1322 | LLGLDisable blend(GL_BLEND); | 1320 | LLGLDisable blend(GL_BLEND); |
1323 | LLGLDisable test(GL_ALPHA_TEST); | 1321 | LLGLDisable test(GL_ALPHA_TEST); |
@@ -1334,7 +1332,7 @@ void LLPipeline::doOcclusion(LLCamera& camera) | |||
1334 | } | 1332 | } |
1335 | } | 1333 | } |
1336 | 1334 | ||
1337 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE); | 1335 | gGL.setColorMask(true, false); |
1338 | glFlush(); | 1336 | glFlush(); |
1339 | } | 1337 | } |
1340 | 1338 | ||
@@ -2262,11 +2260,9 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate) | |||
2262 | LLVertexBuffer::unbind(); | 2260 | LLVertexBuffer::unbind(); |
2263 | 2261 | ||
2264 | // Do verification of GL state | 2262 | // Do verification of GL state |
2265 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
2266 | LLGLState::checkStates(); | 2263 | LLGLState::checkStates(); |
2267 | LLGLState::checkTextureChannels(); | 2264 | LLGLState::checkTextureChannels(); |
2268 | LLGLState::checkClientArrays(); | 2265 | LLGLState::checkClientArrays(); |
2269 | #endif | ||
2270 | if (mRenderDebugMask & RENDER_DEBUG_VERIFY) | 2266 | if (mRenderDebugMask & RENDER_DEBUG_VERIFY) |
2271 | { | 2267 | { |
2272 | if (!verify()) | 2268 | if (!verify()) |
@@ -2384,19 +2380,18 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate) | |||
2384 | } | 2380 | } |
2385 | poolp->endRenderPass(i); | 2381 | poolp->endRenderPass(i); |
2386 | LLVertexBuffer::unbind(); | 2382 | LLVertexBuffer::unbind(); |
2387 | #ifndef LL_RELEASE_FOR_DOWNLOAD | 2383 | if (gDebugGL || gDebugPipeline) |
2388 | # if LL_DEBUG_GL | ||
2389 | GLint depth; | ||
2390 | glGetIntegerv(GL_MODELVIEW_STACK_DEPTH, &depth); | ||
2391 | if (depth > 3) | ||
2392 | { | 2384 | { |
2393 | llerrs << "GL matrix stack corrupted!" << llendl; | 2385 | GLint depth; |
2386 | glGetIntegerv(GL_MODELVIEW_STACK_DEPTH, &depth); | ||
2387 | if (depth > 3) | ||
2388 | { | ||
2389 | llerrs << "GL matrix stack corrupted!" << llendl; | ||
2390 | } | ||
2391 | LLGLState::checkStates(); | ||
2392 | LLGLState::checkTextureChannels(); | ||
2393 | LLGLState::checkClientArrays(); | ||
2394 | } | 2394 | } |
2395 | LLGLState::checkStates(); | ||
2396 | LLGLState::checkTextureChannels(); | ||
2397 | LLGLState::checkClientArrays(); | ||
2398 | # endif | ||
2399 | #endif | ||
2400 | } | 2395 | } |
2401 | } | 2396 | } |
2402 | else | 2397 | else |
@@ -2417,11 +2412,9 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate) | |||
2417 | } | 2412 | } |
2418 | 2413 | ||
2419 | LLVertexBuffer::unbind(); | 2414 | LLVertexBuffer::unbind(); |
2420 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
2421 | LLGLState::checkStates(); | 2415 | LLGLState::checkStates(); |
2422 | LLGLState::checkTextureChannels(); | 2416 | LLGLState::checkTextureChannels(); |
2423 | LLGLState::checkClientArrays(); | 2417 | LLGLState::checkClientArrays(); |
2424 | #endif | ||
2425 | 2418 | ||
2426 | gGLLastMatrix = NULL; | 2419 | gGLLastMatrix = NULL; |
2427 | glLoadMatrixd(gGLModelView); | 2420 | glLoadMatrixd(gGLModelView); |
@@ -2436,12 +2429,10 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate) | |||
2436 | 2429 | ||
2437 | stop_glerror(); | 2430 | stop_glerror(); |
2438 | 2431 | ||
2439 | #ifndef LL_RELEASE_FOR_DOWNLOAD | 2432 | LLGLState::checkStates(); |
2440 | LLGLState::checkStates(); | 2433 | LLGLState::checkTextureChannels(); |
2441 | LLGLState::checkTextureChannels(); | 2434 | LLGLState::checkClientArrays(); |
2442 | LLGLState::checkClientArrays(); | 2435 | |
2443 | #endif | ||
2444 | |||
2445 | if (!sReflectionRender) | 2436 | if (!sReflectionRender) |
2446 | { | 2437 | { |
2447 | renderHighlights(); | 2438 | renderHighlights(); |
@@ -2475,11 +2466,9 @@ void LLPipeline::renderGeom(LLCamera& camera, BOOL forceVBOUpdate) | |||
2475 | 2466 | ||
2476 | LLVertexBuffer::unbind(); | 2467 | LLVertexBuffer::unbind(); |
2477 | 2468 | ||
2478 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
2479 | LLGLState::checkStates(); | 2469 | LLGLState::checkStates(); |
2480 | LLGLState::checkTextureChannels(); | 2470 | LLGLState::checkTextureChannels(); |
2481 | LLGLState::checkClientArrays(); | 2471 | LLGLState::checkClientArrays(); |
2482 | #endif | ||
2483 | } | 2472 | } |
2484 | 2473 | ||
2485 | void LLPipeline::renderGeomDeferred() | 2474 | void LLPipeline::renderGeomDeferred() |
@@ -2514,7 +2503,7 @@ void LLPipeline::renderDebug() | |||
2514 | 2503 | ||
2515 | gGLLastMatrix = NULL; | 2504 | gGLLastMatrix = NULL; |
2516 | glLoadMatrixd(gGLModelView); | 2505 | glLoadMatrixd(gGLModelView); |
2517 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE); | 2506 | gGL.setColorMask(true, false); |
2518 | 2507 | ||
2519 | // Debug stuff. | 2508 | // Debug stuff. |
2520 | for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->getRegionList().begin(); | 2509 | for (LLWorld::region_list_t::iterator iter = LLWorld::getInstance()->getRegionList().begin(); |
@@ -2585,7 +2574,7 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects) | |||
2585 | { | 2574 | { |
2586 | assertInitialized(); | 2575 | assertInitialized(); |
2587 | 2576 | ||
2588 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE); | 2577 | gGL.setColorMask(true, false); |
2589 | gPipeline.resetDrawOrders(); | 2578 | gPipeline.resetDrawOrders(); |
2590 | 2579 | ||
2591 | for (std::set<LLViewerObject*>::iterator iter = objects.begin(); iter != objects.end(); ++iter) | 2580 | for (std::set<LLViewerObject*>::iterator iter = objects.begin(); iter != objects.end(); ++iter) |
@@ -2607,12 +2596,11 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects) | |||
2607 | LLVertexBuffer::unbind(); | 2596 | LLVertexBuffer::unbind(); |
2608 | 2597 | ||
2609 | //for each drawpool | 2598 | //for each drawpool |
2610 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
2611 | LLGLState::checkStates(); | 2599 | LLGLState::checkStates(); |
2612 | LLGLState::checkTextureChannels(); | 2600 | LLGLState::checkTextureChannels(); |
2613 | LLGLState::checkClientArrays(); | 2601 | LLGLState::checkClientArrays(); |
2614 | U32 last_type = 0; | 2602 | U32 last_type = 0; |
2615 | #endif | 2603 | |
2616 | for (pool_set_t::iterator iter = mPools.begin(); iter != mPools.end(); ++iter) | 2604 | for (pool_set_t::iterator iter = mPools.begin(); iter != mPools.end(); ++iter) |
2617 | { | 2605 | { |
2618 | LLDrawPool *poolp = *iter; | 2606 | LLDrawPool *poolp = *iter; |
@@ -2624,7 +2612,6 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects) | |||
2624 | gGLLastMatrix = NULL; | 2612 | gGLLastMatrix = NULL; |
2625 | glLoadMatrixd(gGLModelView); | 2613 | glLoadMatrixd(gGLModelView); |
2626 | 2614 | ||
2627 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
2628 | if (poolp->getType() != last_type) | 2615 | if (poolp->getType() != last_type) |
2629 | { | 2616 | { |
2630 | last_type = poolp->getType(); | 2617 | last_type = poolp->getType(); |
@@ -2632,32 +2619,21 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects) | |||
2632 | LLGLState::checkTextureChannels(); | 2619 | LLGLState::checkTextureChannels(); |
2633 | LLGLState::checkClientArrays(); | 2620 | LLGLState::checkClientArrays(); |
2634 | } | 2621 | } |
2635 | #endif | ||
2636 | } | 2622 | } |
2637 | } | 2623 | } |
2638 | 2624 | ||
2639 | LLGLEnable alpha_test(GL_ALPHA_TEST); | 2625 | LLGLEnable alpha_test(GL_ALPHA_TEST); |
2640 | if (gPickTransparent) | 2626 | if (gPickTransparent) |
2641 | { | 2627 | { |
2642 | glAlphaFunc(GL_GEQUAL, 0.0f); | 2628 | gGL.setAlphaRejectSettings(LLRender::CF_GREATER_EQUAL, 0.f); |
2643 | } | 2629 | } |
2644 | else | 2630 | else |
2645 | { | 2631 | { |
2646 | glAlphaFunc(GL_GREATER, 0.2f); | 2632 | gGL.setAlphaRejectSettings(LLRender::CF_GREATER, 0.2f); |
2647 | } | 2633 | } |
2648 | 2634 | ||
2649 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_ARB); | 2635 | gGL.getTexUnit(0)->setTextureColorBlend(LLTexUnit::TBO_REPLACE, LLTexUnit::TBS_VERT_COLOR); |
2650 | glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_RGB_ARB, GL_REPLACE); | 2636 | gGL.getTexUnit(0)->setTextureAlphaBlend(LLTexUnit::TBO_MULT, LLTexUnit::TBS_TEX_ALPHA, LLTexUnit::TBS_VERT_ALPHA); |
2651 | glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_ALPHA_ARB, GL_MODULATE); | ||
2652 | |||
2653 | glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE0_RGB_ARB, GL_PRIMARY_COLOR); | ||
2654 | glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND0_RGB_ARB, GL_SRC_COLOR); | ||
2655 | |||
2656 | glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE0_ALPHA_ARB, GL_TEXTURE); | ||
2657 | glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND0_ALPHA_ARB, GL_SRC_ALPHA); | ||
2658 | |||
2659 | glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE1_ALPHA_ARB, GL_PRIMARY_COLOR_ARB); | ||
2660 | glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND1_ALPHA_ARB, GL_SRC_ALPHA); | ||
2661 | 2637 | ||
2662 | U32 prim_mask = LLVertexBuffer::MAP_VERTEX | | 2638 | U32 prim_mask = LLVertexBuffer::MAP_VERTEX | |
2663 | LLVertexBuffer::MAP_TEXCOORD; | 2639 | LLVertexBuffer::MAP_TEXCOORD; |
@@ -2758,12 +2734,11 @@ void LLPipeline::renderForSelect(std::set<LLViewerObject*>& objects) | |||
2758 | glViewport(gGLViewport[0], gGLViewport[1], gGLViewport[2], gGLViewport[3]); | 2734 | glViewport(gGLViewport[0], gGLViewport[1], gGLViewport[2], gGLViewport[3]); |
2759 | } | 2735 | } |
2760 | 2736 | ||
2761 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 2737 | gGL.getTexUnit(0)->setTextureBlendType(LLTexUnit::TB_MULT); |
2762 | 2738 | ||
2763 | LLVertexBuffer::unbind(); | 2739 | LLVertexBuffer::unbind(); |
2764 | LLVertexBuffer::unbind(); | ||
2765 | 2740 | ||
2766 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); | 2741 | gGL.setColorMask(true, true); |
2767 | } | 2742 | } |
2768 | 2743 | ||
2769 | void LLPipeline::renderFaceForUVSelect(LLFace* facep) | 2744 | void LLPipeline::renderFaceForUVSelect(LLFace* facep) |
@@ -4118,11 +4093,9 @@ void apply_cube_face_rotation(U32 face) | |||
4118 | } | 4093 | } |
4119 | void LLPipeline::generateReflectionMap(LLCubeMap* cube_map, LLCamera& cube_cam) | 4094 | void LLPipeline::generateReflectionMap(LLCubeMap* cube_map, LLCamera& cube_cam) |
4120 | { | 4095 | { |
4121 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
4122 | LLGLState::checkStates(); | 4096 | LLGLState::checkStates(); |
4123 | LLGLState::checkTextureChannels(); | 4097 | LLGLState::checkTextureChannels(); |
4124 | LLGLState::checkClientArrays(); | 4098 | LLGLState::checkClientArrays(); |
4125 | #endif | ||
4126 | 4099 | ||
4127 | assertInitialized(); | 4100 | assertInitialized(); |
4128 | 4101 | ||
@@ -4140,10 +4113,7 @@ void LLPipeline::generateReflectionMap(LLCubeMap* cube_map, LLCamera& cube_cam) | |||
4140 | glGetTexLevelParameteriv(GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB, 0, GL_TEXTURE_WIDTH, &width); | 4113 | glGetTexLevelParameteriv(GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB, 0, GL_TEXTURE_WIDTH, &width); |
4141 | if (width != res) | 4114 | if (width != res) |
4142 | { | 4115 | { |
4143 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR); | 4116 | cube_map->setReflection(); |
4144 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR); | ||
4145 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); | ||
4146 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); | ||
4147 | 4117 | ||
4148 | for (U32 i = 0; i < 6; i++) | 4118 | for (U32 i = 0; i < 6; i++) |
4149 | { | 4119 | { |
@@ -4224,9 +4194,9 @@ void LLPipeline::generateReflectionMap(LLCubeMap* cube_map, LLCamera& cube_cam) | |||
4224 | gPipeline.stateSort(cube_cam, result); | 4194 | gPipeline.stateSort(cube_cam, result); |
4225 | 4195 | ||
4226 | glClearColor(0,0,0,0); | 4196 | glClearColor(0,0,0,0); |
4227 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_TRUE); | 4197 | gGL.setColorMask(true, true); |
4228 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT); | 4198 | glClear(GL_DEPTH_BUFFER_BIT | GL_COLOR_BUFFER_BIT); |
4229 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_FALSE); | 4199 | gGL.setColorMask(true, false); |
4230 | stop_glerror(); | 4200 | stop_glerror(); |
4231 | gPipeline.renderGeom(cube_cam); | 4201 | gPipeline.renderGeom(cube_cam); |
4232 | } | 4202 | } |
@@ -4254,12 +4224,9 @@ void LLPipeline::generateReflectionMap(LLCubeMap* cube_map, LLCamera& cube_cam) | |||
4254 | LLPipeline::sSkipUpdate = FALSE; | 4224 | LLPipeline::sSkipUpdate = FALSE; |
4255 | LLPipeline::sReflectionRender = FALSE; | 4225 | LLPipeline::sReflectionRender = FALSE; |
4256 | 4226 | ||
4257 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
4258 | LLGLState::checkStates(); | 4227 | LLGLState::checkStates(); |
4259 | LLGLState::checkTextureChannels(); | 4228 | LLGLState::checkTextureChannels(); |
4260 | LLGLState::checkClientArrays(); | 4229 | LLGLState::checkClientArrays(); |
4261 | #endif | ||
4262 | |||
4263 | } | 4230 | } |
4264 | 4231 | ||
4265 | //send cube map vertices and texture coordinates | 4232 | //send cube map vertices and texture coordinates |
@@ -4336,18 +4303,16 @@ void validate_framebuffer_object() | |||
4336 | 4303 | ||
4337 | void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) | 4304 | void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) |
4338 | { | 4305 | { |
4339 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
4340 | LLGLState::checkStates(); | 4306 | LLGLState::checkStates(); |
4341 | LLGLState::checkTextureChannels(); | 4307 | LLGLState::checkTextureChannels(); |
4342 | LLGLState::checkClientArrays(); | 4308 | LLGLState::checkClientArrays(); |
4343 | #endif | ||
4344 | 4309 | ||
4345 | assertInitialized(); | 4310 | assertInitialized(); |
4346 | 4311 | ||
4347 | U32 res = (U32) gSavedSettings.getS32("RenderReflectionRes"); | 4312 | U32 res = (U32) gSavedSettings.getS32("RenderReflectionRes"); |
4348 | enableLightsFullbright(LLColor4::white); | 4313 | enableLightsFullbright(LLColor4::white); |
4349 | LLGLDepthTest depth(GL_FALSE); | 4314 | LLGLDepthTest depth(GL_FALSE); |
4350 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); | 4315 | gGL.setColorMask(true, true); |
4351 | glMatrixMode(GL_PROJECTION); | 4316 | glMatrixMode(GL_PROJECTION); |
4352 | glPushMatrix(); | 4317 | glPushMatrix(); |
4353 | glLoadIdentity(); | 4318 | glLoadIdentity(); |
@@ -4361,10 +4326,7 @@ void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) | |||
4361 | glGetTexLevelParameteriv(GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB, 0, GL_TEXTURE_WIDTH, &width); | 4326 | glGetTexLevelParameteriv(GL_TEXTURE_CUBE_MAP_POSITIVE_X_ARB, 0, GL_TEXTURE_WIDTH, &width); |
4362 | if (width != res) | 4327 | if (width != res) |
4363 | { | 4328 | { |
4364 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR); | 4329 | cube_out->setReflection(); |
4365 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR); | ||
4366 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE); | ||
4367 | glTexParameteri(GL_TEXTURE_CUBE_MAP_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE); | ||
4368 | 4330 | ||
4369 | for (U32 i = 0; i < 6; i++) | 4331 | for (U32 i = 0; i < 6; i++) |
4370 | { | 4332 | { |
@@ -4391,7 +4353,7 @@ void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) | |||
4391 | 4353 | ||
4392 | stop_glerror(); | 4354 | stop_glerror(); |
4393 | glViewport(0,0,res, res); | 4355 | glViewport(0,0,res, res); |
4394 | gGL.blendFunc(GL_ONE, GL_ONE); | 4356 | gGL.setSceneBlendType(LLRender::BT_ADD); |
4395 | cube_in->enableTexture(0); | 4357 | cube_in->enableTexture(0); |
4396 | //3-axis blur | 4358 | //3-axis blur |
4397 | for (U32 j = 0; j < 3; j++) | 4359 | for (U32 j = 0; j < 3; j++) |
@@ -4421,7 +4383,7 @@ void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) | |||
4421 | gl_cube_face[i], | 4383 | gl_cube_face[i], |
4422 | j < 2 ? mBlurCubeTexture[j] : cube_out->getGLName(), 0); | 4384 | j < 2 ? mBlurCubeTexture[j] : cube_out->getGLName(), 0); |
4423 | validate_framebuffer_object(); | 4385 | validate_framebuffer_object(); |
4424 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_TRUE); | 4386 | gGL.setColorMask(true, true); |
4425 | glClear(GL_COLOR_BUFFER_BIT); | 4387 | glClear(GL_COLOR_BUFFER_BIT); |
4426 | glLoadIdentity(); | 4388 | glLoadIdentity(); |
4427 | apply_cube_face_rotation(i); | 4389 | apply_cube_face_rotation(i); |
@@ -4441,7 +4403,7 @@ void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) | |||
4441 | glBindTexture(GL_TEXTURE_CUBE_MAP_ARB, 0); | 4403 | glBindTexture(GL_TEXTURE_CUBE_MAP_ARB, 0); |
4442 | 4404 | ||
4443 | glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0); | 4405 | glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0); |
4444 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_FALSE); | 4406 | gGL.setColorMask(true, false); |
4445 | glMatrixMode(GL_PROJECTION); | 4407 | glMatrixMode(GL_PROJECTION); |
4446 | glPopMatrix(); | 4408 | glPopMatrix(); |
4447 | glMatrixMode(GL_MODELVIEW); | 4409 | glMatrixMode(GL_MODELVIEW); |
@@ -4449,13 +4411,11 @@ void LLPipeline::blurReflectionMap(LLCubeMap* cube_in, LLCubeMap* cube_out) | |||
4449 | 4411 | ||
4450 | cube_in->disableTexture(); | 4412 | cube_in->disableTexture(); |
4451 | gViewerWindow->setupViewport(); | 4413 | gViewerWindow->setupViewport(); |
4452 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 4414 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
4453 | 4415 | ||
4454 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
4455 | LLGLState::checkStates(); | 4416 | LLGLState::checkStates(); |
4456 | LLGLState::checkTextureChannels(); | 4417 | LLGLState::checkTextureChannels(); |
4457 | LLGLState::checkClientArrays(); | 4418 | LLGLState::checkClientArrays(); |
4458 | #endif | ||
4459 | } | 4419 | } |
4460 | 4420 | ||
4461 | void LLPipeline::bindScreenToTexture() | 4421 | void LLPipeline::bindScreenToTexture() |
@@ -4471,10 +4431,8 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4471 | return; | 4431 | return; |
4472 | } | 4432 | } |
4473 | 4433 | ||
4474 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
4475 | LLGLState::checkStates(); | 4434 | LLGLState::checkStates(); |
4476 | LLGLState::checkTextureChannels(); | 4435 | LLGLState::checkTextureChannels(); |
4477 | #endif | ||
4478 | 4436 | ||
4479 | assertInitialized(); | 4437 | assertInitialized(); |
4480 | 4438 | ||
@@ -4494,7 +4452,7 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4494 | tc2 /= (F32) res_mod; | 4452 | tc2 /= (F32) res_mod; |
4495 | } | 4453 | } |
4496 | 4454 | ||
4497 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); | 4455 | gGL.setColorMask(true, true); |
4498 | 4456 | ||
4499 | LLFastTimer ftm(LLFastTimer::FTM_RENDER_BLOOM); | 4457 | LLFastTimer ftm(LLFastTimer::FTM_RENDER_BLOOM); |
4500 | gGL.color4f(1,1,1,1); | 4458 | gGL.color4f(1,1,1,1); |
@@ -4513,7 +4471,7 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4513 | 4471 | ||
4514 | LLGLDisable test(GL_ALPHA_TEST); | 4472 | LLGLDisable test(GL_ALPHA_TEST); |
4515 | 4473 | ||
4516 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); | 4474 | gGL.setColorMask(true, true); |
4517 | glClearColor(0,0,0,0); | 4475 | glClearColor(0,0,0,0); |
4518 | 4476 | ||
4519 | if (for_snapshot) | 4477 | if (for_snapshot) |
@@ -4525,7 +4483,7 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4525 | //glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP); | 4483 | //glStencilOp(GL_KEEP, GL_KEEP, GL_KEEP); |
4526 | //LLGLDisable blend(GL_BLEND); | 4484 | //LLGLDisable blend(GL_BLEND); |
4527 | LLGLEnable blend(GL_BLEND); | 4485 | LLGLEnable blend(GL_BLEND); |
4528 | gGL.blendFunc(GL_ONE, GL_ONE); | 4486 | gGL.setSceneBlendType(LLRender::BT_ADD); |
4529 | tc2.setVec(1,1); | 4487 | tc2.setVec(1,1); |
4530 | gGL.begin(LLVertexBuffer::TRIANGLE_STRIP); | 4488 | gGL.begin(LLVertexBuffer::TRIANGLE_STRIP); |
4531 | gGL.color4f(1,1,1,1); | 4489 | gGL.color4f(1,1,1,1); |
@@ -4543,7 +4501,7 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4543 | gGL.end(); | 4501 | gGL.end(); |
4544 | 4502 | ||
4545 | gGL.flush(); | 4503 | gGL.flush(); |
4546 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 4504 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
4547 | } | 4505 | } |
4548 | 4506 | ||
4549 | gGL.flush(); | 4507 | gGL.flush(); |
@@ -4575,8 +4533,8 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4575 | gGlowExtractProgram.uniform1f("warmthAmount", warmthAmount); | 4533 | gGlowExtractProgram.uniform1f("warmthAmount", warmthAmount); |
4576 | LLGLEnable blend_on(GL_BLEND); | 4534 | LLGLEnable blend_on(GL_BLEND); |
4577 | LLGLEnable test(GL_ALPHA_TEST); | 4535 | LLGLEnable test(GL_ALPHA_TEST); |
4578 | glAlphaFunc(GL_GREATER, 0.f); | 4536 | gGL.setAlphaRejectSettings(LLRender::CF_DEFAULT); |
4579 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE); | 4537 | gGL.setSceneBlendType(LLRender::BT_ADD_WITH_ALPHA); |
4580 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); | 4538 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); |
4581 | 4539 | ||
4582 | glDisable(GL_TEXTURE_2D); | 4540 | glDisable(GL_TEXTURE_2D); |
@@ -4785,26 +4743,17 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4785 | 4743 | ||
4786 | LLGLDisable blend(GL_BLEND); | 4744 | LLGLDisable blend(GL_BLEND); |
4787 | 4745 | ||
4788 | |||
4789 | //tex unit 0 | 4746 | //tex unit 0 |
4790 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_ARB); | 4747 | gGL.getTexUnit(0)->setTextureColorBlend(LLTexUnit::TBO_REPLACE, LLTexUnit::TBS_TEX_COLOR); |
4791 | glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_RGB_ARB, GL_REPLACE); | ||
4792 | glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE0_RGB_ARB, GL_TEXTURE); | ||
4793 | glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND0_RGB_ARB, GL_SRC_COLOR); | ||
4794 | 4748 | ||
4795 | mGlow[1].bindTexture(); | 4749 | mGlow[1].bindTexture(); |
4796 | glEnableClientState(GL_TEXTURE_COORD_ARRAY); | 4750 | glEnableClientState(GL_TEXTURE_COORD_ARRAY); |
4797 | glTexCoordPointer(2, GL_FLOAT, 0, uv0); | 4751 | glTexCoordPointer(2, GL_FLOAT, 0, uv0); |
4798 | glActiveTextureARB(GL_TEXTURE1_ARB); | 4752 | gGL.getTexUnit(1)->activate(); |
4799 | glEnable(GL_TEXTURE_RECTANGLE_ARB); | 4753 | glEnable(GL_TEXTURE_RECTANGLE_ARB); |
4800 | 4754 | ||
4801 | //tex unit 1 | 4755 | //tex unit 1 |
4802 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_ARB); | 4756 | gGL.getTexUnit(1)->setTextureColorBlend(LLTexUnit::TBO_ADD, LLTexUnit::TBS_TEX_COLOR, LLTexUnit::TBS_PREV_COLOR); |
4803 | glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_RGB_ARB, GL_ADD); | ||
4804 | glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE0_RGB_ARB, GL_PREVIOUS_ARB); | ||
4805 | glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND0_RGB_ARB, GL_SRC_COLOR); | ||
4806 | glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE1_RGB_ARB, GL_TEXTURE); | ||
4807 | glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND1_RGB_ARB, GL_SRC_COLOR); | ||
4808 | 4757 | ||
4809 | glClientActiveTextureARB(GL_TEXTURE1_ARB); | 4758 | glClientActiveTextureARB(GL_TEXTURE1_ARB); |
4810 | glEnableClientState(GL_TEXTURE_COORD_ARRAY); | 4759 | glEnableClientState(GL_TEXTURE_COORD_ARRAY); |
@@ -4819,23 +4768,23 @@ void LLPipeline::renderBloom(BOOL for_snapshot) | |||
4819 | 4768 | ||
4820 | glDisable(GL_TEXTURE_RECTANGLE_ARB); | 4769 | glDisable(GL_TEXTURE_RECTANGLE_ARB); |
4821 | glDisableClientState(GL_TEXTURE_COORD_ARRAY); | 4770 | glDisableClientState(GL_TEXTURE_COORD_ARRAY); |
4822 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 4771 | gGL.getTexUnit(1)->setTextureBlendType(LLTexUnit::TB_MULT); |
4823 | glClientActiveTextureARB(GL_TEXTURE0_ARB); | 4772 | glClientActiveTextureARB(GL_TEXTURE0_ARB); |
4824 | glActiveTextureARB(GL_TEXTURE0_ARB); | 4773 | gGL.getTexUnit(0)->activate(); |
4825 | glDisableClientState(GL_TEXTURE_COORD_ARRAY); | 4774 | glDisableClientState(GL_TEXTURE_COORD_ARRAY); |
4826 | glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); | 4775 | gGL.getTexUnit(0)->setTextureBlendType(LLTexUnit::TB_MULT); |
4827 | } | 4776 | } |
4828 | 4777 | ||
4829 | glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 4778 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
4830 | glMatrixMode(GL_PROJECTION); | 4779 | glMatrixMode(GL_PROJECTION); |
4831 | glPopMatrix(); | 4780 | glPopMatrix(); |
4832 | glMatrixMode(GL_MODELVIEW); | 4781 | glMatrixMode(GL_MODELVIEW); |
4833 | glPopMatrix(); | 4782 | glPopMatrix(); |
4834 | 4783 | ||
4835 | #ifndef LL_RELEASE_FOR_DOWNLOAD | 4784 | LLVertexBuffer::unbind(); |
4785 | |||
4836 | LLGLState::checkStates(); | 4786 | LLGLState::checkStates(); |
4837 | LLGLState::checkTextureChannels(); | 4787 | LLGLState::checkTextureChannels(); |
4838 | #endif | ||
4839 | 4788 | ||
4840 | } | 4789 | } |
4841 | 4790 | ||
@@ -4867,11 +4816,9 @@ void LLPipeline::generateWaterReflection(LLCamera& camera_in) | |||
4867 | { | 4816 | { |
4868 | LLVertexBuffer::unbind(); | 4817 | LLVertexBuffer::unbind(); |
4869 | 4818 | ||
4870 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
4871 | LLGLState::checkStates(); | 4819 | LLGLState::checkStates(); |
4872 | LLGLState::checkTextureChannels(); | 4820 | LLGLState::checkTextureChannels(); |
4873 | LLGLState::checkClientArrays(); | 4821 | LLGLState::checkClientArrays(); |
4874 | #endif | ||
4875 | 4822 | ||
4876 | LLCamera camera = camera_in; | 4823 | LLCamera camera = camera_in; |
4877 | camera.setFar(camera.getFar()*0.87654321f); | 4824 | camera.setFar(camera.getFar()*0.87654321f); |
@@ -4916,11 +4863,11 @@ void LLPipeline::generateWaterReflection(LLCamera& camera_in) | |||
4916 | { //generate planar reflection map | 4863 | { //generate planar reflection map |
4917 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); | 4864 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); |
4918 | glClearColor(0,0,0,0); | 4865 | glClearColor(0,0,0,0); |
4919 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_TRUE); | 4866 | gGL.setColorMask(true, true); |
4920 | mWaterRef.bindTarget(); | 4867 | mWaterRef.bindTarget(); |
4921 | mWaterRef.getViewport(gGLViewport); | 4868 | mWaterRef.getViewport(gGLViewport); |
4922 | mWaterRef.clear(); | 4869 | mWaterRef.clear(); |
4923 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_FALSE); | 4870 | gGL.setColorMask(true, false); |
4924 | 4871 | ||
4925 | stop_glerror(); | 4872 | stop_glerror(); |
4926 | 4873 | ||
@@ -5022,11 +4969,11 @@ void LLPipeline::generateWaterReflection(LLCamera& camera_in) | |||
5022 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); | 4969 | LLViewerImage::unbindTexture(0, GL_TEXTURE_2D); |
5023 | LLColor4& col = LLDrawPoolWater::sWaterFogColor; | 4970 | LLColor4& col = LLDrawPoolWater::sWaterFogColor; |
5024 | glClearColor(col.mV[0], col.mV[1], col.mV[2], 0.f); | 4971 | glClearColor(col.mV[0], col.mV[1], col.mV[2], 0.f); |
5025 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_TRUE); | 4972 | gGL.setColorMask(true, true); |
5026 | mWaterDis.bindTarget(); | 4973 | mWaterDis.bindTarget(); |
5027 | mWaterDis.getViewport(gGLViewport); | 4974 | mWaterDis.getViewport(gGLViewport); |
5028 | mWaterDis.clear(); | 4975 | mWaterDis.clear(); |
5029 | glColorMask(GL_TRUE,GL_TRUE,GL_TRUE,GL_FALSE); | 4976 | gGL.setColorMask(true, false); |
5030 | 4977 | ||
5031 | if (!LLPipeline::sUnderWaterRender || LLDrawPoolWater::sNeedsReflectionUpdate) | 4978 | if (!LLPipeline::sUnderWaterRender || LLDrawPoolWater::sNeedsReflectionUpdate) |
5032 | { | 4979 | { |
@@ -5060,11 +5007,9 @@ void LLPipeline::generateWaterReflection(LLCamera& camera_in) | |||
5060 | LLViewerCamera::getInstance()->setUserClipPlane(LLPlane(-pnorm, -pd)); | 5007 | LLViewerCamera::getInstance()->setUserClipPlane(LLPlane(-pnorm, -pd)); |
5061 | LLPipeline::sUseOcclusion = occlusion; | 5008 | LLPipeline::sUseOcclusion = occlusion; |
5062 | 5009 | ||
5063 | #ifndef LL_RELEASE_FOR_DOWNLOAD | ||
5064 | LLGLState::checkStates(); | 5010 | LLGLState::checkStates(); |
5065 | LLGLState::checkTextureChannels(); | 5011 | LLGLState::checkTextureChannels(); |
5066 | LLGLState::checkClientArrays(); | 5012 | LLGLState::checkClientArrays(); |
5067 | #endif | ||
5068 | } | 5013 | } |
5069 | } | 5014 | } |
5070 | 5015 | ||
@@ -5203,7 +5148,7 @@ void LLPipeline::generateImpostor(LLVOAvatar* avatar) | |||
5203 | glh_set_current_modelview(mat); | 5148 | glh_set_current_modelview(mat); |
5204 | 5149 | ||
5205 | glClearColor(0.0f,0.0f,0.0f,0.0f); | 5150 | glClearColor(0.0f,0.0f,0.0f,0.0f); |
5206 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); | 5151 | gGL.setColorMask(true, true); |
5207 | glStencilMask(0xFFFFFFFF); | 5152 | glStencilMask(0xFFFFFFFF); |
5208 | glClearStencil(0); | 5153 | glClearStencil(0); |
5209 | 5154 | ||
@@ -5250,14 +5195,14 @@ void LLPipeline::generateImpostor(LLVOAvatar* avatar) | |||
5250 | 5195 | ||
5251 | if (muted) | 5196 | if (muted) |
5252 | { | 5197 | { |
5253 | glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE); | 5198 | gGL.setColorMask(true, true); |
5254 | } | 5199 | } |
5255 | else | 5200 | else |
5256 | { | 5201 | { |
5257 | glColorMask(GL_FALSE, GL_FALSE, GL_FALSE, GL_TRUE); | 5202 | gGL.setColorMask(false, true); |
5258 | } | 5203 | } |
5259 | 5204 | ||
5260 | gGL.blendFunc(GL_ONE, GL_ONE); | 5205 | gGL.setSceneBlendType(LLRender::BT_ADD); |
5261 | LLImageGL::unbindTexture(0, GL_TEXTURE_2D); | 5206 | LLImageGL::unbindTexture(0, GL_TEXTURE_2D); |
5262 | 5207 | ||
5263 | LLGLDepthTest depth(GL_FALSE, GL_FALSE); | 5208 | LLGLDepthTest depth(GL_FALSE, GL_FALSE); |
@@ -5273,7 +5218,7 @@ void LLPipeline::generateImpostor(LLVOAvatar* avatar) | |||
5273 | gGL.flush(); | 5218 | gGL.flush(); |
5274 | 5219 | ||
5275 | 5220 | ||
5276 | gGL.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); | 5221 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
5277 | } | 5222 | } |
5278 | 5223 | ||
5279 | 5224 | ||