diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/lltexlayer.cpp | 44 |
1 files changed, 24 insertions, 20 deletions
diff --git a/linden/indra/newview/lltexlayer.cpp b/linden/indra/newview/lltexlayer.cpp index 66d9a33..0e4c9c2 100644 --- a/linden/indra/newview/lltexlayer.cpp +++ b/linden/indra/newview/lltexlayer.cpp | |||
@@ -52,7 +52,7 @@ | |||
52 | #include "llxmltree.h" | 52 | #include "llxmltree.h" |
53 | #include "pipeline.h" | 53 | #include "pipeline.h" |
54 | #include "v4coloru.h" | 54 | #include "v4coloru.h" |
55 | #include "llglimmediate.h" | 55 | #include "llrender.h" |
56 | 56 | ||
57 | //#include "../tools/imdebug/imdebug.h" | 57 | //#include "../tools/imdebug/imdebug.h" |
58 | 58 | ||
@@ -239,6 +239,9 @@ BOOL LLTexLayerSetBuffer::render() | |||
239 | { | 239 | { |
240 | U8* baked_bump_data = NULL; | 240 | U8* baked_bump_data = NULL; |
241 | 241 | ||
242 | // Default color mask for tex layer render | ||
243 | gGL.setColorMask(true, true); | ||
244 | |||
242 | // do we need to upload, and do we have sufficient data to create an uploadable composite? | 245 | // do we need to upload, and do we have sufficient data to create an uploadable composite? |
243 | // When do we upload the texture if gAgent.mNumPendingQueries is non-zero? | 246 | // When do we upload the texture if gAgent.mNumPendingQueries is non-zero? |
244 | BOOL upload_now = (gAgent.mNumPendingQueries == 0 && mNeedsUpload && mTexLayerSet->isLocalTextureDataFinal()); | 247 | BOOL upload_now = (gAgent.mNumPendingQueries == 0 && mNeedsUpload && mTexLayerSet->isLocalTextureDataFinal()); |
@@ -292,8 +295,8 @@ BOOL LLTexLayerSetBuffer::render() | |||
292 | } | 295 | } |
293 | 296 | ||
294 | // reset GL state | 297 | // reset GL state |
295 | glColorMask( GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE ); | 298 | gGL.setColorMask(true, true); |
296 | gGL.blendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA ); | 299 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
297 | 300 | ||
298 | // we have valid texture data now | 301 | // we have valid texture data now |
299 | mInitialized = TRUE; | 302 | mInitialized = TRUE; |
@@ -756,6 +759,7 @@ BOOL LLTexLayerSet::render( S32 x, S32 y, S32 width, S32 height ) | |||
756 | 759 | ||
757 | LLGLSUIDefault gls_ui; | 760 | LLGLSUIDefault gls_ui; |
758 | LLGLDepthTest gls_depth(GL_FALSE, GL_FALSE); | 761 | LLGLDepthTest gls_depth(GL_FALSE, GL_FALSE); |
762 | gGL.setColorMask(true, true); | ||
759 | 763 | ||
760 | // composite color layers | 764 | // composite color layers |
761 | for( layer_list_t::iterator iter = mLayerList.begin(); iter != mLayerList.end(); iter++ ) | 765 | for( layer_list_t::iterator iter = mLayerList.begin(); iter != mLayerList.end(); iter++ ) |
@@ -774,8 +778,8 @@ BOOL LLTexLayerSet::render( S32 x, S32 y, S32 width, S32 height ) | |||
774 | { | 778 | { |
775 | LLGLSNoAlphaTest gls_no_alpha_test; | 779 | LLGLSNoAlphaTest gls_no_alpha_test; |
776 | gGL.flush(); | 780 | gGL.flush(); |
777 | glColorMask( GL_FALSE, GL_FALSE, GL_FALSE, GL_TRUE ); | 781 | gGL.setColorMask(false, true); |
778 | gGL.blendFunc( GL_ONE, GL_ZERO ); | 782 | gGL.setSceneBlendType(LLRender::BT_REPLACE); |
779 | 783 | ||
780 | { | 784 | { |
781 | LLImageGL* image_gl = gTexStaticImageList.getImageGL( getInfo()->mStaticAlphaFileName, TRUE ); | 785 | LLImageGL* image_gl = gTexStaticImageList.getImageGL( getInfo()->mStaticAlphaFileName, TRUE ); |
@@ -793,8 +797,8 @@ BOOL LLTexLayerSet::render( S32 x, S32 y, S32 width, S32 height ) | |||
793 | LLImageGL::unbindTexture(0, GL_TEXTURE_2D); | 797 | LLImageGL::unbindTexture(0, GL_TEXTURE_2D); |
794 | 798 | ||
795 | gGL.flush(); | 799 | gGL.flush(); |
796 | glColorMask( GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE ); | 800 | gGL.setColorMask(true, true); |
797 | gGL.blendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA ); | 801 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
798 | } | 802 | } |
799 | else | 803 | else |
800 | if( getInfo()->mClearAlpha ) | 804 | if( getInfo()->mClearAlpha ) |
@@ -803,12 +807,12 @@ BOOL LLTexLayerSet::render( S32 x, S32 y, S32 width, S32 height ) | |||
803 | LLGLSNoTextureNoAlphaTest gls_no_alpha; | 807 | LLGLSNoTextureNoAlphaTest gls_no_alpha; |
804 | gGL.color4f( 0.f, 0.f, 0.f, 1.f ); | 808 | gGL.color4f( 0.f, 0.f, 0.f, 1.f ); |
805 | gGL.flush(); | 809 | gGL.flush(); |
806 | glColorMask( GL_FALSE, GL_FALSE, GL_FALSE, GL_TRUE ); | 810 | gGL.setColorMask(false, true); |
807 | 811 | ||
808 | gl_rect_2d_simple( width, height ); | 812 | gl_rect_2d_simple( width, height ); |
809 | 813 | ||
810 | gGL.flush(); | 814 | gGL.flush(); |
811 | glColorMask( GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE ); | 815 | gGL.setColorMask(true, true); |
812 | } | 816 | } |
813 | stop_glerror(); | 817 | stop_glerror(); |
814 | 818 | ||
@@ -836,11 +840,11 @@ BOOL LLTexLayerSet::renderBump( S32 x, S32 y, S32 width, S32 height ) | |||
836 | // Set the alpha channel to one (clean up after previous blending) | 840 | // Set the alpha channel to one (clean up after previous blending) |
837 | LLGLSNoTextureNoAlphaTest gls_no_texture_no_alpha; | 841 | LLGLSNoTextureNoAlphaTest gls_no_texture_no_alpha; |
838 | gGL.color4f( 0.f, 0.f, 0.f, 1.f ); | 842 | gGL.color4f( 0.f, 0.f, 0.f, 1.f ); |
839 | glColorMask( GL_FALSE, GL_FALSE, GL_FALSE, GL_TRUE ); | 843 | gGL.setColorMask(false, true); |
840 | 844 | ||
841 | gl_rect_2d_simple( width, height ); | 845 | gl_rect_2d_simple( width, height ); |
842 | 846 | ||
843 | glColorMask( GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE ); | 847 | gGL.setColorMask(true, true); |
844 | stop_glerror(); | 848 | stop_glerror(); |
845 | 849 | ||
846 | return success; | 850 | return success; |
@@ -1330,7 +1334,7 @@ BOOL LLTexLayer::render( S32 x, S32 y, S32 width, S32 height ) | |||
1330 | renderAlphaMasks( x, y, width, height, &net_color ); | 1334 | renderAlphaMasks( x, y, width, height, &net_color ); |
1331 | alpha_mask_specified = TRUE; | 1335 | alpha_mask_specified = TRUE; |
1332 | gGL.flush(); | 1336 | gGL.flush(); |
1333 | gGL.blendFunc( GL_DST_ALPHA, GL_ONE_MINUS_DST_ALPHA ); | 1337 | gGL.blendFunc(LLRender::BF_DEST_ALPHA, LLRender::BF_ONE_MINUS_DEST_ALPHA); |
1334 | } | 1338 | } |
1335 | 1339 | ||
1336 | gGL.color4fv( net_color.mV); | 1340 | gGL.color4fv( net_color.mV); |
@@ -1338,7 +1342,7 @@ BOOL LLTexLayer::render( S32 x, S32 y, S32 width, S32 height ) | |||
1338 | if( getInfo()->mWriteAllChannels ) | 1342 | if( getInfo()->mWriteAllChannels ) |
1339 | { | 1343 | { |
1340 | gGL.flush(); | 1344 | gGL.flush(); |
1341 | gGL.blendFunc( GL_ONE, GL_ZERO ); | 1345 | gGL.setSceneBlendType(LLRender::BT_REPLACE); |
1342 | } | 1346 | } |
1343 | 1347 | ||
1344 | if( (getInfo()->mLocalTexture != -1) && !getInfo()->mUseLocalTextureAlphaOnly ) | 1348 | if( (getInfo()->mLocalTexture != -1) && !getInfo()->mUseLocalTextureAlphaOnly ) |
@@ -1401,7 +1405,7 @@ BOOL LLTexLayer::render( S32 x, S32 y, S32 width, S32 height ) | |||
1401 | { | 1405 | { |
1402 | // Restore standard blend func value | 1406 | // Restore standard blend func value |
1403 | gGL.flush(); | 1407 | gGL.flush(); |
1404 | gGL.blendFunc( GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA ); | 1408 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
1405 | stop_glerror(); | 1409 | stop_glerror(); |
1406 | } | 1410 | } |
1407 | 1411 | ||
@@ -1506,7 +1510,7 @@ BOOL LLTexLayer::renderAlphaMasks( S32 x, S32 y, S32 width, S32 height, LLColor4 | |||
1506 | 1510 | ||
1507 | llassert( !mParamAlphaList.empty() ); | 1511 | llassert( !mParamAlphaList.empty() ); |
1508 | 1512 | ||
1509 | glColorMask( GL_FALSE, GL_FALSE, GL_FALSE, GL_TRUE ); | 1513 | gGL.setColorMask(false, true); |
1510 | 1514 | ||
1511 | alpha_list_t::iterator iter = mParamAlphaList.begin(); | 1515 | alpha_list_t::iterator iter = mParamAlphaList.begin(); |
1512 | LLTexLayerParamAlpha* first_param = *iter; | 1516 | LLTexLayerParamAlpha* first_param = *iter; |
@@ -1518,7 +1522,7 @@ BOOL LLTexLayer::renderAlphaMasks( S32 x, S32 y, S32 width, S32 height, LLColor4 | |||
1518 | 1522 | ||
1519 | // Clear the alpha | 1523 | // Clear the alpha |
1520 | gGL.flush(); | 1524 | gGL.flush(); |
1521 | gGL.blendFunc( GL_ONE, GL_ZERO ); | 1525 | gGL.setSceneBlendType(LLRender::BT_REPLACE); |
1522 | 1526 | ||
1523 | gGL.color4f( 0.f, 0.f, 0.f, 0.f ); | 1527 | gGL.color4f( 0.f, 0.f, 0.f, 0.f ); |
1524 | gl_rect_2d_simple( width, height ); | 1528 | gl_rect_2d_simple( width, height ); |
@@ -1536,7 +1540,7 @@ BOOL LLTexLayer::renderAlphaMasks( S32 x, S32 y, S32 width, S32 height, LLColor4 | |||
1536 | 1540 | ||
1537 | // Approximates a min() function | 1541 | // Approximates a min() function |
1538 | gGL.flush(); | 1542 | gGL.flush(); |
1539 | gGL.blendFunc( GL_DST_ALPHA, GL_ZERO ); | 1543 | gGL.blendFunc(LLRender::BF_DEST_ALPHA, LLRender::BF_ZERO); |
1540 | 1544 | ||
1541 | // Accumulate the alpha component of the texture | 1545 | // Accumulate the alpha component of the texture |
1542 | if( getInfo()->mLocalTexture != -1 ) | 1546 | if( getInfo()->mLocalTexture != -1 ) |
@@ -1601,7 +1605,7 @@ BOOL LLTexLayer::renderAlphaMasks( S32 x, S32 y, S32 width, S32 height, LLColor4 | |||
1601 | 1605 | ||
1602 | LLGLSUIDefault gls_ui; | 1606 | LLGLSUIDefault gls_ui; |
1603 | 1607 | ||
1604 | glColorMask( GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE ); | 1608 | gGL.setColorMask(true, true); |
1605 | 1609 | ||
1606 | if (!mMorphMasksValid && !mMaskedMorphs.empty()) | 1610 | if (!mMorphMasksValid && !mMaskedMorphs.empty()) |
1607 | { | 1611 | { |
@@ -1963,11 +1967,11 @@ BOOL LLTexLayerParamAlpha::render( S32 x, S32 y, S32 width, S32 height ) | |||
1963 | gGL.flush(); | 1967 | gGL.flush(); |
1964 | if( getInfo()->mMultiplyBlend ) | 1968 | if( getInfo()->mMultiplyBlend ) |
1965 | { | 1969 | { |
1966 | gGL.blendFunc( GL_DST_ALPHA, GL_ZERO ); // Multiplication: approximates a min() function | 1970 | gGL.blendFunc(LLRender::BF_DEST_ALPHA, LLRender::BF_ZERO); // Multiplication: approximates a min() function |
1967 | } | 1971 | } |
1968 | else | 1972 | else |
1969 | { | 1973 | { |
1970 | gGL.blendFunc( GL_ONE, GL_ONE ); // Addition: approximates a max() function | 1974 | gGL.setSceneBlendType(LLRender::BT_ADD); // Addition: approximates a max() function |
1971 | } | 1975 | } |
1972 | 1976 | ||
1973 | if( !getInfo()->mStaticImageFileName.empty() && !mStaticImageInvalid) | 1977 | if( !getInfo()->mStaticImageFileName.empty() && !mStaticImageInvalid) |