diff options
Diffstat (limited to 'linden/indra/newview/lltexlayer.h')
-rw-r--r-- | linden/indra/newview/lltexlayer.h | 585 |
1 files changed, 585 insertions, 0 deletions
diff --git a/linden/indra/newview/lltexlayer.h b/linden/indra/newview/lltexlayer.h new file mode 100644 index 0000000..3db6f96 --- /dev/null +++ b/linden/indra/newview/lltexlayer.h | |||
@@ -0,0 +1,585 @@ | |||
1 | /** | ||
2 | * @file lltexlayer.h | ||
3 | * @brief A texture layer. Used for avatars. | ||
4 | * | ||
5 | * Copyright (c) 2002-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | #ifndef LL_LLTEXLAYER_H | ||
29 | #define LL_LLTEXLAYER_H | ||
30 | |||
31 | #include <deque> | ||
32 | #include "llassetstorage.h" | ||
33 | #include "lldynamictexture.h" | ||
34 | #include "llrect.h" | ||
35 | #include "llstring.h" | ||
36 | #include "lluuid.h" | ||
37 | #include "llviewerimage.h" | ||
38 | #include "llviewervisualparam.h" | ||
39 | #include "llvoavatar.h" | ||
40 | #include "llwearable.h" | ||
41 | #include "v4color.h" | ||
42 | #include "llfloater.h" | ||
43 | |||
44 | class LLTexLayerSetInfo; | ||
45 | class LLTexLayerSet; | ||
46 | class LLTexLayerInfo; | ||
47 | class LLTexLayer; | ||
48 | class LLImageGL; | ||
49 | class LLImageTGA; | ||
50 | class LLTexGlobalColorInfo; | ||
51 | class LLTexLayerParamAlphaInfo; | ||
52 | class LLTexLayerParamAlpha; | ||
53 | class LLTexParamColorInfo; | ||
54 | class LLTexParamColor; | ||
55 | class LLPolyMesh; | ||
56 | class LLXmlTreeNode; | ||
57 | class LLImageRaw; | ||
58 | class LLPolyMorphTarget; | ||
59 | |||
60 | class LLTextureCtrl; | ||
61 | class LLVOAvatar; | ||
62 | |||
63 | |||
64 | enum EColorOperation | ||
65 | { | ||
66 | OP_ADD = 0, | ||
67 | OP_MULTIPLY = 1, | ||
68 | OP_BLEND = 2, | ||
69 | OP_COUNT = 3 // Number of operations | ||
70 | }; | ||
71 | |||
72 | |||
73 | //----------------------------------------------------------------------------- | ||
74 | // LLTexLayerParamAlphaInfo | ||
75 | //----------------------------------------------------------------------------- | ||
76 | class LLTexLayerParamAlphaInfo : public LLViewerVisualParamInfo | ||
77 | { | ||
78 | friend class LLTexLayerParamAlpha; | ||
79 | public: | ||
80 | LLTexLayerParamAlphaInfo(); | ||
81 | /*virtual*/ ~LLTexLayerParamAlphaInfo() {}; | ||
82 | |||
83 | /*virtual*/ BOOL parseXml(LLXmlTreeNode* node); | ||
84 | |||
85 | protected: | ||
86 | LLString mStaticImageFileName; | ||
87 | BOOL mMultiplyBlend; | ||
88 | BOOL mSkipIfZeroWeight; | ||
89 | F32 mDomain; | ||
90 | }; | ||
91 | |||
92 | //----------------------------------------------------------------------------- | ||
93 | // LLTexParamColorInfo | ||
94 | //----------------------------------------------------------------------------- | ||
95 | class LLTexParamColorInfo : public LLViewerVisualParamInfo | ||
96 | { | ||
97 | friend class LLTexParamColor; | ||
98 | |||
99 | public: | ||
100 | LLTexParamColorInfo(); | ||
101 | virtual ~LLTexParamColorInfo() {}; | ||
102 | BOOL parseXml( LLXmlTreeNode* node ); | ||
103 | |||
104 | protected: | ||
105 | enum { MAX_COLOR_VALUES = 20 }; | ||
106 | EColorOperation mOperation; | ||
107 | LLColor4 mColors[MAX_COLOR_VALUES]; | ||
108 | S32 mNumColors; | ||
109 | }; | ||
110 | |||
111 | //----------------------------------------------------------------------------- | ||
112 | // LLTexGlobalColorInfo | ||
113 | //----------------------------------------------------------------------------- | ||
114 | class LLTexGlobalColorInfo | ||
115 | { | ||
116 | friend class LLTexGlobalColor; | ||
117 | public: | ||
118 | LLTexGlobalColorInfo(); | ||
119 | ~LLTexGlobalColorInfo(); | ||
120 | |||
121 | BOOL parseXml(LLXmlTreeNode* node); | ||
122 | |||
123 | protected: | ||
124 | typedef std::vector<LLTexParamColorInfo *> color_info_list_t; | ||
125 | color_info_list_t mColorInfoList; | ||
126 | LLString mName; | ||
127 | }; | ||
128 | |||
129 | //----------------------------------------------------------------------------- | ||
130 | // LLTexLayerSetInfo | ||
131 | // Containes shared layer set data | ||
132 | //----------------------------------------------------------------------------- | ||
133 | class LLTexLayerSetInfo | ||
134 | { | ||
135 | friend class LLTexLayerSet; | ||
136 | public: | ||
137 | LLTexLayerSetInfo(); | ||
138 | ~LLTexLayerSetInfo(); | ||
139 | |||
140 | BOOL parseXml(LLXmlTreeNode* node); | ||
141 | |||
142 | protected: | ||
143 | LLString mBodyRegion; | ||
144 | S32 mWidth; | ||
145 | S32 mHeight; | ||
146 | LLString mStaticAlphaFileName; | ||
147 | BOOL mClearAlpha; // Set alpha to 1 for this layerset (if there is no mStaticAlphaFileName) | ||
148 | |||
149 | typedef std::vector<LLTexLayerInfo*> layer_info_list_t; | ||
150 | layer_info_list_t mLayerInfoList; | ||
151 | }; | ||
152 | |||
153 | //----------------------------------------------------------------------------- | ||
154 | // LLTexLayerInfo | ||
155 | //----------------------------------------------------------------------------- | ||
156 | enum ERenderPass | ||
157 | { | ||
158 | RP_COLOR, | ||
159 | RP_BUMP, | ||
160 | RP_SHINE | ||
161 | }; | ||
162 | |||
163 | class LLTexLayerInfo | ||
164 | { | ||
165 | friend class LLTexLayer; | ||
166 | public: | ||
167 | LLTexLayerInfo(); | ||
168 | ~LLTexLayerInfo(); | ||
169 | |||
170 | BOOL parseXml(LLXmlTreeNode* node); | ||
171 | |||
172 | protected: | ||
173 | LLString mName; | ||
174 | |||
175 | BOOL mWriteAllChannels; // Don't use masking. Just write RGBA into buffer, | ||
176 | ERenderPass mRenderPass; | ||
177 | |||
178 | LLString mGlobalColor; | ||
179 | LLColor4 mFixedColor; | ||
180 | |||
181 | S32 mLocalTexture; | ||
182 | LLString mStaticImageFileName; | ||
183 | BOOL mStaticImageIsMask; | ||
184 | BOOL mUseLocalTextureAlphaOnly; // Ignore RGB channels from the input texture. Use alpha as a mask | ||
185 | |||
186 | typedef std::vector<std::pair<LLString,BOOL> > morph_name_list_t; | ||
187 | morph_name_list_t mMorphNameList; | ||
188 | |||
189 | typedef std::vector<LLTexParamColorInfo*> color_info_list_t; | ||
190 | color_info_list_t mColorInfoList; | ||
191 | |||
192 | typedef std::vector<LLTexLayerParamAlphaInfo*> alpha_info_list_t; | ||
193 | alpha_info_list_t mAlphaInfoList; | ||
194 | |||
195 | }; | ||
196 | |||
197 | //----------------------------------------------------------------------------- | ||
198 | // LLTexLayerSetBuffer | ||
199 | // The composite image that a LLTexLayerSet writes to. Each LLTexLayerSet has one. | ||
200 | //----------------------------------------------------------------------------- | ||
201 | class LLTexLayerSetBuffer : public LLDynamicTexture | ||
202 | { | ||
203 | public: | ||
204 | LLTexLayerSetBuffer( LLTexLayerSet* owner, S32 width, S32 height, BOOL has_bump ); | ||
205 | virtual ~LLTexLayerSetBuffer(); | ||
206 | |||
207 | virtual void preRender(BOOL clear_depth); | ||
208 | virtual void postRender(BOOL success); | ||
209 | virtual BOOL render(); | ||
210 | BOOL updateImmediate(); | ||
211 | virtual void bindTexture(); | ||
212 | void bindBumpTexture( U32 stage ); | ||
213 | BOOL isInitialized() { return mInitialized; } // Initialized here means that we've done at least one render | ||
214 | BOOL needsRender(); | ||
215 | void requestUpdate(); | ||
216 | void requestUpload(); | ||
217 | void cancelUpload(); | ||
218 | BOOL uploadPending() { return mUploadPending; } | ||
219 | BOOL render( S32 x, S32 y, S32 width, S32 height ); | ||
220 | void readBackAndUpload(U8* baked_bump_data); | ||
221 | static void onTextureUploadComplete( const LLUUID& uuid, | ||
222 | void* userdata, | ||
223 | S32 result); | ||
224 | static void dumpTotalByteCount(); | ||
225 | |||
226 | private: | ||
227 | void pushProjection(); | ||
228 | void popProjection(); | ||
229 | |||
230 | private: | ||
231 | BOOL mNeedsUpdate; | ||
232 | BOOL mNeedsUpload; | ||
233 | BOOL mUploadPending; | ||
234 | LLUUID mUploadID; // Identifys the current upload process (null if none). Used to avoid overlaps (eg, when the user rapidly makes two changes outside of Face Edit) | ||
235 | LLTexLayerSet* mTexLayerSet; | ||
236 | BOOL mInitialized; | ||
237 | LLGLuint mBumpTexName; // zero if none | ||
238 | |||
239 | static S32 sGLByteCount; | ||
240 | static S32 sGLBumpByteCount; | ||
241 | }; | ||
242 | |||
243 | //----------------------------------------------------------------------------- | ||
244 | // LLTexLayerSet | ||
245 | // An ordered set of texture layers that get composited into a single texture. | ||
246 | //----------------------------------------------------------------------------- | ||
247 | class LLTexLayerSet | ||
248 | { | ||
249 | public: | ||
250 | LLTexLayerSet( LLVOAvatar* avatar ); | ||
251 | ~LLTexLayerSet(); | ||
252 | |||
253 | //BOOL parseData(LLXmlTreeNode* node); | ||
254 | LLTexLayerSetInfo* getInfo() const { return mInfo; } | ||
255 | // This sets mInfo and calls initialization functions | ||
256 | BOOL setInfo(LLTexLayerSetInfo *info); | ||
257 | |||
258 | BOOL render( S32 x, S32 y, S32 width, S32 height ); | ||
259 | BOOL renderBump( S32 x, S32 y, S32 width,S32 height ); | ||
260 | BOOL isBodyRegion( const char* region ) { return mInfo->mBodyRegion == region; } | ||
261 | LLTexLayerSetBuffer* getComposite(); | ||
262 | void requestUpdate(); | ||
263 | void requestUpload(); | ||
264 | void cancelUpload(); | ||
265 | LLVOAvatar* getAvatar() { return mAvatar; } | ||
266 | void updateComposite(); | ||
267 | BOOL isLocalTextureDataAvailable(); | ||
268 | BOOL isLocalTextureDataFinal(); | ||
269 | void createComposite(); | ||
270 | void destroyComposite(); | ||
271 | void setUpdatesEnabled( BOOL b ); | ||
272 | BOOL getUpdatesEnabled() { return mUpdatesEnabled; } | ||
273 | void deleteCaches(); | ||
274 | void gatherAlphaMasks(U8 *data, S32 width, S32 height); | ||
275 | void applyMorphMask(U8* tex_data, S32 width, S32 height, S32 num_components); | ||
276 | const LLString& getBodyRegion() { return mInfo->mBodyRegion; } | ||
277 | BOOL hasComposite() { return (mComposite != NULL); } | ||
278 | void setBump( BOOL b ) { mHasBump = b; } | ||
279 | BOOL hasBump() { return mHasBump; } | ||
280 | |||
281 | public: | ||
282 | static BOOL sHasCaches; | ||
283 | |||
284 | protected: | ||
285 | typedef std::vector<LLTexLayer *> layer_list_t; | ||
286 | layer_list_t mLayerList; | ||
287 | LLTexLayerSetBuffer* mComposite; | ||
288 | LLVOAvatar* mAvatar; | ||
289 | BOOL mUpdatesEnabled; | ||
290 | BOOL mHasBump; | ||
291 | |||
292 | LLTexLayerSetInfo *mInfo; | ||
293 | }; | ||
294 | |||
295 | //----------------------------------------------------------------------------- | ||
296 | // LLMaskedMorph | ||
297 | //----------------------------------------------------------------------------- | ||
298 | |||
299 | class LLMaskedMorph | ||
300 | { | ||
301 | public: | ||
302 | LLMaskedMorph( LLPolyMorphTarget *morph_target, BOOL invert ); | ||
303 | |||
304 | public: | ||
305 | LLPolyMorphTarget *mMorphTarget; | ||
306 | BOOL mInvert; | ||
307 | }; | ||
308 | |||
309 | //----------------------------------------------------------------------------- | ||
310 | // LLTexLayer | ||
311 | // A single texture layer | ||
312 | //----------------------------------------------------------------------------- | ||
313 | class LLTexLayer | ||
314 | { | ||
315 | public: | ||
316 | LLTexLayer( LLTexLayerSet* layer_set ); | ||
317 | ~LLTexLayer(); | ||
318 | |||
319 | //BOOL parseData(LLXmlTreeNode* node); | ||
320 | LLTexLayerInfo* getInfo() const { return mInfo; } | ||
321 | // This sets mInfo and calls initialization functions | ||
322 | BOOL setInfo(LLTexLayerInfo *info); | ||
323 | |||
324 | BOOL render( S32 x, S32 y, S32 width, S32 height ); | ||
325 | void requestUpdate(); | ||
326 | LLTexLayerSet* getTexLayerSet() { return mTexLayerSet; } | ||
327 | |||
328 | const std::string& getName() { return mInfo->mName; } | ||
329 | |||
330 | void addMaskedMorph(LLPolyMorphTarget* morph_target, BOOL invert); | ||
331 | void deleteCaches(); | ||
332 | U8* getAlphaData(); | ||
333 | void applyMorphMask(U8* tex_data, S32 width, S32 height, S32 num_components); | ||
334 | |||
335 | void invalidateMorphMasks(); | ||
336 | ERenderPass getRenderPass() { return mInfo->mRenderPass; } | ||
337 | const LLString& getGlobalColor() { return mInfo->mGlobalColor; } | ||
338 | BOOL findNetColor( LLColor4* color ); | ||
339 | BOOL renderImageRaw( U8* in_data, S32 in_width, S32 in_height, S32 in_components, S32 width, S32 height, BOOL is_mask ); | ||
340 | BOOL renderAlphaMasks( S32 x, S32 y, S32 width, S32 height, LLColor4* colorp ); | ||
341 | BOOL hasAlphaParams() { return (!mParamAlphaList.empty());} | ||
342 | |||
343 | protected: | ||
344 | BOOL loadStaticImageRaw(); | ||
345 | |||
346 | protected: | ||
347 | LLTexLayerSet* mTexLayerSet; | ||
348 | LLPointer<LLImageRaw> mStaticImageRaw; | ||
349 | |||
350 | // Layers can have either mParamColorList, mGlobalColor, or mFixedColor. They are looked for in that order. | ||
351 | typedef std::vector<LLTexParamColor *> color_list_t; | ||
352 | color_list_t mParamColorList; | ||
353 | // mGlobalColor name stored in mInfo | ||
354 | // mFixedColor value stored in mInfo | ||
355 | |||
356 | typedef std::vector<LLTexLayerParamAlpha *> alpha_list_t; | ||
357 | alpha_list_t mParamAlphaList; | ||
358 | |||
359 | |||
360 | typedef std::deque<LLMaskedMorph> morph_list_t; | ||
361 | morph_list_t mMaskedMorphs; | ||
362 | typedef std::map<U32, U8*> alpha_cache_t; | ||
363 | alpha_cache_t mAlphaCache; | ||
364 | BOOL mMorphMasksValid; | ||
365 | BOOL mStaticImageInvalid; | ||
366 | |||
367 | LLTexLayerInfo *mInfo; | ||
368 | }; | ||
369 | |||
370 | //----------------------------------------------------------------------------- | ||
371 | // LLTexLayerParamAlpha | ||
372 | //----------------------------------------------------------------------------- | ||
373 | class LLTexLayerParamAlpha : public LLViewerVisualParam | ||
374 | { | ||
375 | public: | ||
376 | LLTexLayerParamAlpha( LLTexLayer* layer ); | ||
377 | /*virtual*/ ~LLTexLayerParamAlpha(); | ||
378 | |||
379 | // Special: These functions are overridden by child classes | ||
380 | LLTexLayerParamAlphaInfo* getInfo() const { return (LLTexLayerParamAlphaInfo*)mInfo; } | ||
381 | // This sets mInfo and calls initialization functions | ||
382 | BOOL setInfo(LLTexLayerParamAlphaInfo *info); | ||
383 | |||
384 | // LLVisualParam Virtual functions | ||
385 | ///*virtual*/ BOOL parseData(LLXmlTreeNode* node); | ||
386 | /*virtual*/ void apply( ESex avatar_sex ) {} | ||
387 | /*virtual*/ void setWeight(F32 weight, BOOL set_by_user); | ||
388 | /*virtual*/ void setAnimationTarget(F32 target_value, BOOL set_by_user); | ||
389 | /*virtual*/ void animate(F32 delta, BOOL set_by_user); | ||
390 | |||
391 | // LLViewerVisualParam Virtual functions | ||
392 | /*virtual*/ F32 getTotalDistortion() { return 1.f; } | ||
393 | /*virtual*/ const LLVector3& getAvgDistortion() { return mAvgDistortionVec; } | ||
394 | /*virtual*/ F32 getMaxDistortion() { return 3.f; } | ||
395 | /*virtual*/ LLVector3 getVertexDistortion(S32 index, LLPolyMesh *poly_mesh) { return LLVector3(1.f, 1.f, 1.f);} | ||
396 | /*virtual*/ const LLVector3* getFirstDistortion(U32 *index, LLPolyMesh **poly_mesh) { index = 0; poly_mesh = NULL; return &mAvgDistortionVec;}; | ||
397 | /*virtual*/ const LLVector3* getNextDistortion(U32 *index, LLPolyMesh **poly_mesh) { index = 0; poly_mesh = NULL; return NULL;}; | ||
398 | |||
399 | // New functions | ||
400 | BOOL render( S32 x, S32 y, S32 width, S32 height ); | ||
401 | BOOL getSkip(); | ||
402 | void deleteCaches(); | ||
403 | LLTexLayer* getTexLayer() { return mTexLayer; } | ||
404 | BOOL getMultiplyBlend() { return getInfo()->mMultiplyBlend; } | ||
405 | |||
406 | protected: | ||
407 | LLPointer<LLImageGL> mCachedProcessedImageGL; | ||
408 | LLTexLayer* mTexLayer; | ||
409 | LLPointer<LLImageTGA> mStaticImageTGA; | ||
410 | LLPointer<LLImageRaw> mStaticImageRaw; | ||
411 | BOOL mNeedsCreateTexture; | ||
412 | BOOL mStaticImageInvalid; | ||
413 | LLVector3 mAvgDistortionVec; | ||
414 | F32 mCachedEffectiveWeight; | ||
415 | |||
416 | public: | ||
417 | // Global list of instances for gathering statistics | ||
418 | static void dumpCacheByteCount(); | ||
419 | static void getCacheByteCount( S32* gl_bytes ); | ||
420 | |||
421 | typedef std::list< LLTexLayerParamAlpha* > param_alpha_ptr_list_t; | ||
422 | static param_alpha_ptr_list_t sInstances; | ||
423 | }; | ||
424 | |||
425 | |||
426 | //----------------------------------------------------------------------------- | ||
427 | // LLTexGlobalColor | ||
428 | //----------------------------------------------------------------------------- | ||
429 | class LLTexGlobalColor | ||
430 | { | ||
431 | public: | ||
432 | LLTexGlobalColor( LLVOAvatar* avatar ); | ||
433 | ~LLTexGlobalColor(); | ||
434 | |||
435 | //BOOL parseData(LLXmlTreeNode* node); | ||
436 | LLTexGlobalColorInfo* getInfo() const { return mInfo; } | ||
437 | // This sets mInfo and calls initialization functions | ||
438 | BOOL setInfo(LLTexGlobalColorInfo *info); | ||
439 | |||
440 | void requstUpdate(); | ||
441 | LLVOAvatar* getAvatar() { return mAvatar; } | ||
442 | LLColor4 getColor(); | ||
443 | const std::string& getName() { return mInfo->mName; } | ||
444 | |||
445 | protected: | ||
446 | typedef std::vector<LLTexParamColor *> param_list_t; | ||
447 | param_list_t mParamList; | ||
448 | LLVOAvatar* mAvatar; | ||
449 | |||
450 | LLTexGlobalColorInfo *mInfo; | ||
451 | }; | ||
452 | |||
453 | |||
454 | //----------------------------------------------------------------------------- | ||
455 | // LLTexParamColor | ||
456 | //----------------------------------------------------------------------------- | ||
457 | class LLTexParamColor : public LLViewerVisualParam | ||
458 | { | ||
459 | public: | ||
460 | LLTexParamColor( LLTexGlobalColor* tex_color ); | ||
461 | LLTexParamColor( LLTexLayer* layer ); | ||
462 | /* virtual */ ~LLTexParamColor(); | ||
463 | |||
464 | // Special: These functions are overridden by child classes | ||
465 | LLTexParamColorInfo* getInfo() const { return (LLTexParamColorInfo*)mInfo; } | ||
466 | // This sets mInfo and calls initialization functions | ||
467 | BOOL setInfo(LLTexParamColorInfo *info); | ||
468 | |||
469 | // LLVisualParam Virtual functions | ||
470 | ///*virtual*/ BOOL parseData(LLXmlTreeNode* node); | ||
471 | /*virtual*/ void apply( ESex avatar_sex ) {} | ||
472 | /*virtual*/ void setWeight(F32 weight, BOOL set_by_user); | ||
473 | /*virtual*/ void setAnimationTarget(F32 target_value, BOOL set_by_user); | ||
474 | /*virtual*/ void animate(F32 delta, BOOL set_by_user); | ||
475 | |||
476 | |||
477 | // LLViewerVisualParam Virtual functions | ||
478 | /*virtual*/ F32 getTotalDistortion() { return 1.f; } | ||
479 | /*virtual*/ const LLVector3& getAvgDistortion() { return mAvgDistortionVec; } | ||
480 | /*virtual*/ F32 getMaxDistortion() { return 3.f; } | ||
481 | /*virtual*/ LLVector3 getVertexDistortion(S32 index, LLPolyMesh *poly_mesh) { return LLVector3(1.f, 1.f, 1.f); } | ||
482 | /*virtual*/ const LLVector3* getFirstDistortion(U32 *index, LLPolyMesh **poly_mesh) { index = 0; poly_mesh = NULL; return &mAvgDistortionVec;}; | ||
483 | /*virtual*/ const LLVector3* getNextDistortion(U32 *index, LLPolyMesh **poly_mesh) { index = 0; poly_mesh = NULL; return NULL;}; | ||
484 | |||
485 | // New functions | ||
486 | LLColor4 getNetColor(); | ||
487 | EColorOperation getOperation() const { return getInfo()->mOperation; } | ||
488 | |||
489 | |||
490 | protected: | ||
491 | LLVector3 mAvgDistortionVec; | ||
492 | LLTexGlobalColor* mTexGlobalColor; // either has mTexGlobalColor or mTexLayer as its parent | ||
493 | LLTexLayer* mTexLayer; | ||
494 | LLVOAvatar* mAvatar; // redundant, but simplifies the code | ||
495 | }; | ||
496 | |||
497 | //----------------------------------------------------------------------------- | ||
498 | // LLTexStaticImageList | ||
499 | //----------------------------------------------------------------------------- | ||
500 | |||
501 | class LLTexStaticImageList | ||
502 | { | ||
503 | public: | ||
504 | LLTexStaticImageList(); | ||
505 | ~LLTexStaticImageList(); | ||
506 | |||
507 | LLImageRaw* getImageRaw( const LLString& file_name ); | ||
508 | LLImageGL* getImageGL( const LLString& file_name, BOOL is_mask ); | ||
509 | LLImageTGA* getImageTGA( const LLString& file_name ); | ||
510 | |||
511 | void deleteCachedImages(); | ||
512 | void dumpByteCount(); | ||
513 | |||
514 | private: | ||
515 | BOOL loadImageRaw( const LLString& file_name, LLImageRaw* image_raw ); | ||
516 | |||
517 | private: | ||
518 | static LLStringTable sImageNames; | ||
519 | |||
520 | typedef std::map< const char *, LLPointer<LLImageRaw> > image_raw_map_t; | ||
521 | typedef std::map< const char *, LLPointer<LLImageGL> > image_gl_map_t; | ||
522 | typedef std::map< const char *, LLPointer<LLImageTGA> > image_tga_map_t; | ||
523 | image_raw_map_t mStaticImageListRaw; | ||
524 | image_gl_map_t mStaticImageListGL; | ||
525 | image_tga_map_t mStaticImageListTGA; | ||
526 | |||
527 | public: | ||
528 | S32 mRawBytes; | ||
529 | S32 mGLBytes; | ||
530 | S32 mTGABytes; | ||
531 | }; | ||
532 | |||
533 | |||
534 | //----------------------------------------------------------------------------- | ||
535 | // LLGradientPaletteList | ||
536 | // A static set of ramp grayscale palettes. The "effective_weight" is used | ||
537 | // to determine the x position of the ramp (offset) | ||
538 | // | ||
539 | // "Domain" isn't really the right word. It refers to the width of the | ||
540 | // ramp portion of the function that relates input and output pixel values. | ||
541 | // A domain of 0 gives a step function. | ||
542 | // | ||
543 | // | /---------------- | ||
544 | // O| / | | ||
545 | // u| / | | ||
546 | // t| / | | ||
547 | // p|------------------/ | | ||
548 | // u| | | | ||
549 | // t|<---------------->|<-->| | ||
550 | // | "offset" "domain" | ||
551 | // | | ||
552 | // --+---Input-------------------------------- | ||
553 | // | | ||
554 | //----------------------------------------------------------------------------- | ||
555 | class LLGradientPaletteList | ||
556 | { | ||
557 | public: | ||
558 | LLGradientPaletteList() {} | ||
559 | ~LLGradientPaletteList(); | ||
560 | |||
561 | void initPalette(F32 domain); | ||
562 | void setHardwarePalette(F32 domain, F32 effective_weight); | ||
563 | |||
564 | private: | ||
565 | typedef std::map<F32, U8*> palette_map_t; | ||
566 | palette_map_t mPaletteMap; | ||
567 | }; | ||
568 | |||
569 | // Used by LLTexLayerSetBuffer for a callback. | ||
570 | class LLBakedUploadData | ||
571 | { | ||
572 | public: | ||
573 | LLBakedUploadData( LLVOAvatar* avatar, LLTexLayerSetBuffer* layerset_buffer ); | ||
574 | ~LLBakedUploadData() {} | ||
575 | |||
576 | LLUUID mID; | ||
577 | LLVOAvatar* mAvatar; | ||
578 | LLTexLayerSetBuffer* mLayerSetBuffer; | ||
579 | LLUUID mWearableAssets[WT_COUNT]; | ||
580 | }; | ||
581 | |||
582 | extern LLTexStaticImageList gTexStaticImageList; | ||
583 | |||
584 | |||
585 | #endif // LL_LLTEXLAYER_H | ||