diff options
author | Oz Linden <oz@lindenlab.com> | 2013-02-15 18:35:34 -0500 |
---|---|---|
committer | Oz Linden <oz@lindenlab.com> | 2013-02-15 18:35:34 -0500 |
commit | 1b4a585af6de4af5f861a5e83842b0464082c8fd (patch) | |
tree | 07794c2d6ad4e7d9459d1ad5aff5d7ba0173362b /indra/newview/pipeline.cpp | |
parent | 64a4a13397ea7b895ebbeb707bdba72e2d97ff6b (diff) | |
parent | ec3b4e05a43fec4414924eb92a483bc164fb0ec2 (diff) |
merge latest rendering fixes
Diffstat (limited to 'indra/newview/pipeline.cpp')
-rw-r--r-- | indra/newview/pipeline.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/indra/newview/pipeline.cpp b/indra/newview/pipeline.cpp index 6e585bc60a..8b9e02946b 100644 --- a/indra/newview/pipeline.cpp +++ b/indra/newview/pipeline.cpp @@ -1596,7 +1596,20 @@ U32 LLPipeline::getPoolTypeFromTE(const LLTextureEntry* te, LLViewerTexture* ima { alpha = alpha || (imagep->getComponents() == 4 && imagep->getType() != LLViewerTexture::MEDIA_TEXTURE) || (imagep->getComponents() == 2); } - + + if (alpha && te->getMaterialParams()) + { + switch (te->getMaterialParams()->getDiffuseAlphaMode()) + { + case 1: + alpha = true; // Material's alpha mode is set to blend. Toss it into the alpha draw pool. + break; + default: + alpha = false; // Material's alpha mode is set to none, mask, or emissive. Toss it into the opaque material draw pool. + break; + } + } + if (alpha) { return LLDrawPool::POOL_ALPHA; |