diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/lldynamictexture.cpp | 45 |
1 files changed, 41 insertions, 4 deletions
diff --git a/linden/indra/newview/lldynamictexture.cpp b/linden/indra/newview/lldynamictexture.cpp index 9ce4515..8801d72 100644 --- a/linden/indra/newview/lldynamictexture.cpp +++ b/linden/indra/newview/lldynamictexture.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2001&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2001-2008, Linden Research, Inc. | 7 | * Copyright (c) 2001-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -112,7 +112,7 @@ void LLDynamicTexture::generateGLTexture(LLGLint internal_format, LLGLenum prima | |||
112 | // llinfos << "ALLOCATING " << (mWidth*mHeight*mComponents)/1024 << "K" << llendl; | 112 | // llinfos << "ALLOCATING " << (mWidth*mHeight*mComponents)/1024 << "K" << llendl; |
113 | mTexture->createGLTexture(0, raw_image); | 113 | mTexture->createGLTexture(0, raw_image); |
114 | mTexture->setClamp(mClamp, mClamp); | 114 | mTexture->setClamp(mClamp, mClamp); |
115 | mTexture->setInitialized(false); | 115 | mTexture->setGLTextureCreated(false); |
116 | } | 116 | } |
117 | 117 | ||
118 | //----------------------------------------------------------------------------- | 118 | //----------------------------------------------------------------------------- |
@@ -197,6 +197,7 @@ BOOL LLDynamicTexture::updateAllInstances() | |||
197 | } | 197 | } |
198 | 198 | ||
199 | BOOL result = FALSE; | 199 | BOOL result = FALSE; |
200 | BOOL ret = FALSE ; | ||
200 | for( S32 order = 0; order < ORDER_COUNT; order++ ) | 201 | for( S32 order = 0; order < ORDER_COUNT; order++ ) |
201 | { | 202 | { |
202 | for (instance_list_t::iterator iter = LLDynamicTexture::sInstances[order].begin(); | 203 | for (instance_list_t::iterator iter = LLDynamicTexture::sInstances[order].begin(); |
@@ -211,9 +212,10 @@ BOOL LLDynamicTexture::updateAllInstances() | |||
211 | 212 | ||
212 | gGL.color4f(1,1,1,1); | 213 | gGL.color4f(1,1,1,1); |
213 | dynamicTexture->preRender(); // Must be called outside of startRender() | 214 | dynamicTexture->preRender(); // Must be called outside of startRender() |
214 | 215 | result = FALSE; | |
215 | if (dynamicTexture->render()) | 216 | if (dynamicTexture->render()) |
216 | { | 217 | { |
218 | ret = TRUE ; | ||
217 | result = TRUE; | 219 | result = TRUE; |
218 | sNumRenders++; | 220 | sNumRenders++; |
219 | } | 221 | } |
@@ -225,7 +227,19 @@ BOOL LLDynamicTexture::updateAllInstances() | |||
225 | } | 227 | } |
226 | } | 228 | } |
227 | 229 | ||
228 | return result; | 230 | return ret; |
231 | } | ||
232 | |||
233 | //virtual | ||
234 | void LLDynamicTexture::restoreGLTexture() | ||
235 | { | ||
236 | generateGLTexture() ; | ||
237 | } | ||
238 | |||
239 | //virtual | ||
240 | void LLDynamicTexture::destroyGLTexture() | ||
241 | { | ||
242 | releaseGLTexture() ; | ||
229 | } | 243 | } |
230 | 244 | ||
231 | //----------------------------------------------------------------------------- | 245 | //----------------------------------------------------------------------------- |
@@ -234,6 +248,15 @@ BOOL LLDynamicTexture::updateAllInstances() | |||
234 | //----------------------------------------------------------------------------- | 248 | //----------------------------------------------------------------------------- |
235 | void LLDynamicTexture::destroyGL() | 249 | void LLDynamicTexture::destroyGL() |
236 | { | 250 | { |
251 | for( S32 order = 0; order < ORDER_COUNT; order++ ) | ||
252 | { | ||
253 | for (instance_list_t::iterator iter = LLDynamicTexture::sInstances[order].begin(); | ||
254 | iter != LLDynamicTexture::sInstances[order].end(); ++iter) | ||
255 | { | ||
256 | LLDynamicTexture *dynamicTexture = *iter; | ||
257 | dynamicTexture->destroyGLTexture() ; | ||
258 | } | ||
259 | } | ||
237 | } | 260 | } |
238 | 261 | ||
239 | //----------------------------------------------------------------------------- | 262 | //----------------------------------------------------------------------------- |
@@ -242,4 +265,18 @@ void LLDynamicTexture::destroyGL() | |||
242 | //----------------------------------------------------------------------------- | 265 | //----------------------------------------------------------------------------- |
243 | void LLDynamicTexture::restoreGL() | 266 | void LLDynamicTexture::restoreGL() |
244 | { | 267 | { |
268 | if (gGLManager.mIsDisabled) | ||
269 | { | ||
270 | return ; | ||
271 | } | ||
272 | |||
273 | for( S32 order = 0; order < ORDER_COUNT; order++ ) | ||
274 | { | ||
275 | for (instance_list_t::iterator iter = LLDynamicTexture::sInstances[order].begin(); | ||
276 | iter != LLDynamicTexture::sInstances[order].end(); ++iter) | ||
277 | { | ||
278 | LLDynamicTexture *dynamicTexture = *iter; | ||
279 | dynamicTexture->restoreGLTexture() ; | ||
280 | } | ||
281 | } | ||
245 | } | 282 | } |