aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/lldrawpoolwlsky.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/newview/lldrawpoolwlsky.cpp21
1 files changed, 6 insertions, 15 deletions
diff --git a/linden/indra/newview/lldrawpoolwlsky.cpp b/linden/indra/newview/lldrawpoolwlsky.cpp
index e10cd0a..01e1af0 100644
--- a/linden/indra/newview/lldrawpoolwlsky.cpp
+++ b/linden/indra/newview/lldrawpoolwlsky.cpp
@@ -44,7 +44,7 @@
44#include "llagent.h" 44#include "llagent.h"
45#include "llviewerregion.h" 45#include "llviewerregion.h"
46#include "llface.h" 46#include "llface.h"
47#include "llglimmediate.h" 47#include "llrender.h"
48 48
49LLPointer<LLImageGL> LLDrawPoolWLSky::sCloudNoiseTexture = NULL; 49LLPointer<LLImageGL> LLDrawPoolWLSky::sCloudNoiseTexture = NULL;
50 50
@@ -153,7 +153,7 @@ void LLDrawPoolWLSky::renderStars(void) const
153{ 153{
154 LLGLSPipelineSkyBox gls_sky; 154 LLGLSPipelineSkyBox gls_sky;
155 LLGLEnable blend(GL_BLEND); 155 LLGLEnable blend(GL_BLEND);
156 gGL.blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); 156 gGL.setSceneBlendType(LLRender::BT_ALPHA);
157 157
158 // *NOTE: have to have bound the cloud noise texture already since register 158 // *NOTE: have to have bound the cloud noise texture already since register
159 // combiners blending below requires something to be bound 159 // combiners blending below requires something to be bound
@@ -176,16 +176,8 @@ void LLDrawPoolWLSky::renderStars(void) const
176 176
177 // gl_FragColor.rgb = gl_Color.rgb; 177 // gl_FragColor.rgb = gl_Color.rgb;
178 // gl_FragColor.a = gl_Color.a * star_alpha.a; 178 // gl_FragColor.a = gl_Color.a * star_alpha.a;
179 glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_COMBINE_ARB); 179 gGL.getTexUnit(0)->setTextureColorBlend(LLTexUnit::TBO_REPLACE, LLTexUnit::TBS_PREV_COLOR);
180 glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_RGB_ARB, GL_REPLACE); 180 gGL.getTexUnit(0)->setTextureAlphaBlend(LLTexUnit::TBO_MULT_X2, LLTexUnit::TBS_PREV_ALPHA, LLTexUnit::TBS_CONST_ALPHA);
181 glTexEnvi(GL_TEXTURE_ENV, GL_COMBINE_ALPHA_ARB, GL_MODULATE);
182 glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE0_RGB_ARB, GL_PREVIOUS);
183 glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND0_RGB_ARB, GL_SRC_COLOR);
184 glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE0_ALPHA_ARB, GL_PREVIOUS);
185 glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND0_ALPHA_ARB, GL_SRC_ALPHA);
186 glTexEnvi(GL_TEXTURE_ENV, GL_SOURCE1_ALPHA_ARB, GL_CONSTANT);
187 glTexEnvi(GL_TEXTURE_ENV, GL_OPERAND1_ALPHA_ARB, GL_SRC_ALPHA);
188 glTexEnvf(GL_TEXTURE_ENV, GL_ALPHA_SCALE, 2.0f);
189 glTexEnvfv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_COLOR, star_alpha.mV); 181 glTexEnvfv(GL_TEXTURE_ENV, GL_TEXTURE_ENV_COLOR, star_alpha.mV);
190 182
191 gSky.mVOWLSkyp->drawStars(); 183 gSky.mVOWLSkyp->drawStars();
@@ -193,8 +185,7 @@ void LLDrawPoolWLSky::renderStars(void) const
193 glPointSize(1.f); 185 glPointSize(1.f);
194 186
195 // and disable the combiner states 187 // and disable the combiner states
196 glTexEnvf(GL_TEXTURE_ENV, GL_ALPHA_SCALE, 1.0f); 188 gGL.getTexUnit(0)->setTextureBlendType(LLTexUnit::TB_MULT);
197 glTexEnvi(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
198} 189}
199 190
200void LLDrawPoolWLSky::renderSkyClouds(F32 camHeightLocal) const 191void LLDrawPoolWLSky::renderSkyClouds(F32 camHeightLocal) const
@@ -208,7 +199,7 @@ void LLDrawPoolWLSky::renderSkyClouds(F32 camHeightLocal) const
208 199
209 LLGLEnable blend(GL_BLEND); 200 LLGLEnable blend(GL_BLEND);
210 LLGLSBlendFunc blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); 201 LLGLSBlendFunc blendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
211 glAlphaFunc(GL_GREATER, 0.01f); 202 gGL.setAlphaRejectSettings(LLRender::CF_DEFAULT);
212 203
213 sCloudNoiseTexture->bind(); 204 sCloudNoiseTexture->bind();
214 shader->bind(); 205 shader->bind();