diff options
author | Graham Linden <graham@lindenlab.com> | 2013-07-08 10:47:02 -0700 |
---|---|---|
committer | Graham Linden <graham@lindenlab.com> | 2013-07-08 10:47:02 -0700 |
commit | 366932b81d55c562011239b68116ffb1a18ada97 (patch) | |
tree | 4f8cf497707c22f01941420d40b64c113c563fb0 /indra | |
parent | 5d7be3a4987c603500bbe3733870a378bd9eda92 (diff) | |
parent | b8e67899650b487f3e716366624eb74dc5f490b2 (diff) |
Merge
Diffstat (limited to 'indra')
-rwxr-xr-x | indra/newview/llvovolume.cpp | 24 |
1 files changed, 23 insertions, 1 deletions
diff --git a/indra/newview/llvovolume.cpp b/indra/newview/llvovolume.cpp index d890548710..b545e99a32 100755 --- a/indra/newview/llvovolume.cpp +++ b/indra/newview/llvovolume.cpp @@ -3724,8 +3724,30 @@ BOOL LLVOVolume::lineSegmentIntersect(const LLVector4a& start, const LLVector4a& { LLFace* face = mDrawable->getFace(face_hit); + bool ignore_alpha = false; + + const LLTextureEntry* te = face->getTextureEntry(); + if (te) + { + LLMaterial* mat = te->getMaterialParams(); + if (mat) + { + U8 mode = mat->getDiffuseAlphaMode(); + + if (mode == LLMaterial::DIFFUSE_ALPHA_MODE_EMISSIVE || + mode == LLMaterial::DIFFUSE_ALPHA_MODE_NONE) + { + ignore_alpha = true; + } + } + } + if (face && - (pick_transparent || !face->getTexture() || !face->getTexture()->hasGLTexture() || face->getTexture()->getMask(face->surfaceToTexture(tc, p, n)))) + (ignore_alpha || + pick_transparent || + !face->getTexture() || + !face->getTexture()->hasGLTexture() || + face->getTexture()->getMask(face->surfaceToTexture(tc, p, n)))) { local_end = p; if (face_hitp != NULL) |