aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llprimitive/lltextureanim.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llprimitive/lltextureanim.cpp240
1 files changed, 240 insertions, 0 deletions
diff --git a/linden/indra/llprimitive/lltextureanim.cpp b/linden/indra/llprimitive/lltextureanim.cpp
new file mode 100644
index 0000000..b496463
--- /dev/null
+++ b/linden/indra/llprimitive/lltextureanim.cpp
@@ -0,0 +1,240 @@
1/**
2 * @file lltextureanim.cpp
3 * @brief LLTextureAnim base class
4 *
5 * Copyright (c) 2001-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#include "linden_common.h"
29
30#include "lltextureanim.h"
31#include "message.h"
32#include "lldatapacker.h"
33
34const S32 TA_BLOCK_SIZE = 16;
35
36LLTextureAnim::LLTextureAnim()
37{
38 reset();
39}
40
41
42LLTextureAnim::~LLTextureAnim()
43{
44}
45
46
47void LLTextureAnim::reset()
48{
49 mMode = 0;
50 mFace = -1;
51 mSizeX = 4;
52 mSizeY = 4;
53 mStart = 0.f;
54 mLength = 0.f;
55 mRate = 1.f;
56}
57
58BOOL LLTextureAnim::equals(const LLTextureAnim &other) const
59{
60 if (mMode != other.mMode)
61 {
62 return FALSE;
63 }
64 if (mFace != other.mFace)
65 {
66 return FALSE;
67 }
68 if (mSizeX != other.mSizeX)
69 {
70 return FALSE;
71 }
72 if (mSizeY != other.mSizeY)
73 {
74 return FALSE;
75 }
76 if (mStart != other.mStart)
77 {
78 return FALSE;
79 }
80 if (mLength != other.mLength)
81 {
82 return FALSE;
83 }
84 if (mRate != other.mRate)
85 {
86 return FALSE;
87 }
88
89 return TRUE;
90}
91void LLTextureAnim::packTAMessage(LLMessageSystem *mesgsys) const
92{
93 U8 data[TA_BLOCK_SIZE];
94 data[0] = mMode;
95 data[1] = mFace;
96 data[2] = mSizeX;
97 data[3] = mSizeY;
98 htonmemcpy(data + 4, &mStart, MVT_F32, sizeof(F32));
99 htonmemcpy(data + 8, &mLength, MVT_F32, sizeof(F32));
100 htonmemcpy(data + 12, &mRate, MVT_F32, sizeof(F32));
101
102 mesgsys->addBinaryDataFast(_PREHASH_TextureAnim, data, TA_BLOCK_SIZE);
103}
104
105
106void LLTextureAnim::packTAMessage(LLDataPacker &dp) const
107{
108 U8 data[TA_BLOCK_SIZE];
109 data[0] = mMode;
110 data[1] = mFace;
111 data[2] = mSizeX;
112 data[3] = mSizeY;
113 htonmemcpy(data + 4, &mStart, MVT_F32, sizeof(F32));
114 htonmemcpy(data + 8, &mLength, MVT_F32, sizeof(F32));
115 htonmemcpy(data + 12, &mRate, MVT_F32, sizeof(F32));
116
117 dp.packBinaryData(data, TA_BLOCK_SIZE, "TextureAnimation");
118}
119
120
121void LLTextureAnim::unpackTAMessage(LLMessageSystem *mesgsys, const S32 block_num)
122{
123 S32 size = mesgsys->getSizeFast(_PREHASH_ObjectData, block_num, _PREHASH_TextureAnim);
124
125 if (size != TA_BLOCK_SIZE)
126 {
127 if (size)
128 {
129 llwarns << "Bad size " << size << " for TA block, ignoring." << llendl;
130 }
131 mMode = 0;
132 return;
133 }
134
135 U8 data[TA_BLOCK_SIZE];
136 mesgsys->getBinaryDataFast(_PREHASH_ObjectData, _PREHASH_TextureAnim, data, TA_BLOCK_SIZE, block_num);
137
138 mMode = data[0];
139 mFace = data[1];
140 if (mMode & LLTextureAnim::SMOOTH)
141 {
142 mSizeX = llmax((U8)0, data[2]);
143 mSizeY = llmax((U8)0, data[3]);
144 }
145 else
146 {
147 mSizeX = llmax((U8)1, data[2]);
148 mSizeY = llmax((U8)1, data[3]);
149 }
150 htonmemcpy(&mStart, data + 4, MVT_F32, sizeof(F32));
151 htonmemcpy(&mLength, data + 8, MVT_F32, sizeof(F32));
152 htonmemcpy(&mRate, data + 12, MVT_F32, sizeof(F32));
153}
154
155void LLTextureAnim::unpackTAMessage(LLDataPacker &dp)
156{
157 S32 size;
158 U8 data[TA_BLOCK_SIZE];
159 dp.unpackBinaryData(data, size, "TextureAnimation");
160 if (size != TA_BLOCK_SIZE)
161 {
162 if (size)
163 {
164 llwarns << "Bad size " << size << " for TA block, ignoring." << llendl;
165 }
166 mMode = 0;
167 return;
168 }
169
170 mMode = data[0];
171 mFace = data[1];
172 mSizeX = llmax((U8)1, data[2]);
173 mSizeY = llmax((U8)1, data[3]);
174 htonmemcpy(&mStart, data + 4, MVT_F32, sizeof(F32));
175 htonmemcpy(&mLength, data + 8, MVT_F32, sizeof(F32));
176 htonmemcpy(&mRate, data + 12, MVT_F32, sizeof(F32));
177}
178
179LLSD LLTextureAnim::asLLSD() const
180{
181 LLSD sd;
182 sd["mode"] = mMode;
183 sd["face"] = mFace;
184 sd["sizeX"] = mSizeX;
185 sd["sizeY"] = mSizeY;
186 sd["start"] = mStart;
187 sd["length"] = mLength;
188 sd["rate"] = mRate;
189 return sd;
190}
191
192bool LLTextureAnim::fromLLSD(LLSD& sd)
193{
194 const char *w;
195 w = "mode";
196 if (sd.has(w))
197 {
198 mMode = (U8)sd[w].asInteger();
199 } else goto fail;
200
201 w = "face";
202 if (sd.has(w))
203 {
204 mFace = (S8)sd[w].asInteger();
205 } else goto fail;
206
207 w = "sizeX";
208 if (sd.has(w))
209 {
210 mSizeX = (U8)sd[w].asInteger();
211 } else goto fail;
212
213 w = "sizeY";
214 if (sd.has(w))
215 {
216 mSizeY = (U8)sd[w].asInteger();
217 } else goto fail;
218
219 w = "start";
220 if (sd.has(w))
221 {
222 mStart = (F32)sd[w].asReal();
223 } else goto fail;
224
225 w = "length";
226 if (sd.has(w))
227 {
228 mLength = (F32)sd[w].asReal();
229 } else goto fail;
230
231 w = "rate";
232 if (sd.has(w))
233 {
234 mRate = (F32)sd[w].asReal();
235 } else goto fail;
236
237 return true;
238fail:
239 return false;
240}