diff options
Diffstat (limited to 'linden/indra/newview/lltexlayer.cpp')
-rw-r--r-- | linden/indra/newview/lltexlayer.cpp | 87 |
1 files changed, 57 insertions, 30 deletions
diff --git a/linden/indra/newview/lltexlayer.cpp b/linden/indra/newview/lltexlayer.cpp index a687344..0944d4b 100644 --- a/linden/indra/newview/lltexlayer.cpp +++ b/linden/indra/newview/lltexlayer.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2002-2008, Linden Research, Inc. | 7 | * Copyright (c) 2002-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 |
@@ -93,17 +93,59 @@ LLTexLayerSetBuffer::LLTexLayerSetBuffer( LLTexLayerSet* owner, S32 width, S32 h | |||
93 | mNeedsUpdate( TRUE ), | 93 | mNeedsUpdate( TRUE ), |
94 | mNeedsUpload( FALSE ), | 94 | mNeedsUpload( FALSE ), |
95 | mUploadPending( FALSE ), // Not used for any logic here, just to sync sending of updates | 95 | mUploadPending( FALSE ), // Not used for any logic here, just to sync sending of updates |
96 | mTexLayerSet( owner ), | 96 | mTexLayerSet( owner ) |
97 | mBumpTexName(0) | ||
98 | { | 97 | { |
99 | LLTexLayerSetBuffer::sGLByteCount += getSize(); | 98 | LLTexLayerSetBuffer::sGLByteCount += getSize(); |
99 | mHasBump = has_bump ; | ||
100 | mBumpTex = NULL ; | ||
100 | 101 | ||
101 | if( has_bump ) | 102 | createBumpTexture() ; |
103 | } | ||
104 | |||
105 | LLTexLayerSetBuffer::~LLTexLayerSetBuffer() | ||
106 | { | ||
107 | LLTexLayerSetBuffer::sGLByteCount -= getSize(); | ||
108 | |||
109 | if( mBumpTex.notNull()) | ||
110 | { | ||
111 | mBumpTex = NULL ; | ||
112 | LLImageGL::sGlobalTextureMemory -= mWidth * mHeight * 4; | ||
113 | LLTexLayerSetBuffer::sGLBumpByteCount -= mWidth * mHeight * 4; | ||
114 | } | ||
115 | } | ||
116 | //virtual | ||
117 | void LLTexLayerSetBuffer::restoreGLTexture() | ||
118 | { | ||
119 | createBumpTexture() ; | ||
120 | LLDynamicTexture::restoreGLTexture() ; | ||
121 | } | ||
122 | |||
123 | //virtual | ||
124 | void LLTexLayerSetBuffer::destroyGLTexture() | ||
125 | { | ||
126 | if( mBumpTex.notNull() ) | ||
127 | { | ||
128 | mBumpTex = NULL ; | ||
129 | LLImageGL::sGlobalTextureMemory -= mWidth * mHeight * 4; | ||
130 | LLTexLayerSetBuffer::sGLBumpByteCount -= mWidth * mHeight * 4; | ||
131 | } | ||
132 | |||
133 | LLDynamicTexture::destroyGLTexture() ; | ||
134 | } | ||
135 | |||
136 | void LLTexLayerSetBuffer::createBumpTexture() | ||
137 | { | ||
138 | if( mHasBump ) | ||
102 | { | 139 | { |
103 | LLGLSUIDefault gls_ui; | 140 | LLGLSUIDefault gls_ui; |
104 | glGenTextures(1, (GLuint*) &mBumpTexName); | 141 | mBumpTex = new LLImageGL(FALSE) ; |
142 | if(!mBumpTex->createGLTexture()) | ||
143 | { | ||
144 | mBumpTex = NULL ; | ||
145 | return ; | ||
146 | } | ||
105 | 147 | ||
106 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mBumpTexName); | 148 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mBumpTex->getTexName()); |
107 | stop_glerror(); | 149 | stop_glerror(); |
108 | 150 | ||
109 | gGL.getTexUnit(0)->setTextureAddressMode(LLTexUnit::TAM_CLAMP); | 151 | gGL.getTexUnit(0)->setTextureAddressMode(LLTexUnit::TAM_CLAMP); |
@@ -111,7 +153,7 @@ LLTexLayerSetBuffer::LLTexLayerSetBuffer( LLTexLayerSet* owner, S32 width, S32 h | |||
111 | glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); | 153 | glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); |
112 | glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); | 154 | glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_LINEAR); |
113 | 155 | ||
114 | glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA8, width, height, 0, GL_RGBA, GL_UNSIGNED_BYTE, NULL); | 156 | glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA8, mWidth, mHeight, 0, GL_RGBA, GL_UNSIGNED_BYTE, NULL); |
115 | stop_glerror(); | 157 | stop_glerror(); |
116 | 158 | ||
117 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); | 159 | gGL.getTexUnit(0)->unbind(LLTexUnit::TT_TEXTURE); |
@@ -121,21 +163,6 @@ LLTexLayerSetBuffer::LLTexLayerSetBuffer( LLTexLayerSet* owner, S32 width, S32 h | |||
121 | } | 163 | } |
122 | } | 164 | } |
123 | 165 | ||
124 | LLTexLayerSetBuffer::~LLTexLayerSetBuffer() | ||
125 | { | ||
126 | LLTexLayerSetBuffer::sGLByteCount -= getSize(); | ||
127 | |||
128 | if( mBumpTexName ) | ||
129 | { | ||
130 | glDeleteTextures(1, (GLuint*) &mBumpTexName); | ||
131 | stop_glerror(); | ||
132 | mBumpTexName = 0; | ||
133 | |||
134 | LLImageGL::sGlobalTextureMemory -= mWidth * mHeight * 4; | ||
135 | LLTexLayerSetBuffer::sGLBumpByteCount -= mWidth * mHeight * 4; | ||
136 | } | ||
137 | } | ||
138 | |||
139 | // static | 166 | // static |
140 | void LLTexLayerSetBuffer::dumpTotalByteCount() | 167 | void LLTexLayerSetBuffer::dumpTotalByteCount() |
141 | { | 168 | { |
@@ -244,7 +271,7 @@ BOOL LLTexLayerSetBuffer::render() | |||
244 | BOOL success = TRUE; | 271 | BOOL success = TRUE; |
245 | 272 | ||
246 | // Composite bump | 273 | // Composite bump |
247 | if( mBumpTexName ) | 274 | if( mBumpTex.notNull() ) |
248 | { | 275 | { |
249 | // Composite the bump data | 276 | // Composite the bump data |
250 | success &= mTexLayerSet->renderBump( mOrigin.mX, mOrigin.mY, mWidth, mHeight ); | 277 | success &= mTexLayerSet->renderBump( mOrigin.mX, mOrigin.mY, mWidth, mHeight ); |
@@ -255,7 +282,7 @@ BOOL LLTexLayerSetBuffer::render() | |||
255 | LLGLSUIDefault gls_ui; | 282 | LLGLSUIDefault gls_ui; |
256 | 283 | ||
257 | // read back into texture (this is done externally for the color data) | 284 | // read back into texture (this is done externally for the color data) |
258 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mBumpTexName); | 285 | gGL.getTexUnit(0)->bindManual(LLTexUnit::TT_TEXTURE, mBumpTex->getTexName()); |
259 | stop_glerror(); | 286 | stop_glerror(); |
260 | 287 | ||
261 | glCopyTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, mOrigin.mX, mOrigin.mY, mWidth, mHeight); | 288 | glCopyTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, mOrigin.mX, mOrigin.mY, mWidth, mHeight); |
@@ -295,7 +322,7 @@ BOOL LLTexLayerSetBuffer::render() | |||
295 | gGL.setSceneBlendType(LLRender::BT_ALPHA); | 322 | gGL.setSceneBlendType(LLRender::BT_ALPHA); |
296 | 323 | ||
297 | // we have valid texture data now | 324 | // we have valid texture data now |
298 | mTexture->setInitialized(true); | 325 | mTexture->setGLTextureCreated(true); |
299 | mNeedsUpdate = FALSE; | 326 | mNeedsUpdate = FALSE; |
300 | 327 | ||
301 | return success; | 328 | return success; |
@@ -303,7 +330,7 @@ BOOL LLTexLayerSetBuffer::render() | |||
303 | 330 | ||
304 | bool LLTexLayerSetBuffer::isInitialized(void) const | 331 | bool LLTexLayerSetBuffer::isInitialized(void) const |
305 | { | 332 | { |
306 | return mTexture->isInitialized(); | 333 | return mTexture.notNull() && mTexture->isGLTextureCreated(); |
307 | } | 334 | } |
308 | 335 | ||
309 | BOOL LLTexLayerSetBuffer::updateImmediate() | 336 | BOOL LLTexLayerSetBuffer::updateImmediate() |
@@ -351,11 +378,11 @@ void LLTexLayerSetBuffer::readBackAndUpload(U8* baked_bump_data) | |||
351 | // writes into baked_color_data | 378 | // writes into baked_color_data |
352 | const char* comment_text = NULL; | 379 | const char* comment_text = NULL; |
353 | 380 | ||
354 | S32 baked_image_components = mBumpTexName ? 5 : 4; // red green blue [bump] clothing | 381 | S32 baked_image_components = mBumpTex.notNull() ? 5 : 4; // red green blue [bump] clothing |
355 | LLPointer<LLImageRaw> baked_image = new LLImageRaw( mWidth, mHeight, baked_image_components ); | 382 | LLPointer<LLImageRaw> baked_image = new LLImageRaw( mWidth, mHeight, baked_image_components ); |
356 | U8* baked_image_data = baked_image->getData(); | 383 | U8* baked_image_data = baked_image->getData(); |
357 | 384 | ||
358 | if( mBumpTexName ) | 385 | if( mBumpTex.notNull() ) |
359 | { | 386 | { |
360 | comment_text = LINDEN_J2C_COMMENT_PREFIX "RGBHM"; // 5 channels: rgb, heightfield/alpha, mask | 387 | comment_text = LINDEN_J2C_COMMENT_PREFIX "RGBHM"; // 5 channels: rgb, heightfield/alpha, mask |
361 | 388 | ||
@@ -554,9 +581,9 @@ void LLTexLayerSetBuffer::onTextureUploadComplete(const LLUUID& uuid, void* user | |||
554 | 581 | ||
555 | void LLTexLayerSetBuffer::bindBumpTexture( U32 stage ) | 582 | void LLTexLayerSetBuffer::bindBumpTexture( U32 stage ) |
556 | { | 583 | { |
557 | if( mBumpTexName ) | 584 | if( mBumpTex.notNull() ) |
558 | { | 585 | { |
559 | gGL.getTexUnit(stage)->bindManual(LLTexUnit::TT_TEXTURE, mBumpTexName); | 586 | gGL.getTexUnit(stage)->bindManual(LLTexUnit::TT_TEXTURE, mBumpTex->getTexName()); |
560 | gGL.getTexUnit(0)->activate(); | 587 | gGL.getTexUnit(0)->activate(); |
561 | 588 | ||
562 | if( mLastBindTime != LLImageGL::sLastFrameTime ) | 589 | if( mLastBindTime != LLImageGL::sLastFrameTime ) |