diff options
author | Jacek Antonelli | 2008-08-15 23:45:27 -0500 |
---|---|---|
committer | Jacek Antonelli | 2008-08-15 23:45:27 -0500 |
commit | a8a62201ba762e98dff92cf49033e577fc34d8d4 (patch) | |
tree | 11f8513c5cdc222f2fac0c93eb724c089803c200 /linden/indra/llcharacter | |
parent | Second Life viewer sources 1.18.6.4-RC (diff) | |
download | meta-impy-a8a62201ba762e98dff92cf49033e577fc34d8d4.zip meta-impy-a8a62201ba762e98dff92cf49033e577fc34d8d4.tar.gz meta-impy-a8a62201ba762e98dff92cf49033e577fc34d8d4.tar.bz2 meta-impy-a8a62201ba762e98dff92cf49033e577fc34d8d4.tar.xz |
Second Life viewer sources 1.19.0.0
Diffstat (limited to 'linden/indra/llcharacter')
44 files changed, 842 insertions, 352 deletions
diff --git a/linden/indra/llcharacter/llanimationstates.cpp b/linden/indra/llcharacter/llanimationstates.cpp index 05c0ca3..81e15c7 100644 --- a/linden/indra/llcharacter/llanimationstates.cpp +++ b/linden/indra/llcharacter/llanimationstates.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llanimationstates.h b/linden/indra/llcharacter/llanimationstates.h index e23f3b5..b2ed27a 100644 --- a/linden/indra/llcharacter/llanimationstates.h +++ b/linden/indra/llcharacter/llanimationstates.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llbvhloader.cpp b/linden/indra/llcharacter/llbvhloader.cpp index 26dc4e1..e6e49f8 100644 --- a/linden/indra/llcharacter/llbvhloader.cpp +++ b/linden/indra/llcharacter/llbvhloader.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llbvhloader.h b/linden/indra/llcharacter/llbvhloader.h index c9a49f7..3935ebe 100644 --- a/linden/indra/llcharacter/llbvhloader.h +++ b/linden/indra/llcharacter/llbvhloader.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llcharacter.cpp b/linden/indra/llcharacter/llcharacter.cpp index 5718a20..af4c5aa 100644 --- a/linden/indra/llcharacter/llcharacter.cpp +++ b/linden/indra/llcharacter/llcharacter.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llcharacter.h b/linden/indra/llcharacter/llcharacter.h index a0de93d..6699796 100644 --- a/linden/indra/llcharacter/llcharacter.h +++ b/linden/indra/llcharacter/llcharacter.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llcharacter_vc9.vcproj b/linden/indra/llcharacter/llcharacter_vc9.vcproj new file mode 100644 index 0000000..13e3b14 --- /dev/null +++ b/linden/indra/llcharacter/llcharacter_vc9.vcproj | |||
@@ -0,0 +1,420 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="9.00" | ||
5 | Name="llcharacter" | ||
6 | ProjectGUID="{5EA5DDF0-C7E1-4F49-BEF5-9246A4656B2E}" | ||
7 | RootNamespace="llcharacter" | ||
8 | Keyword="Win32Proj" | ||
9 | TargetFrameworkVersion="131072" | ||
10 | > | ||
11 | <Platforms> | ||
12 | <Platform | ||
13 | Name="Win32" | ||
14 | /> | ||
15 | </Platforms> | ||
16 | <ToolFiles> | ||
17 | </ToolFiles> | ||
18 | <Configurations> | ||
19 | <Configuration | ||
20 | Name="Debug|Win32" | ||
21 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
22 | IntermediateDirectory="Debug" | ||
23 | ConfigurationType="4" | ||
24 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
25 | CharacterSet="1" | ||
26 | > | ||
27 | <Tool | ||
28 | Name="VCPreBuildEventTool" | ||
29 | /> | ||
30 | <Tool | ||
31 | Name="VCCustomBuildTool" | ||
32 | /> | ||
33 | <Tool | ||
34 | Name="VCXMLDataGeneratorTool" | ||
35 | /> | ||
36 | <Tool | ||
37 | Name="VCWebServiceProxyGeneratorTool" | ||
38 | /> | ||
39 | <Tool | ||
40 | Name="VCMIDLTool" | ||
41 | /> | ||
42 | <Tool | ||
43 | Name="VCCLCompilerTool" | ||
44 | Optimization="0" | ||
45 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llvfs;..\llmessage;..\llxml;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
46 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" | ||
47 | MinimalRebuild="true" | ||
48 | BasicRuntimeChecks="3" | ||
49 | RuntimeLibrary="1" | ||
50 | StructMemberAlignment="4" | ||
51 | TreatWChar_tAsBuiltInType="false" | ||
52 | ForceConformanceInForLoopScope="true" | ||
53 | UsePrecompiledHeader="0" | ||
54 | WarningLevel="3" | ||
55 | WarnAsError="true" | ||
56 | Detect64BitPortabilityProblems="false" | ||
57 | DebugInformationFormat="4" | ||
58 | /> | ||
59 | <Tool | ||
60 | Name="VCManagedResourceCompilerTool" | ||
61 | /> | ||
62 | <Tool | ||
63 | Name="VCResourceCompilerTool" | ||
64 | /> | ||
65 | <Tool | ||
66 | Name="VCPreLinkEventTool" | ||
67 | /> | ||
68 | <Tool | ||
69 | Name="VCLibrarianTool" | ||
70 | OutputFile="$(OutDir)/llcharacter.lib" | ||
71 | /> | ||
72 | <Tool | ||
73 | Name="VCALinkTool" | ||
74 | /> | ||
75 | <Tool | ||
76 | Name="VCXDCMakeTool" | ||
77 | /> | ||
78 | <Tool | ||
79 | Name="VCBscMakeTool" | ||
80 | /> | ||
81 | <Tool | ||
82 | Name="VCFxCopTool" | ||
83 | /> | ||
84 | <Tool | ||
85 | Name="VCPostBuildEventTool" | ||
86 | /> | ||
87 | </Configuration> | ||
88 | <Configuration | ||
89 | Name="Release|Win32" | ||
90 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
91 | IntermediateDirectory="Release" | ||
92 | ConfigurationType="4" | ||
93 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
94 | CharacterSet="1" | ||
95 | > | ||
96 | <Tool | ||
97 | Name="VCPreBuildEventTool" | ||
98 | /> | ||
99 | <Tool | ||
100 | Name="VCCustomBuildTool" | ||
101 | /> | ||
102 | <Tool | ||
103 | Name="VCXMLDataGeneratorTool" | ||
104 | /> | ||
105 | <Tool | ||
106 | Name="VCWebServiceProxyGeneratorTool" | ||
107 | /> | ||
108 | <Tool | ||
109 | Name="VCMIDLTool" | ||
110 | /> | ||
111 | <Tool | ||
112 | Name="VCCLCompilerTool" | ||
113 | AdditionalOptions="/Oy-" | ||
114 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llvfs;..\llmessage;..\llxml;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
115 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
116 | RuntimeLibrary="0" | ||
117 | StructMemberAlignment="0" | ||
118 | TreatWChar_tAsBuiltInType="false" | ||
119 | ForceConformanceInForLoopScope="true" | ||
120 | UsePrecompiledHeader="0" | ||
121 | WarningLevel="3" | ||
122 | WarnAsError="true" | ||
123 | Detect64BitPortabilityProblems="false" | ||
124 | DebugInformationFormat="3" | ||
125 | /> | ||
126 | <Tool | ||
127 | Name="VCManagedResourceCompilerTool" | ||
128 | /> | ||
129 | <Tool | ||
130 | Name="VCResourceCompilerTool" | ||
131 | /> | ||
132 | <Tool | ||
133 | Name="VCPreLinkEventTool" | ||
134 | /> | ||
135 | <Tool | ||
136 | Name="VCLibrarianTool" | ||
137 | OutputFile="$(OutDir)/llcharacter.lib" | ||
138 | /> | ||
139 | <Tool | ||
140 | Name="VCALinkTool" | ||
141 | /> | ||
142 | <Tool | ||
143 | Name="VCXDCMakeTool" | ||
144 | /> | ||
145 | <Tool | ||
146 | Name="VCBscMakeTool" | ||
147 | /> | ||
148 | <Tool | ||
149 | Name="VCFxCopTool" | ||
150 | /> | ||
151 | <Tool | ||
152 | Name="VCPostBuildEventTool" | ||
153 | /> | ||
154 | </Configuration> | ||
155 | <Configuration | ||
156 | Name="ReleaseNoOpt|Win32" | ||
157 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
158 | IntermediateDirectory="$(ConfigurationName)" | ||
159 | ConfigurationType="4" | ||
160 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
161 | CharacterSet="1" | ||
162 | > | ||
163 | <Tool | ||
164 | Name="VCPreBuildEventTool" | ||
165 | /> | ||
166 | <Tool | ||
167 | Name="VCCustomBuildTool" | ||
168 | /> | ||
169 | <Tool | ||
170 | Name="VCXMLDataGeneratorTool" | ||
171 | /> | ||
172 | <Tool | ||
173 | Name="VCWebServiceProxyGeneratorTool" | ||
174 | /> | ||
175 | <Tool | ||
176 | Name="VCMIDLTool" | ||
177 | /> | ||
178 | <Tool | ||
179 | Name="VCCLCompilerTool" | ||
180 | AdditionalOptions="/Oy-" | ||
181 | Optimization="0" | ||
182 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\llvfs;..\llmessage;..\llxml;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
183 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
184 | RuntimeLibrary="0" | ||
185 | StructMemberAlignment="0" | ||
186 | TreatWChar_tAsBuiltInType="false" | ||
187 | ForceConformanceInForLoopScope="true" | ||
188 | UsePrecompiledHeader="0" | ||
189 | WarningLevel="3" | ||
190 | WarnAsError="true" | ||
191 | Detect64BitPortabilityProblems="false" | ||
192 | DebugInformationFormat="3" | ||
193 | /> | ||
194 | <Tool | ||
195 | Name="VCManagedResourceCompilerTool" | ||
196 | /> | ||
197 | <Tool | ||
198 | Name="VCResourceCompilerTool" | ||
199 | /> | ||
200 | <Tool | ||
201 | Name="VCPreLinkEventTool" | ||
202 | /> | ||
203 | <Tool | ||
204 | Name="VCLibrarianTool" | ||
205 | OutputFile="$(OutDir)/llcharacter.lib" | ||
206 | /> | ||
207 | <Tool | ||
208 | Name="VCALinkTool" | ||
209 | /> | ||
210 | <Tool | ||
211 | Name="VCXDCMakeTool" | ||
212 | /> | ||
213 | <Tool | ||
214 | Name="VCBscMakeTool" | ||
215 | /> | ||
216 | <Tool | ||
217 | Name="VCFxCopTool" | ||
218 | /> | ||
219 | <Tool | ||
220 | Name="VCPostBuildEventTool" | ||
221 | /> | ||
222 | </Configuration> | ||
223 | </Configurations> | ||
224 | <References> | ||
225 | </References> | ||
226 | <Files> | ||
227 | <Filter | ||
228 | Name="Source Files" | ||
229 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
230 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}" | ||
231 | > | ||
232 | <File | ||
233 | RelativePath=".\llanimationstates.cpp" | ||
234 | > | ||
235 | </File> | ||
236 | <File | ||
237 | RelativePath=".\llbvhloader.cpp" | ||
238 | > | ||
239 | </File> | ||
240 | <File | ||
241 | RelativePath=".\llcharacter.cpp" | ||
242 | > | ||
243 | </File> | ||
244 | <File | ||
245 | RelativePath=".\lleditingmotion.cpp" | ||
246 | > | ||
247 | </File> | ||
248 | <File | ||
249 | RelativePath=".\llgesture.cpp" | ||
250 | > | ||
251 | </File> | ||
252 | <File | ||
253 | RelativePath=".\llhandmotion.cpp" | ||
254 | > | ||
255 | </File> | ||
256 | <File | ||
257 | RelativePath=".\llheadrotmotion.cpp" | ||
258 | > | ||
259 | </File> | ||
260 | <File | ||
261 | RelativePath=".\lljoint.cpp" | ||
262 | > | ||
263 | </File> | ||
264 | <File | ||
265 | RelativePath=".\lljointsolverrp3.cpp" | ||
266 | > | ||
267 | </File> | ||
268 | <File | ||
269 | RelativePath=".\llkeyframefallmotion.cpp" | ||
270 | > | ||
271 | </File> | ||
272 | <File | ||
273 | RelativePath=".\llkeyframemotion.cpp" | ||
274 | > | ||
275 | </File> | ||
276 | <File | ||
277 | RelativePath=".\llkeyframemotionparam.cpp" | ||
278 | > | ||
279 | </File> | ||
280 | <File | ||
281 | RelativePath=".\llkeyframestandmotion.cpp" | ||
282 | > | ||
283 | </File> | ||
284 | <File | ||
285 | RelativePath=".\llkeyframewalkmotion.cpp" | ||
286 | > | ||
287 | </File> | ||
288 | <File | ||
289 | RelativePath=".\llmotion.cpp" | ||
290 | > | ||
291 | </File> | ||
292 | <File | ||
293 | RelativePath=".\llmotioncontroller.cpp" | ||
294 | > | ||
295 | </File> | ||
296 | <File | ||
297 | RelativePath=".\llmultigesture.cpp" | ||
298 | > | ||
299 | </File> | ||
300 | <File | ||
301 | RelativePath=".\llpose.cpp" | ||
302 | > | ||
303 | </File> | ||
304 | <File | ||
305 | RelativePath=".\llstatemachine.cpp" | ||
306 | > | ||
307 | </File> | ||
308 | <File | ||
309 | RelativePath=".\lltargetingmotion.cpp" | ||
310 | > | ||
311 | </File> | ||
312 | <File | ||
313 | RelativePath=".\llvisualparam.cpp" | ||
314 | > | ||
315 | </File> | ||
316 | </Filter> | ||
317 | <Filter | ||
318 | Name="Header Files" | ||
319 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
320 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}" | ||
321 | > | ||
322 | <File | ||
323 | RelativePath=".\llanimationstates.h" | ||
324 | > | ||
325 | </File> | ||
326 | <File | ||
327 | RelativePath=".\llbvhloader.h" | ||
328 | > | ||
329 | </File> | ||
330 | <File | ||
331 | RelativePath=".\llcharacter.h" | ||
332 | > | ||
333 | </File> | ||
334 | <File | ||
335 | RelativePath=".\lleditingmotion.h" | ||
336 | > | ||
337 | </File> | ||
338 | <File | ||
339 | RelativePath=".\llgesture.h" | ||
340 | > | ||
341 | </File> | ||
342 | <File | ||
343 | RelativePath=".\llhandmotion.h" | ||
344 | > | ||
345 | </File> | ||
346 | <File | ||
347 | RelativePath=".\llheadrotmotion.h" | ||
348 | > | ||
349 | </File> | ||
350 | <File | ||
351 | RelativePath=".\lljoint.h" | ||
352 | > | ||
353 | </File> | ||
354 | <File | ||
355 | RelativePath=".\lljointsolverrp3.h" | ||
356 | > | ||
357 | </File> | ||
358 | <File | ||
359 | RelativePath=".\lljointstate.h" | ||
360 | > | ||
361 | </File> | ||
362 | <File | ||
363 | RelativePath=".\llkeyframefallmotion.h" | ||
364 | > | ||
365 | </File> | ||
366 | <File | ||
367 | RelativePath=".\llkeyframemotion.h" | ||
368 | > | ||
369 | </File> | ||
370 | <File | ||
371 | RelativePath=".\llkeyframemotionparam.h" | ||
372 | > | ||
373 | </File> | ||
374 | <File | ||
375 | RelativePath=".\llkeyframestandmotion.h" | ||
376 | > | ||
377 | </File> | ||
378 | <File | ||
379 | RelativePath=".\llkeyframewalkmotion.h" | ||
380 | > | ||
381 | </File> | ||
382 | <File | ||
383 | RelativePath=".\llmotion.h" | ||
384 | > | ||
385 | </File> | ||
386 | <File | ||
387 | RelativePath=".\llmotioncontroller.h" | ||
388 | > | ||
389 | </File> | ||
390 | <File | ||
391 | RelativePath=".\llmultigesture.h" | ||
392 | > | ||
393 | </File> | ||
394 | <File | ||
395 | RelativePath=".\llpose.h" | ||
396 | > | ||
397 | </File> | ||
398 | <File | ||
399 | RelativePath=".\llstatemachine.h" | ||
400 | > | ||
401 | </File> | ||
402 | <File | ||
403 | RelativePath=".\lltargetingmotion.h" | ||
404 | > | ||
405 | </File> | ||
406 | <File | ||
407 | RelativePath=".\llvisualparam.h" | ||
408 | > | ||
409 | </File> | ||
410 | </Filter> | ||
411 | <Filter | ||
412 | Name="Resource Files" | ||
413 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
414 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||
415 | > | ||
416 | </Filter> | ||
417 | </Files> | ||
418 | <Globals> | ||
419 | </Globals> | ||
420 | </VisualStudioProject> | ||
diff --git a/linden/indra/llcharacter/lleditingmotion.cpp b/linden/indra/llcharacter/lleditingmotion.cpp index c2519c2..c693e6d 100644 --- a/linden/indra/llcharacter/lleditingmotion.cpp +++ b/linden/indra/llcharacter/lleditingmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -64,6 +64,12 @@ LLEditingMotion::LLEditingMotion( const LLUUID &id) : LLMotion(id) | |||
64 | mElbowJoint.addChild( &mWristJoint ); | 64 | mElbowJoint.addChild( &mWristJoint ); |
65 | 65 | ||
66 | mName = "editing"; | 66 | mName = "editing"; |
67 | |||
68 | mParentState = new LLJointState; | ||
69 | mShoulderState = new LLJointState; | ||
70 | mElbowState = new LLJointState; | ||
71 | mWristState = new LLJointState; | ||
72 | mTorsoState = new LLJointState; | ||
67 | } | 73 | } |
68 | 74 | ||
69 | 75 | ||
@@ -93,13 +99,13 @@ LLMotion::LLMotionInitStatus LLEditingMotion::onInitialize(LLCharacter *characte | |||
93 | } | 99 | } |
94 | 100 | ||
95 | // get the shoulder, elbow, wrist joints from the character | 101 | // get the shoulder, elbow, wrist joints from the character |
96 | mParentState.setJoint( mCharacter->getJoint("mShoulderLeft")->getParent() ); | 102 | mParentState->setJoint( mCharacter->getJoint("mShoulderLeft")->getParent() ); |
97 | mShoulderState.setJoint( mCharacter->getJoint("mShoulderLeft") ); | 103 | mShoulderState->setJoint( mCharacter->getJoint("mShoulderLeft") ); |
98 | mElbowState.setJoint( mCharacter->getJoint("mElbowLeft") ); | 104 | mElbowState->setJoint( mCharacter->getJoint("mElbowLeft") ); |
99 | mWristState.setJoint( mCharacter->getJoint("mWristLeft") ); | 105 | mWristState->setJoint( mCharacter->getJoint("mWristLeft") ); |
100 | mTorsoState.setJoint( mCharacter->getJoint("mTorso")); | 106 | mTorsoState->setJoint( mCharacter->getJoint("mTorso")); |
101 | 107 | ||
102 | if ( ! mParentState.getJoint() ) | 108 | if ( ! mParentState->getJoint() ) |
103 | { | 109 | { |
104 | llinfos << getName() << ": Can't get parent joint." << llendl; | 110 | llinfos << getName() << ": Can't get parent joint." << llendl; |
105 | return STATUS_FAILURE; | 111 | return STATUS_FAILURE; |
@@ -108,25 +114,25 @@ LLMotion::LLMotionInitStatus LLEditingMotion::onInitialize(LLCharacter *characte | |||
108 | mWristOffset = LLVector3(0.0f, 0.2f, 0.0f); | 114 | mWristOffset = LLVector3(0.0f, 0.2f, 0.0f); |
109 | 115 | ||
110 | // add joint states to the pose | 116 | // add joint states to the pose |
111 | mShoulderState.setUsage(LLJointState::ROT); | 117 | mShoulderState->setUsage(LLJointState::ROT); |
112 | mElbowState.setUsage(LLJointState::ROT); | 118 | mElbowState->setUsage(LLJointState::ROT); |
113 | mTorsoState.setUsage(LLJointState::ROT); | 119 | mTorsoState->setUsage(LLJointState::ROT); |
114 | mWristState.setUsage(LLJointState::ROT); | 120 | mWristState->setUsage(LLJointState::ROT); |
115 | addJointState( &mShoulderState ); | 121 | addJointState( mShoulderState ); |
116 | addJointState( &mElbowState ); | 122 | addJointState( mElbowState ); |
117 | addJointState( &mTorsoState ); | 123 | addJointState( mTorsoState ); |
118 | addJointState( &mWristState ); | 124 | addJointState( mWristState ); |
119 | 125 | ||
120 | // propagate joint positions to kinematic chain | 126 | // propagate joint positions to kinematic chain |
121 | mParentJoint.setPosition( mParentState.getJoint()->getWorldPosition() ); | 127 | mParentJoint.setPosition( mParentState->getJoint()->getWorldPosition() ); |
122 | mShoulderJoint.setPosition( mShoulderState.getJoint()->getPosition() ); | 128 | mShoulderJoint.setPosition( mShoulderState->getJoint()->getPosition() ); |
123 | mElbowJoint.setPosition( mElbowState.getJoint()->getPosition() ); | 129 | mElbowJoint.setPosition( mElbowState->getJoint()->getPosition() ); |
124 | mWristJoint.setPosition( mWristState.getJoint()->getPosition() + mWristOffset ); | 130 | mWristJoint.setPosition( mWristState->getJoint()->getPosition() + mWristOffset ); |
125 | 131 | ||
126 | // propagate current joint rotations to kinematic chain | 132 | // propagate current joint rotations to kinematic chain |
127 | mParentJoint.setRotation( mParentState.getJoint()->getWorldRotation() ); | 133 | mParentJoint.setRotation( mParentState->getJoint()->getWorldRotation() ); |
128 | mShoulderJoint.setRotation( mShoulderState.getJoint()->getRotation() ); | 134 | mShoulderJoint.setRotation( mShoulderState->getJoint()->getRotation() ); |
129 | mElbowJoint.setRotation( mElbowState.getJoint()->getRotation() ); | 135 | mElbowJoint.setRotation( mElbowState->getJoint()->getRotation() ); |
130 | 136 | ||
131 | // connect the ikSolver to the chain | 137 | // connect the ikSolver to the chain |
132 | mIKSolver.setPoleVector( LLVector3( -1.0f, 1.0f, 0.0f ) ); | 138 | mIKSolver.setPoleVector( LLVector3( -1.0f, 1.0f, 0.0f ) ); |
@@ -144,15 +150,15 @@ LLMotion::LLMotionInitStatus LLEditingMotion::onInitialize(LLCharacter *characte | |||
144 | BOOL LLEditingMotion::onActivate() | 150 | BOOL LLEditingMotion::onActivate() |
145 | { | 151 | { |
146 | // propagate joint positions to kinematic chain | 152 | // propagate joint positions to kinematic chain |
147 | mParentJoint.setPosition( mParentState.getJoint()->getWorldPosition() ); | 153 | mParentJoint.setPosition( mParentState->getJoint()->getWorldPosition() ); |
148 | mShoulderJoint.setPosition( mShoulderState.getJoint()->getPosition() ); | 154 | mShoulderJoint.setPosition( mShoulderState->getJoint()->getPosition() ); |
149 | mElbowJoint.setPosition( mElbowState.getJoint()->getPosition() ); | 155 | mElbowJoint.setPosition( mElbowState->getJoint()->getPosition() ); |
150 | mWristJoint.setPosition( mWristState.getJoint()->getPosition() + mWristOffset ); | 156 | mWristJoint.setPosition( mWristState->getJoint()->getPosition() + mWristOffset ); |
151 | 157 | ||
152 | // propagate current joint rotations to kinematic chain | 158 | // propagate current joint rotations to kinematic chain |
153 | mParentJoint.setRotation( mParentState.getJoint()->getWorldRotation() ); | 159 | mParentJoint.setRotation( mParentState->getJoint()->getWorldRotation() ); |
154 | mShoulderJoint.setRotation( mShoulderState.getJoint()->getRotation() ); | 160 | mShoulderJoint.setRotation( mShoulderState->getJoint()->getRotation() ); |
155 | mElbowJoint.setRotation( mElbowState.getJoint()->getRotation() ); | 161 | mElbowJoint.setRotation( mElbowState->getJoint()->getRotation() ); |
156 | 162 | ||
157 | return TRUE; | 163 | return TRUE; |
158 | } | 164 | } |
@@ -182,15 +188,15 @@ BOOL LLEditingMotion::onUpdate(F32 time, U8* joint_mask) | |||
182 | focus_pt += mCharacter->getCharacterPosition(); | 188 | focus_pt += mCharacter->getCharacterPosition(); |
183 | 189 | ||
184 | // propagate joint positions to kinematic chain | 190 | // propagate joint positions to kinematic chain |
185 | mParentJoint.setPosition( mParentState.getJoint()->getWorldPosition() ); | 191 | mParentJoint.setPosition( mParentState->getJoint()->getWorldPosition() ); |
186 | mShoulderJoint.setPosition( mShoulderState.getJoint()->getPosition() ); | 192 | mShoulderJoint.setPosition( mShoulderState->getJoint()->getPosition() ); |
187 | mElbowJoint.setPosition( mElbowState.getJoint()->getPosition() ); | 193 | mElbowJoint.setPosition( mElbowState->getJoint()->getPosition() ); |
188 | mWristJoint.setPosition( mWristState.getJoint()->getPosition() + mWristOffset ); | 194 | mWristJoint.setPosition( mWristState->getJoint()->getPosition() + mWristOffset ); |
189 | 195 | ||
190 | // propagate current joint rotations to kinematic chain | 196 | // propagate current joint rotations to kinematic chain |
191 | mParentJoint.setRotation( mParentState.getJoint()->getWorldRotation() ); | 197 | mParentJoint.setRotation( mParentState->getJoint()->getWorldRotation() ); |
192 | mShoulderJoint.setRotation( mShoulderState.getJoint()->getRotation() ); | 198 | mShoulderJoint.setRotation( mShoulderState->getJoint()->getRotation() ); |
193 | mElbowJoint.setRotation( mElbowState.getJoint()->getRotation() ); | 199 | mElbowJoint.setRotation( mElbowState->getJoint()->getRotation() ); |
194 | 200 | ||
195 | // update target position from character | 201 | // update target position from character |
196 | LLVector3 target = focus_pt - mParentJoint.getPosition(); | 202 | LLVector3 target = focus_pt - mParentJoint.getPosition(); |
@@ -199,7 +205,7 @@ BOOL LLEditingMotion::onUpdate(F32 time, U8* joint_mask) | |||
199 | LLVector3 edit_plane_normal(1.f / F_SQRT2, 1.f / F_SQRT2, 0.f); | 205 | LLVector3 edit_plane_normal(1.f / F_SQRT2, 1.f / F_SQRT2, 0.f); |
200 | edit_plane_normal.normVec(); | 206 | edit_plane_normal.normVec(); |
201 | 207 | ||
202 | edit_plane_normal.rotVec(mTorsoState.getJoint()->getWorldRotation()); | 208 | edit_plane_normal.rotVec(mTorsoState->getJoint()->getWorldRotation()); |
203 | 209 | ||
204 | F32 dot = edit_plane_normal * target; | 210 | F32 dot = edit_plane_normal * target; |
205 | 211 | ||
@@ -236,9 +242,9 @@ BOOL LLEditingMotion::onUpdate(F32 time, U8* joint_mask) | |||
236 | // now put blended values back into joints | 242 | // now put blended values back into joints |
237 | llassert(shoulderRot.isFinite()); | 243 | llassert(shoulderRot.isFinite()); |
238 | llassert(elbowRot.isFinite()); | 244 | llassert(elbowRot.isFinite()); |
239 | mShoulderState.setRotation(shoulderRot); | 245 | mShoulderState->setRotation(shoulderRot); |
240 | mElbowState.setRotation(elbowRot); | 246 | mElbowState->setRotation(elbowRot); |
241 | mWristState.setRotation(LLQuaternion::DEFAULT); | 247 | mWristState->setRotation(LLQuaternion::DEFAULT); |
242 | } | 248 | } |
243 | 249 | ||
244 | mCharacter->setAnimationData("Hand Pose", &sHandPose); | 250 | mCharacter->setAnimationData("Hand Pose", &sHandPose); |
diff --git a/linden/indra/llcharacter/lleditingmotion.h b/linden/indra/llcharacter/lleditingmotion.h index 06828fa..3d46343 100644 --- a/linden/indra/llcharacter/lleditingmotion.h +++ b/linden/indra/llcharacter/lleditingmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -116,11 +116,11 @@ public: | |||
116 | LLCharacter *mCharacter; | 116 | LLCharacter *mCharacter; |
117 | LLVector3 mWristOffset; | 117 | LLVector3 mWristOffset; |
118 | 118 | ||
119 | LLJointState mParentState; | 119 | LLPointer<LLJointState> mParentState; |
120 | LLJointState mShoulderState; | 120 | LLPointer<LLJointState> mShoulderState; |
121 | LLJointState mElbowState; | 121 | LLPointer<LLJointState> mElbowState; |
122 | LLJointState mWristState; | 122 | LLPointer<LLJointState> mWristState; |
123 | LLJointState mTorsoState; | 123 | LLPointer<LLJointState> mTorsoState; |
124 | 124 | ||
125 | LLJoint mParentJoint; | 125 | LLJoint mParentJoint; |
126 | LLJoint mShoulderJoint; | 126 | LLJoint mShoulderJoint; |
diff --git a/linden/indra/llcharacter/llgesture.cpp b/linden/indra/llcharacter/llgesture.cpp index b3d3127..c124ad0 100644 --- a/linden/indra/llcharacter/llgesture.cpp +++ b/linden/indra/llcharacter/llgesture.cpp | |||
@@ -11,12 +11,12 @@ | |||
11 | * ("GPL"), unless you have obtained a separate licensing agreement | 11 | * ("GPL"), unless you have obtained a separate licensing agreement |
12 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 12 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
13 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 13 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
14 | * online at http://secondlife.com/developers/opensource/gplv2 | 14 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
15 | * | 15 | * |
16 | * There are special exceptions to the terms and conditions of the GPL as | 16 | * There are special exceptions to the terms and conditions of the GPL as |
17 | * it is applied to this Source Code. View the full text of the exception | 17 | * it is applied to this Source Code. View the full text of the exception |
18 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 18 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
19 | * online at http://secondlife.com/developers/opensource/flossexception | 19 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
20 | * | 20 | * |
21 | * By copying, modifying or distributing this software, you acknowledge | 21 | * By copying, modifying or distributing this software, you acknowledge |
22 | * that you have read and understood your obligations described above, | 22 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llgesture.h b/linden/indra/llcharacter/llgesture.h index f245a1c..0e4b781 100644 --- a/linden/indra/llcharacter/llgesture.h +++ b/linden/indra/llcharacter/llgesture.h | |||
@@ -13,12 +13,12 @@ | |||
13 | * ("GPL"), unless you have obtained a separate licensing agreement | 13 | * ("GPL"), unless you have obtained a separate licensing agreement |
14 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 14 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
15 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 15 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
16 | * online at http://secondlife.com/developers/opensource/gplv2 | 16 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
17 | * | 17 | * |
18 | * There are special exceptions to the terms and conditions of the GPL as | 18 | * There are special exceptions to the terms and conditions of the GPL as |
19 | * it is applied to this Source Code. View the full text of the exception | 19 | * it is applied to this Source Code. View the full text of the exception |
20 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 20 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
21 | * online at http://secondlife.com/developers/opensource/flossexception | 21 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
22 | * | 22 | * |
23 | * By copying, modifying or distributing this software, you acknowledge | 23 | * By copying, modifying or distributing this software, you acknowledge |
24 | * that you have read and understood your obligations described above, | 24 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llhandmotion.cpp b/linden/indra/llcharacter/llhandmotion.cpp index bdaf0f3..3902518 100644 --- a/linden/indra/llcharacter/llhandmotion.cpp +++ b/linden/indra/llcharacter/llhandmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llhandmotion.h b/linden/indra/llcharacter/llhandmotion.h index 3729659..548e4de 100644 --- a/linden/indra/llcharacter/llhandmotion.h +++ b/linden/indra/llcharacter/llhandmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -124,6 +124,8 @@ public: | |||
124 | // called when a motion is deactivated | 124 | // called when a motion is deactivated |
125 | virtual void onDeactivate(); | 125 | virtual void onDeactivate(); |
126 | 126 | ||
127 | virtual BOOL canDeprecate() { return FALSE; } | ||
128 | |||
127 | static LLString getHandPoseName(eHandPose pose); | 129 | static LLString getHandPoseName(eHandPose pose); |
128 | static eHandPose getHandPose(LLString posename); | 130 | static eHandPose getHandPose(LLString posename); |
129 | 131 | ||
diff --git a/linden/indra/llcharacter/llheadrotmotion.cpp b/linden/indra/llcharacter/llheadrotmotion.cpp index e8afb82..f01dfcc 100644 --- a/linden/indra/llcharacter/llheadrotmotion.cpp +++ b/linden/indra/llcharacter/llheadrotmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -82,6 +82,10 @@ LLHeadRotMotion::LLHeadRotMotion(const LLUUID &id) : | |||
82 | mHeadJoint(NULL) | 82 | mHeadJoint(NULL) |
83 | { | 83 | { |
84 | mName = "head_rot"; | 84 | mName = "head_rot"; |
85 | |||
86 | mTorsoState = new LLJointState; | ||
87 | mNeckState = new LLJointState; | ||
88 | mHeadState = new LLJointState; | ||
85 | } | 89 | } |
86 | 90 | ||
87 | 91 | ||
@@ -130,34 +134,34 @@ LLMotion::LLMotionInitStatus LLHeadRotMotion::onInitialize(LLCharacter *characte | |||
130 | return STATUS_FAILURE; | 134 | return STATUS_FAILURE; |
131 | } | 135 | } |
132 | 136 | ||
133 | mTorsoState.setJoint( character->getJoint("mTorso") ); | 137 | mTorsoState->setJoint( character->getJoint("mTorso") ); |
134 | if ( ! mTorsoState.getJoint() ) | 138 | if ( ! mTorsoState->getJoint() ) |
135 | { | 139 | { |
136 | llinfos << getName() << ": Can't get torso joint." << llendl; | 140 | llinfos << getName() << ": Can't get torso joint." << llendl; |
137 | return STATUS_FAILURE; | 141 | return STATUS_FAILURE; |
138 | } | 142 | } |
139 | 143 | ||
140 | mNeckState.setJoint( character->getJoint("mNeck") ); | 144 | mNeckState->setJoint( character->getJoint("mNeck") ); |
141 | if ( ! mNeckState.getJoint() ) | 145 | if ( ! mNeckState->getJoint() ) |
142 | { | 146 | { |
143 | llinfos << getName() << ": Can't get neck joint." << llendl; | 147 | llinfos << getName() << ": Can't get neck joint." << llendl; |
144 | return STATUS_FAILURE; | 148 | return STATUS_FAILURE; |
145 | } | 149 | } |
146 | 150 | ||
147 | mHeadState.setJoint( character->getJoint("mHead") ); | 151 | mHeadState->setJoint( character->getJoint("mHead") ); |
148 | if ( ! mHeadState.getJoint() ) | 152 | if ( ! mHeadState->getJoint() ) |
149 | { | 153 | { |
150 | llinfos << getName() << ": Can't get head joint." << llendl; | 154 | llinfos << getName() << ": Can't get head joint." << llendl; |
151 | return STATUS_FAILURE; | 155 | return STATUS_FAILURE; |
152 | } | 156 | } |
153 | 157 | ||
154 | mTorsoState.setUsage(LLJointState::ROT); | 158 | mTorsoState->setUsage(LLJointState::ROT); |
155 | mNeckState.setUsage(LLJointState::ROT); | 159 | mNeckState->setUsage(LLJointState::ROT); |
156 | mHeadState.setUsage(LLJointState::ROT); | 160 | mHeadState->setUsage(LLJointState::ROT); |
157 | 161 | ||
158 | addJointState( &mTorsoState ); | 162 | addJointState( mTorsoState ); |
159 | addJointState( &mNeckState ); | 163 | addJointState( mNeckState ); |
160 | addJointState( &mHeadState ); | 164 | addJointState( mHeadState ); |
161 | 165 | ||
162 | mLastHeadRot.loadIdentity(); | 166 | mLastHeadRot.loadIdentity(); |
163 | 167 | ||
@@ -240,16 +244,16 @@ BOOL LLHeadRotMotion::onUpdate(F32 time, U8* joint_mask) | |||
240 | // Set torso target rotation such that it lags behind the head rotation | 244 | // Set torso target rotation such that it lags behind the head rotation |
241 | // by a fixed amount. | 245 | // by a fixed amount. |
242 | LLQuaternion torso_rot_local = nlerp(TORSO_LAG, LLQuaternion::DEFAULT, head_rot_local ); | 246 | LLQuaternion torso_rot_local = nlerp(TORSO_LAG, LLQuaternion::DEFAULT, head_rot_local ); |
243 | mTorsoState.setRotation( nlerp(torso_slerp_amt, mTorsoState.getRotation(), torso_rot_local) ); | 247 | mTorsoState->setRotation( nlerp(torso_slerp_amt, mTorsoState->getRotation(), torso_rot_local) ); |
244 | 248 | ||
245 | head_rot_local = nlerp(head_slerp_amt, mLastHeadRot, head_rot_local); | 249 | head_rot_local = nlerp(head_slerp_amt, mLastHeadRot, head_rot_local); |
246 | mLastHeadRot = head_rot_local; | 250 | mLastHeadRot = head_rot_local; |
247 | 251 | ||
248 | // Set the head rotation. | 252 | // Set the head rotation. |
249 | LLQuaternion torsoRotLocal = mNeckState.getJoint()->getParent()->getWorldRotation() * currentInvRootRotWorld; | 253 | LLQuaternion torsoRotLocal = mNeckState->getJoint()->getParent()->getWorldRotation() * currentInvRootRotWorld; |
250 | head_rot_local = head_rot_local * ~torsoRotLocal; | 254 | head_rot_local = head_rot_local * ~torsoRotLocal; |
251 | mNeckState.setRotation( nlerp(NECK_LAG, LLQuaternion::DEFAULT, head_rot_local) ); | 255 | mNeckState->setRotation( nlerp(NECK_LAG, LLQuaternion::DEFAULT, head_rot_local) ); |
252 | mHeadState.setRotation( nlerp(1.f - NECK_LAG, LLQuaternion::DEFAULT, head_rot_local)); | 256 | mHeadState->setRotation( nlerp(1.f - NECK_LAG, LLQuaternion::DEFAULT, head_rot_local)); |
253 | 257 | ||
254 | return TRUE; | 258 | return TRUE; |
255 | } | 259 | } |
@@ -284,6 +288,9 @@ LLEyeMotion::LLEyeMotion(const LLUUID &id) : LLMotion(id) | |||
284 | mHeadJoint = NULL; | 288 | mHeadJoint = NULL; |
285 | 289 | ||
286 | mName = "eye_rot"; | 290 | mName = "eye_rot"; |
291 | |||
292 | mLeftEyeState = new LLJointState; | ||
293 | mRightEyeState = new LLJointState; | ||
287 | } | 294 | } |
288 | 295 | ||
289 | 296 | ||
@@ -309,25 +316,25 @@ LLMotion::LLMotionInitStatus LLEyeMotion::onInitialize(LLCharacter *character) | |||
309 | return STATUS_FAILURE; | 316 | return STATUS_FAILURE; |
310 | } | 317 | } |
311 | 318 | ||
312 | mLeftEyeState.setJoint( character->getJoint("mEyeLeft") ); | 319 | mLeftEyeState->setJoint( character->getJoint("mEyeLeft") ); |
313 | if ( ! mLeftEyeState.getJoint() ) | 320 | if ( ! mLeftEyeState->getJoint() ) |
314 | { | 321 | { |
315 | llinfos << getName() << ": Can't get left eyeball joint." << llendl; | 322 | llinfos << getName() << ": Can't get left eyeball joint." << llendl; |
316 | return STATUS_FAILURE; | 323 | return STATUS_FAILURE; |
317 | } | 324 | } |
318 | 325 | ||
319 | mRightEyeState.setJoint( character->getJoint("mEyeRight") ); | 326 | mRightEyeState->setJoint( character->getJoint("mEyeRight") ); |
320 | if ( ! mRightEyeState.getJoint() ) | 327 | if ( ! mRightEyeState->getJoint() ) |
321 | { | 328 | { |
322 | llinfos << getName() << ": Can't get Right eyeball joint." << llendl; | 329 | llinfos << getName() << ": Can't get Right eyeball joint." << llendl; |
323 | return STATUS_FAILURE; | 330 | return STATUS_FAILURE; |
324 | } | 331 | } |
325 | 332 | ||
326 | mLeftEyeState.setUsage(LLJointState::ROT); | 333 | mLeftEyeState->setUsage(LLJointState::ROT); |
327 | mRightEyeState.setUsage(LLJointState::ROT); | 334 | mRightEyeState->setUsage(LLJointState::ROT); |
328 | 335 | ||
329 | addJointState( &mLeftEyeState ); | 336 | addJointState( mLeftEyeState ); |
330 | addJointState( &mRightEyeState ); | 337 | addJointState( mRightEyeState ); |
331 | 338 | ||
332 | return STATUS_SUCCESS; | 339 | return STATUS_SUCCESS; |
333 | } | 340 | } |
@@ -443,11 +450,15 @@ BOOL LLEyeMotion::onUpdate(F32 time, U8* joint_mask) | |||
443 | target_eye_rot = LLQuaternion(eye_look_at, left, up); | 450 | target_eye_rot = LLQuaternion(eye_look_at, left, up); |
444 | // convert target rotation to head-local coordinates | 451 | // convert target rotation to head-local coordinates |
445 | target_eye_rot *= ~mHeadJoint->getWorldRotation(); | 452 | target_eye_rot *= ~mHeadJoint->getWorldRotation(); |
453 | // eliminate any Euler roll - we're lucky that roll is applied last. | ||
454 | F32 roll, pitch, yaw; | ||
455 | target_eye_rot.getEulerAngles(&roll, &pitch, &yaw); | ||
456 | target_eye_rot.setQuat(0.0f, pitch, yaw); | ||
446 | // constrain target orientation to be in front of avatar's face | 457 | // constrain target orientation to be in front of avatar's face |
447 | target_eye_rot.constrain(EYE_ROT_LIMIT_ANGLE); | 458 | target_eye_rot.constrain(EYE_ROT_LIMIT_ANGLE); |
448 | 459 | ||
449 | // calculate vergence | 460 | // calculate vergence |
450 | F32 interocular_dist = (mLeftEyeState.getJoint()->getWorldPosition() - mRightEyeState.getJoint()->getWorldPosition()).magVec(); | 461 | F32 interocular_dist = (mLeftEyeState->getJoint()->getWorldPosition() - mRightEyeState->getJoint()->getWorldPosition()).magVec(); |
451 | vergence = -atan2((interocular_dist / 2.f), lookAtDistance); | 462 | vergence = -atan2((interocular_dist / 2.f), lookAtDistance); |
452 | llclamp(vergence, -F_PI_BY_TWO, 0.f); | 463 | llclamp(vergence, -F_PI_BY_TWO, 0.f); |
453 | } | 464 | } |
@@ -495,8 +506,8 @@ BOOL LLEyeMotion::onUpdate(F32 time, U8* joint_mask) | |||
495 | vergence_quat.transQuat(); | 506 | vergence_quat.transQuat(); |
496 | right_eye_rot = vergence_quat * eye_jitter_rot * right_eye_rot; | 507 | right_eye_rot = vergence_quat * eye_jitter_rot * right_eye_rot; |
497 | 508 | ||
498 | mLeftEyeState.setRotation( left_eye_rot ); | 509 | mLeftEyeState->setRotation( left_eye_rot ); |
499 | mRightEyeState.setRotation( right_eye_rot ); | 510 | mRightEyeState->setRotation( right_eye_rot ); |
500 | 511 | ||
501 | return TRUE; | 512 | return TRUE; |
502 | } | 513 | } |
@@ -507,13 +518,13 @@ BOOL LLEyeMotion::onUpdate(F32 time, U8* joint_mask) | |||
507 | //----------------------------------------------------------------------------- | 518 | //----------------------------------------------------------------------------- |
508 | void LLEyeMotion::onDeactivate() | 519 | void LLEyeMotion::onDeactivate() |
509 | { | 520 | { |
510 | LLJoint* joint = mLeftEyeState.getJoint(); | 521 | LLJoint* joint = mLeftEyeState->getJoint(); |
511 | if (joint) | 522 | if (joint) |
512 | { | 523 | { |
513 | joint->setRotation(LLQuaternion::DEFAULT); | 524 | joint->setRotation(LLQuaternion::DEFAULT); |
514 | } | 525 | } |
515 | 526 | ||
516 | joint = mRightEyeState.getJoint(); | 527 | joint = mRightEyeState->getJoint(); |
517 | if (joint) | 528 | if (joint) |
518 | { | 529 | { |
519 | joint->setRotation(LLQuaternion::DEFAULT); | 530 | joint->setRotation(LLQuaternion::DEFAULT); |
diff --git a/linden/indra/llcharacter/llheadrotmotion.h b/linden/indra/llcharacter/llheadrotmotion.h index bc9c8ea..d13cdb4 100644 --- a/linden/indra/llcharacter/llheadrotmotion.h +++ b/linden/indra/llcharacter/llheadrotmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -117,9 +117,9 @@ public: | |||
117 | LLJoint *mRootJoint; | 117 | LLJoint *mRootJoint; |
118 | LLJoint *mPelvisJoint; | 118 | LLJoint *mPelvisJoint; |
119 | 119 | ||
120 | LLJointState mTorsoState; | 120 | LLPointer<LLJointState> mTorsoState; |
121 | LLJointState mNeckState; | 121 | LLPointer<LLJointState> mNeckState; |
122 | LLJointState mHeadState; | 122 | LLPointer<LLJointState> mHeadState; |
123 | 123 | ||
124 | LLQuaternion mLastHeadRot; | 124 | LLQuaternion mLastHeadRot; |
125 | }; | 125 | }; |
@@ -196,8 +196,8 @@ public: | |||
196 | LLCharacter *mCharacter; | 196 | LLCharacter *mCharacter; |
197 | 197 | ||
198 | LLJoint *mHeadJoint; | 198 | LLJoint *mHeadJoint; |
199 | LLJointState mLeftEyeState; | 199 | LLPointer<LLJointState> mLeftEyeState; |
200 | LLJointState mRightEyeState; | 200 | LLPointer<LLJointState> mRightEyeState; |
201 | 201 | ||
202 | LLFrameTimer mEyeJitterTimer; | 202 | LLFrameTimer mEyeJitterTimer; |
203 | F32 mEyeJitterTime; | 203 | F32 mEyeJitterTime; |
diff --git a/linden/indra/llcharacter/lljoint.cpp b/linden/indra/llcharacter/lljoint.cpp index 052d5e2..b7a51f1 100644 --- a/linden/indra/llcharacter/lljoint.cpp +++ b/linden/indra/llcharacter/lljoint.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/lljoint.h b/linden/indra/llcharacter/lljoint.h index c05412d..6492fe2 100644 --- a/linden/indra/llcharacter/lljoint.h +++ b/linden/indra/llcharacter/lljoint.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -115,7 +115,7 @@ public: | |||
115 | void touch(U32 flags = ALL_DIRTY); | 115 | void touch(U32 flags = ALL_DIRTY); |
116 | 116 | ||
117 | // get/set name | 117 | // get/set name |
118 | const std::string &getName() { return mName; } | 118 | const std::string& getName() const { return mName; } |
119 | void setName( const std::string &name ) { mName = name; } | 119 | void setName( const std::string &name ) { mName = name; } |
120 | 120 | ||
121 | // getParent | 121 | // getParent |
@@ -175,7 +175,7 @@ public: | |||
175 | 175 | ||
176 | virtual BOOL isAnimatable() { return TRUE; } | 176 | virtual BOOL isAnimatable() { return TRUE; } |
177 | 177 | ||
178 | S32 getJointNum() { return mJointNum; } | 178 | S32 getJointNum() const { return mJointNum; } |
179 | void setJointNum(S32 joint_num) { mJointNum = joint_num; } | 179 | void setJointNum(S32 joint_num) { mJointNum = joint_num; } |
180 | }; | 180 | }; |
181 | #endif // LL_LLJOINT_H | 181 | #endif // LL_LLJOINT_H |
diff --git a/linden/indra/llcharacter/lljointsolverrp3.cpp b/linden/indra/llcharacter/lljointsolverrp3.cpp index c6ae76e..0356912 100644 --- a/linden/indra/llcharacter/lljointsolverrp3.cpp +++ b/linden/indra/llcharacter/lljointsolverrp3.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/lljointsolverrp3.h b/linden/indra/llcharacter/lljointsolverrp3.h index 370360f..511351a 100644 --- a/linden/indra/llcharacter/lljointsolverrp3.h +++ b/linden/indra/llcharacter/lljointsolverrp3.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/lljointstate.h b/linden/indra/llcharacter/lljointstate.h index ef74150..15dfd6d 100644 --- a/linden/indra/llcharacter/lljointstate.h +++ b/linden/indra/llcharacter/lljointstate.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -36,11 +36,12 @@ | |||
36 | // Header Files | 36 | // Header Files |
37 | //----------------------------------------------------------------------------- | 37 | //----------------------------------------------------------------------------- |
38 | #include "lljoint.h" | 38 | #include "lljoint.h" |
39 | #include "llmemory.h" | ||
39 | 40 | ||
40 | //----------------------------------------------------------------------------- | 41 | //----------------------------------------------------------------------------- |
41 | // class LLJointState | 42 | // class LLJointState |
42 | //----------------------------------------------------------------------------- | 43 | //----------------------------------------------------------------------------- |
43 | class LLJointState | 44 | class LLJointState : public LLRefCount |
44 | { | 45 | { |
45 | public: | 46 | public: |
46 | enum BlendPhase | 47 | enum BlendPhase |
@@ -85,13 +86,9 @@ public: | |||
85 | mPriority = LLJoint::USE_MOTION_PRIORITY; | 86 | mPriority = LLJoint::USE_MOTION_PRIORITY; |
86 | } | 87 | } |
87 | 88 | ||
88 | // Destructor | ||
89 | virtual ~LLJointState() | ||
90 | { | ||
91 | } | ||
92 | |||
93 | // joint that this state is applied to | 89 | // joint that this state is applied to |
94 | LLJoint *getJoint() { return mJoint; } | 90 | LLJoint* getJoint() { return mJoint; } |
91 | const LLJoint* getJoint() const { return mJoint; } | ||
95 | BOOL setJoint( LLJoint *joint ) { mJoint = joint; return mJoint != NULL; } | 92 | BOOL setJoint( LLJoint *joint ) { mJoint = joint; return mJoint != NULL; } |
96 | 93 | ||
97 | // transform type (bitwise flags can be combined) | 94 | // transform type (bitwise flags can be combined) |
@@ -103,26 +100,33 @@ public: | |||
103 | ROT = 2, | 100 | ROT = 2, |
104 | SCALE = 4, | 101 | SCALE = 4, |
105 | }; | 102 | }; |
106 | U32 getUsage() { return mUsage; } | 103 | U32 getUsage() const { return mUsage; } |
107 | void setUsage( U32 usage ) { mUsage = usage; } | 104 | void setUsage( U32 usage ) { mUsage = usage; } |
108 | F32 getWeight() { return mWeight; } | 105 | F32 getWeight() const { return mWeight; } |
109 | void setWeight( F32 weight ) { mWeight = weight; } | 106 | void setWeight( F32 weight ) { mWeight = weight; } |
110 | 107 | ||
111 | // get/set position | 108 | // get/set position |
112 | const LLVector3& getPosition() { return mPosition; } | 109 | const LLVector3& getPosition() const { return mPosition; } |
113 | void setPosition( const LLVector3& pos ) { llassert(mUsage & POS); mPosition = pos; } | 110 | void setPosition( const LLVector3& pos ) { llassert(mUsage & POS); mPosition = pos; } |
114 | 111 | ||
115 | // get/set rotation | 112 | // get/set rotation |
116 | const LLQuaternion& getRotation() { return mRotation; } | 113 | const LLQuaternion& getRotation() const { return mRotation; } |
117 | void setRotation( const LLQuaternion& rot ) { llassert(mUsage & ROT); mRotation = rot; } | 114 | void setRotation( const LLQuaternion& rot ) { llassert(mUsage & ROT); mRotation = rot; } |
118 | 115 | ||
119 | // get/set scale | 116 | // get/set scale |
120 | const LLVector3& getScale() { return mScale; } | 117 | const LLVector3& getScale() const { return mScale; } |
121 | void setScale( const LLVector3& scale ) { llassert(mUsage & SCALE); mScale = scale; } | 118 | void setScale( const LLVector3& scale ) { llassert(mUsage & SCALE); mScale = scale; } |
122 | 119 | ||
123 | // get/set priority | 120 | // get/set priority |
124 | LLJoint::JointPriority getPriority() { return mPriority; } | 121 | LLJoint::JointPriority getPriority() const { return mPriority; } |
125 | void setPriority( const LLJoint::JointPriority priority ) { mPriority = priority; } | 122 | void setPriority( LLJoint::JointPriority priority ) { mPriority = priority; } |
123 | |||
124 | protected: | ||
125 | // Destructor | ||
126 | virtual ~LLJointState() | ||
127 | { | ||
128 | } | ||
129 | |||
126 | }; | 130 | }; |
127 | 131 | ||
128 | #endif // LL_LLJOINTSTATE_H | 132 | #endif // LL_LLJOINTSTATE_H |
diff --git a/linden/indra/llcharacter/llkeyframefallmotion.cpp b/linden/indra/llcharacter/llkeyframefallmotion.cpp index d3113fa..4a1f525 100644 --- a/linden/indra/llcharacter/llkeyframefallmotion.cpp +++ b/linden/indra/llcharacter/llkeyframefallmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -75,13 +75,13 @@ LLMotion::LLMotionInitStatus LLKeyframeFallMotion::onInitialize(LLCharacter *cha | |||
75 | // load keyframe data, setup pose and joint states | 75 | // load keyframe data, setup pose and joint states |
76 | LLMotion::LLMotionInitStatus result = LLKeyframeMotion::onInitialize(character); | 76 | LLMotion::LLMotionInitStatus result = LLKeyframeMotion::onInitialize(character); |
77 | 77 | ||
78 | for (U32 jm=0; jm<mJointMotionList->mNumJointMotions; jm++) | 78 | for (U32 jm=0; jm<mJointMotionList->getNumJointMotions(); jm++) |
79 | { | 79 | { |
80 | if (!mJointStates[jm].getJoint()) | 80 | if (!mJointStates[jm]->getJoint()) |
81 | continue; | 81 | continue; |
82 | if (mJointStates[jm].getJoint()->getName() == std::string("mPelvis")) | 82 | if (mJointStates[jm]->getJoint()->getName() == std::string("mPelvis")) |
83 | { | 83 | { |
84 | mPelvisStatep = &mJointStates[jm]; | 84 | mPelvisState = mJointStates[jm]; |
85 | } | 85 | } |
86 | } | 86 | } |
87 | 87 | ||
@@ -124,8 +124,11 @@ BOOL LLKeyframeFallMotion::onUpdate(F32 activeTime, U8* joint_mask) | |||
124 | BOOL result = LLKeyframeMotion::onUpdate(activeTime, joint_mask); | 124 | BOOL result = LLKeyframeMotion::onUpdate(activeTime, joint_mask); |
125 | F32 slerp_amt = clamp_rescale(activeTime / getDuration(), 0.5f, 0.75f, 0.f, 1.f); | 125 | F32 slerp_amt = clamp_rescale(activeTime / getDuration(), 0.5f, 0.75f, 0.f, 1.f); |
126 | 126 | ||
127 | mPelvisStatep->setRotation(mPelvisStatep->getRotation() * slerp(slerp_amt, mRotationToGroundNormal, LLQuaternion())); | 127 | if (mPelvisState.notNull()) |
128 | 128 | { | |
129 | mPelvisState->setRotation(mPelvisState->getRotation() * slerp(slerp_amt, mRotationToGroundNormal, LLQuaternion())); | ||
130 | } | ||
131 | |||
129 | return result; | 132 | return result; |
130 | } | 133 | } |
131 | 134 | ||
diff --git a/linden/indra/llcharacter/llkeyframefallmotion.h b/linden/indra/llcharacter/llkeyframefallmotion.h index 9f6ed6b..b35925f 100644 --- a/linden/indra/llcharacter/llkeyframefallmotion.h +++ b/linden/indra/llcharacter/llkeyframefallmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -75,7 +75,7 @@ protected: | |||
75 | //------------------------------------------------------------------------- | 75 | //------------------------------------------------------------------------- |
76 | LLCharacter* mCharacter; | 76 | LLCharacter* mCharacter; |
77 | F32 mVelocityZ; | 77 | F32 mVelocityZ; |
78 | LLJointState* mPelvisStatep; | 78 | LLPointer<LLJointState> mPelvisState; |
79 | LLQuaternion mRotationToGroundNormal; | 79 | LLQuaternion mRotationToGroundNormal; |
80 | }; | 80 | }; |
81 | 81 | ||
diff --git a/linden/indra/llcharacter/llkeyframemotion.cpp b/linden/indra/llcharacter/llkeyframemotion.cpp index 9979750..4288b8d 100644 --- a/linden/indra/llcharacter/llkeyframemotion.cpp +++ b/linden/indra/llcharacter/llkeyframemotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -71,24 +71,22 @@ static F32 MAX_CONSTRAINTS = 10; | |||
71 | // JointMotionList | 71 | // JointMotionList |
72 | //----------------------------------------------------------------------------- | 72 | //----------------------------------------------------------------------------- |
73 | LLKeyframeMotion::JointMotionList::JointMotionList() | 73 | LLKeyframeMotion::JointMotionList::JointMotionList() |
74 | : mNumJointMotions(0), | ||
75 | mJointMotionArray(NULL) | ||
76 | { | 74 | { |
77 | } | 75 | } |
78 | 76 | ||
79 | LLKeyframeMotion::JointMotionList::~JointMotionList() | 77 | LLKeyframeMotion::JointMotionList::~JointMotionList() |
80 | { | 78 | { |
81 | for_each(mConstraints.begin(), mConstraints.end(), DeletePointer()); | 79 | for_each(mConstraints.begin(), mConstraints.end(), DeletePointer()); |
82 | delete [] mJointMotionArray; | 80 | for_each(mJointMotionArray.begin(), mJointMotionArray.end(), DeletePointer()); |
83 | } | 81 | } |
84 | 82 | ||
85 | U32 LLKeyframeMotion::JointMotionList::dumpDiagInfo() | 83 | U32 LLKeyframeMotion::JointMotionList::dumpDiagInfo() |
86 | { | 84 | { |
87 | S32 total_size = sizeof(JointMotionList); | 85 | S32 total_size = sizeof(JointMotionList); |
88 | 86 | ||
89 | for (U32 i = 0; i < mNumJointMotions; i++) | 87 | for (U32 i = 0; i < getNumJointMotions(); i++) |
90 | { | 88 | { |
91 | LLKeyframeMotion::JointMotion* joint_motion_p = &mJointMotionArray[i]; | 89 | LLKeyframeMotion::JointMotion* joint_motion_p = mJointMotionArray[i]; |
92 | 90 | ||
93 | llinfos << "\tJoint " << joint_motion_p->mJointName << llendl; | 91 | llinfos << "\tJoint " << joint_motion_p->mJointName << llendl; |
94 | if (joint_motion_p->mUsage & LLJointState::SCALE) | 92 | if (joint_motion_p->mUsage & LLJointState::SCALE) |
@@ -385,10 +383,10 @@ void LLKeyframeMotion::JointMotion::update(LLJointState* joint_state, F32 time, | |||
385 | { | 383 | { |
386 | // this value being 0 is the cause of https://jira.lindenlab.com/browse/SL-22678 but I haven't | 384 | // this value being 0 is the cause of https://jira.lindenlab.com/browse/SL-22678 but I haven't |
387 | // managed to get a stack to see how it got here. Testing for 0 here will stop the crash. | 385 | // managed to get a stack to see how it got here. Testing for 0 here will stop the crash. |
388 | if ( joint_state == 0 ) | 386 | if ( joint_state == NULL ) |
389 | { | 387 | { |
390 | return; | 388 | return; |
391 | }; | 389 | } |
392 | 390 | ||
393 | U32 usage = joint_state->getUsage(); | 391 | U32 usage = joint_state->getUsage(); |
394 | 392 | ||
@@ -431,7 +429,6 @@ void LLKeyframeMotion::JointMotion::update(LLJointState* joint_state, F32 time, | |||
431 | LLKeyframeMotion::LLKeyframeMotion(const LLUUID &id) | 429 | LLKeyframeMotion::LLKeyframeMotion(const LLUUID &id) |
432 | : LLMotion(id), | 430 | : LLMotion(id), |
433 | mJointMotionList(NULL), | 431 | mJointMotionList(NULL), |
434 | mJointStates(NULL), | ||
435 | mPelvisp(NULL), | 432 | mPelvisp(NULL), |
436 | mLastSkeletonSerialNum(0), | 433 | mLastSkeletonSerialNum(0), |
437 | mLastUpdateTime(0.f), | 434 | mLastUpdateTime(0.f), |
@@ -448,10 +445,6 @@ LLKeyframeMotion::LLKeyframeMotion(const LLUUID &id) | |||
448 | //----------------------------------------------------------------------------- | 445 | //----------------------------------------------------------------------------- |
449 | LLKeyframeMotion::~LLKeyframeMotion() | 446 | LLKeyframeMotion::~LLKeyframeMotion() |
450 | { | 447 | { |
451 | if (mJointStates) | ||
452 | { | ||
453 | delete [] mJointStates; | ||
454 | } | ||
455 | for_each(mConstraints.begin(), mConstraints.end(), DeletePointer()); | 448 | for_each(mConstraints.begin(), mConstraints.end(), DeletePointer()); |
456 | } | 449 | } |
457 | 450 | ||
@@ -464,6 +457,26 @@ LLMotion *LLKeyframeMotion::create(const LLUUID &id) | |||
464 | } | 457 | } |
465 | 458 | ||
466 | //----------------------------------------------------------------------------- | 459 | //----------------------------------------------------------------------------- |
460 | // getJointState() | ||
461 | //----------------------------------------------------------------------------- | ||
462 | LLPointer<LLJointState>& LLKeyframeMotion::getJointState(U32 index) | ||
463 | { | ||
464 | llassert_always (index < (S32)mJointStates.size()); | ||
465 | return mJointStates[index]; | ||
466 | } | ||
467 | |||
468 | //----------------------------------------------------------------------------- | ||
469 | // getJoin() | ||
470 | //----------------------------------------------------------------------------- | ||
471 | LLJoint* LLKeyframeMotion::getJoint(U32 index) | ||
472 | { | ||
473 | llassert_always (index < (S32)mJointStates.size()); | ||
474 | LLJoint* joint = mJointStates[index]->getJoint(); | ||
475 | llassert_always (joint); | ||
476 | return joint; | ||
477 | } | ||
478 | |||
479 | //----------------------------------------------------------------------------- | ||
467 | // LLKeyframeMotion::onInitialize(LLCharacter *character) | 480 | // LLKeyframeMotion::onInitialize(LLCharacter *character) |
468 | //----------------------------------------------------------------------------- | 481 | //----------------------------------------------------------------------------- |
469 | LLMotion::LLMotionInitStatus LLKeyframeMotion::onInitialize(LLCharacter *character) | 482 | LLMotion::LLMotionInitStatus LLKeyframeMotion::onInitialize(LLCharacter *character) |
@@ -506,17 +519,25 @@ LLMotion::LLMotionInitStatus LLKeyframeMotion::onInitialize(LLCharacter *charact | |||
506 | // motion already existed in cache, so grab it | 519 | // motion already existed in cache, so grab it |
507 | mJointMotionList = joint_motion_list; | 520 | mJointMotionList = joint_motion_list; |
508 | 521 | ||
522 | mJointStates.reserve(mJointMotionList->getNumJointMotions()); | ||
523 | |||
509 | // don't forget to allocate joint states | 524 | // don't forget to allocate joint states |
510 | mJointStates = new LLJointState[mJointMotionList->mNumJointMotions]; | ||
511 | |||
512 | // set up joint states to point to character joints | 525 | // set up joint states to point to character joints |
513 | for(U32 i = 0; i < mJointMotionList->mNumJointMotions; i++) | 526 | for(U32 i = 0; i < mJointMotionList->getNumJointMotions(); i++) |
514 | { | 527 | { |
515 | if (LLJoint *jointp = mCharacter->getJoint(mJointMotionList->mJointMotionArray[i].mJointName)) | 528 | JointMotion* joint_motion = mJointMotionList->getJointMotion(i); |
529 | if (LLJoint *joint = mCharacter->getJoint(joint_motion->mJointName)) | ||
530 | { | ||
531 | LLPointer<LLJointState> joint_state = new LLJointState; | ||
532 | mJointStates.push_back(joint_state); | ||
533 | joint_state->setJoint(joint); | ||
534 | joint_state->setUsage(joint_motion->mUsage); | ||
535 | joint_state->setPriority(joint_motion->mPriority); | ||
536 | } | ||
537 | else | ||
516 | { | 538 | { |
517 | mJointStates[i].setJoint(jointp); | 539 | // add dummy joint state with no associated joint |
518 | mJointStates[i].setUsage(mJointMotionList->mJointMotionArray[i].mUsage); | 540 | mJointStates.push_back(new LLJointState); |
519 | mJointStates[i].setPriority(joint_motion_list->mJointMotionArray[i].mPriority); | ||
520 | } | 541 | } |
521 | } | 542 | } |
522 | mAssetStatus = ASSET_LOADED; | 543 | mAssetStatus = ASSET_LOADED; |
@@ -587,11 +608,12 @@ LLMotion::LLMotionInitStatus LLKeyframeMotion::onInitialize(LLCharacter *charact | |||
587 | BOOL LLKeyframeMotion::setupPose() | 608 | BOOL LLKeyframeMotion::setupPose() |
588 | { | 609 | { |
589 | // add all valid joint states to the pose | 610 | // add all valid joint states to the pose |
590 | for (U32 jm=0; jm<mJointMotionList->mNumJointMotions; jm++) | 611 | for (U32 jm=0; jm<mJointMotionList->getNumJointMotions(); jm++) |
591 | { | 612 | { |
592 | if ( mJointStates[jm].getJoint() ) | 613 | LLPointer<LLJointState> joint_state = getJointState(jm); |
614 | if ( joint_state->getJoint() ) | ||
593 | { | 615 | { |
594 | addJointState( &mJointStates[jm] ); | 616 | addJointState( joint_state ); |
595 | } | 617 | } |
596 | } | 618 | } |
597 | 619 | ||
@@ -692,13 +714,12 @@ BOOL LLKeyframeMotion::onUpdate(F32 time, U8* joint_mask) | |||
692 | //----------------------------------------------------------------------------- | 714 | //----------------------------------------------------------------------------- |
693 | void LLKeyframeMotion::applyKeyframes(F32 time) | 715 | void LLKeyframeMotion::applyKeyframes(F32 time) |
694 | { | 716 | { |
695 | U32 i; | 717 | llassert_always (mJointMotionList->getNumJointMotions() <= mJointStates.size()); |
696 | for (i=0; i<mJointMotionList->mNumJointMotions; i++) | 718 | for (U32 i=0; i<mJointMotionList->getNumJointMotions(); i++) |
697 | { | 719 | { |
698 | mJointMotionList->mJointMotionArray[i].update( | 720 | mJointMotionList->getJointMotion(i)->update(mJointStates[i], |
699 | &mJointStates[i], | 721 | time, |
700 | time, | 722 | mJointMotionList->mDuration ); |
701 | mJointMotionList->mDuration ); | ||
702 | } | 723 | } |
703 | 724 | ||
704 | LLJoint::JointPriority* pose_priority = (LLJoint::JointPriority* )mCharacter->getAnimationData("Hand Pose Priority"); | 725 | LLJoint::JointPriority* pose_priority = (LLJoint::JointPriority* )mCharacter->getAnimationData("Hand Pose Priority"); |
@@ -793,7 +814,7 @@ void LLKeyframeMotion::initializeConstraint(JointConstraint* constraint) | |||
793 | 814 | ||
794 | S32 joint_num; | 815 | S32 joint_num; |
795 | LLVector3 source_pos = mCharacter->getVolumePos(shared_data->mSourceConstraintVolume, shared_data->mSourceConstraintOffset); | 816 | LLVector3 source_pos = mCharacter->getVolumePos(shared_data->mSourceConstraintVolume, shared_data->mSourceConstraintOffset); |
796 | LLJoint* cur_joint = mJointStates[shared_data->mJointStateIndices[0]].getJoint(); | 817 | LLJoint* cur_joint = getJoint(shared_data->mJointStateIndices[0]); |
797 | 818 | ||
798 | F32 source_pos_offset = dist_vec(source_pos, cur_joint->getWorldPosition()); | 819 | F32 source_pos_offset = dist_vec(source_pos, cur_joint->getWorldPosition()); |
799 | 820 | ||
@@ -802,7 +823,7 @@ void LLKeyframeMotion::initializeConstraint(JointConstraint* constraint) | |||
802 | // grab joint lengths | 823 | // grab joint lengths |
803 | for (joint_num = 1; joint_num < shared_data->mChainLength; joint_num++) | 824 | for (joint_num = 1; joint_num < shared_data->mChainLength; joint_num++) |
804 | { | 825 | { |
805 | cur_joint = mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint(); | 826 | cur_joint = getJointState(shared_data->mJointStateIndices[joint_num])->getJoint(); |
806 | if (!cur_joint) | 827 | if (!cur_joint) |
807 | { | 828 | { |
808 | return; | 829 | return; |
@@ -844,7 +865,7 @@ void LLKeyframeMotion::activateConstraint(JointConstraint* constraint) | |||
844 | 865 | ||
845 | for (joint_num = 1; joint_num < shared_data->mChainLength; joint_num++) | 866 | for (joint_num = 1; joint_num < shared_data->mChainLength; joint_num++) |
846 | { | 867 | { |
847 | LLJoint* cur_joint = mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint(); | 868 | LLJoint* cur_joint = getJoint(shared_data->mJointStateIndices[joint_num]); |
848 | constraint->mPositions[joint_num] = (cur_joint->getWorldPosition() - mPelvisp->getWorldPosition()) * ~mPelvisp->getWorldRotation(); | 869 | constraint->mPositions[joint_num] = (cur_joint->getWorldPosition() - mPelvisp->getWorldPosition()) * ~mPelvisp->getWorldRotation(); |
849 | } | 870 | } |
850 | 871 | ||
@@ -884,7 +905,6 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
884 | LLVector3 velocities[MAX_CHAIN_LENGTH - 1]; | 905 | LLVector3 velocities[MAX_CHAIN_LENGTH - 1]; |
885 | LLQuaternion old_rots[MAX_CHAIN_LENGTH]; | 906 | LLQuaternion old_rots[MAX_CHAIN_LENGTH]; |
886 | S32 joint_num; | 907 | S32 joint_num; |
887 | LLJoint* cur_joint; | ||
888 | 908 | ||
889 | if (time < shared_data->mEaseInStartTime) | 909 | if (time < shared_data->mEaseInStartTime) |
890 | { | 910 | { |
@@ -905,7 +925,7 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
905 | activateConstraint(constraint); | 925 | activateConstraint(constraint); |
906 | } | 926 | } |
907 | 927 | ||
908 | LLJoint* root_joint = mJointStates[shared_data->mJointStateIndices[shared_data->mChainLength]].getJoint(); | 928 | LLJoint* root_joint = getJoint(shared_data->mJointStateIndices[shared_data->mChainLength]); |
909 | LLVector3 root_pos = root_joint->getWorldPosition(); | 929 | LLVector3 root_pos = root_joint->getWorldPosition(); |
910 | // LLQuaternion root_rot = | 930 | // LLQuaternion root_rot = |
911 | root_joint->getParent()->getWorldRotation(); | 931 | root_joint->getParent()->getWorldRotation(); |
@@ -916,14 +936,14 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
916 | //apply underlying keyframe animation to get nominal "kinematic" joint positions | 936 | //apply underlying keyframe animation to get nominal "kinematic" joint positions |
917 | for (joint_num = 0; joint_num <= shared_data->mChainLength; joint_num++) | 937 | for (joint_num = 0; joint_num <= shared_data->mChainLength; joint_num++) |
918 | { | 938 | { |
919 | cur_joint = mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint(); | 939 | LLJoint* cur_joint = getJoint(shared_data->mJointStateIndices[joint_num]); |
920 | if (joint_mask[cur_joint->getJointNum()] >= (0xff >> (7 - getPriority()))) | 940 | if (joint_mask[cur_joint->getJointNum()] >= (0xff >> (7 - getPriority()))) |
921 | { | 941 | { |
922 | // skip constraint | 942 | // skip constraint |
923 | return; | 943 | return; |
924 | } | 944 | } |
925 | old_rots[joint_num] = cur_joint->getRotation(); | 945 | old_rots[joint_num] = cur_joint->getRotation(); |
926 | cur_joint->setRotation(mJointStates[shared_data->mJointStateIndices[joint_num]].getRotation()); | 946 | cur_joint->setRotation(getJointState(shared_data->mJointStateIndices[joint_num])->getRotation()); |
927 | } | 947 | } |
928 | 948 | ||
929 | 949 | ||
@@ -1007,7 +1027,7 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
1007 | 1027 | ||
1008 | if (shared_data->mChainLength) | 1028 | if (shared_data->mChainLength) |
1009 | { | 1029 | { |
1010 | LLQuaternion end_rot = mJointStates[shared_data->mJointStateIndices[0]].getJoint()->getWorldRotation(); | 1030 | LLQuaternion end_rot = getJoint(shared_data->mJointStateIndices[0])->getWorldRotation(); |
1011 | 1031 | ||
1012 | // slam start and end of chain to the proper positions (rest of chain stays put) | 1032 | // slam start and end of chain to the proper positions (rest of chain stays put) |
1013 | positions[0] = lerp(keyframe_source_pos, target_pos, weight); | 1033 | positions[0] = lerp(keyframe_source_pos, target_pos, weight); |
@@ -1016,7 +1036,7 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
1016 | // grab keyframe-specified positions of joints | 1036 | // grab keyframe-specified positions of joints |
1017 | for (joint_num = 1; joint_num < shared_data->mChainLength; joint_num++) | 1037 | for (joint_num = 1; joint_num < shared_data->mChainLength; joint_num++) |
1018 | { | 1038 | { |
1019 | LLVector3 kinematic_position = mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint()->getWorldPosition() + | 1039 | LLVector3 kinematic_position = getJoint(shared_data->mJointStateIndices[joint_num])->getWorldPosition() + |
1020 | (source_to_target * constraint->mJointLengthFractions[joint_num]); | 1040 | (source_to_target * constraint->mJointLengthFractions[joint_num]); |
1021 | 1041 | ||
1022 | // convert intermediate joint positions to world coordinates | 1042 | // convert intermediate joint positions to world coordinates |
@@ -1061,9 +1081,9 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
1061 | 1081 | ||
1062 | for (joint_num = shared_data->mChainLength; joint_num > 0; joint_num--) | 1082 | for (joint_num = shared_data->mChainLength; joint_num > 0; joint_num--) |
1063 | { | 1083 | { |
1064 | LLQuaternion parent_rot = mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint()->getParent()->getWorldRotation(); | 1084 | LLJoint* cur_joint = getJoint(shared_data->mJointStateIndices[joint_num]); |
1065 | cur_joint = mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint(); | 1085 | LLJoint* child_joint = getJoint(shared_data->mJointStateIndices[joint_num - 1]); |
1066 | LLJoint* child_joint = mJointStates[shared_data->mJointStateIndices[joint_num - 1]].getJoint(); | 1086 | LLQuaternion parent_rot = cur_joint->getParent()->getWorldRotation(); |
1067 | 1087 | ||
1068 | LLQuaternion cur_rot = cur_joint->getWorldRotation(); | 1088 | LLQuaternion cur_rot = cur_joint->getWorldRotation(); |
1069 | LLQuaternion fixup_rot; | 1089 | LLQuaternion fixup_rot; |
@@ -1088,25 +1108,25 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
1088 | 1108 | ||
1089 | if (weight != 1.f) | 1109 | if (weight != 1.f) |
1090 | { | 1110 | { |
1091 | LLQuaternion cur_rot = mJointStates[shared_data->mJointStateIndices[joint_num]].getRotation(); | 1111 | LLQuaternion cur_rot = getJointState(shared_data->mJointStateIndices[joint_num])->getRotation(); |
1092 | target_rot = nlerp(weight, cur_rot, target_rot); | 1112 | target_rot = nlerp(weight, cur_rot, target_rot); |
1093 | } | 1113 | } |
1094 | 1114 | ||
1095 | mJointStates[shared_data->mJointStateIndices[joint_num]].setRotation(target_rot); | 1115 | getJointState(shared_data->mJointStateIndices[joint_num])->setRotation(target_rot); |
1096 | cur_joint->setRotation(target_rot); | 1116 | cur_joint->setRotation(target_rot); |
1097 | } | 1117 | } |
1098 | 1118 | ||
1099 | LLJoint* end_joint = mJointStates[shared_data->mJointStateIndices[0]].getJoint(); | 1119 | LLJoint* end_joint = getJoint(shared_data->mJointStateIndices[0]); |
1100 | LLQuaternion end_local_rot = end_rot * ~end_joint->getParent()->getWorldRotation(); | 1120 | LLQuaternion end_local_rot = end_rot * ~end_joint->getParent()->getWorldRotation(); |
1101 | 1121 | ||
1102 | if (weight == 1.f) | 1122 | if (weight == 1.f) |
1103 | { | 1123 | { |
1104 | mJointStates[shared_data->mJointStateIndices[0]].setRotation(end_local_rot); | 1124 | getJointState(shared_data->mJointStateIndices[0])->setRotation(end_local_rot); |
1105 | } | 1125 | } |
1106 | else | 1126 | else |
1107 | { | 1127 | { |
1108 | LLQuaternion cur_rot = mJointStates[shared_data->mJointStateIndices[0]].getRotation(); | 1128 | LLQuaternion cur_rot = getJointState(shared_data->mJointStateIndices[0])->getRotation(); |
1109 | mJointStates[shared_data->mJointStateIndices[0]].setRotation(nlerp(weight, cur_rot, end_local_rot)); | 1129 | getJointState(shared_data->mJointStateIndices[0])->setRotation(nlerp(weight, cur_rot, end_local_rot)); |
1110 | } | 1130 | } |
1111 | 1131 | ||
1112 | // save simulated positions in pelvis-space and calculate total fixup distance | 1132 | // save simulated positions in pelvis-space and calculate total fixup distance |
@@ -1124,17 +1144,17 @@ void LLKeyframeMotion::applyConstraint(JointConstraint* constraint, F32 time, U8 | |||
1124 | //reset old joint rots | 1144 | //reset old joint rots |
1125 | for (joint_num = 0; joint_num <= shared_data->mChainLength; joint_num++) | 1145 | for (joint_num = 0; joint_num <= shared_data->mChainLength; joint_num++) |
1126 | { | 1146 | { |
1127 | mJointStates[shared_data->mJointStateIndices[joint_num]].getJoint()->setRotation(old_rots[joint_num]); | 1147 | getJoint(shared_data->mJointStateIndices[joint_num])->setRotation(old_rots[joint_num]); |
1128 | } | 1148 | } |
1129 | } | 1149 | } |
1130 | // simple positional constraint (pelvis only) | 1150 | // simple positional constraint (pelvis only) |
1131 | else if (mJointStates[shared_data->mJointStateIndices[0]].getUsage() & LLJointState::POS) | 1151 | else if (getJointState(shared_data->mJointStateIndices[0])->getUsage() & LLJointState::POS) |
1132 | { | 1152 | { |
1133 | LLVector3 delta = source_to_target * weight; | 1153 | LLVector3 delta = source_to_target * weight; |
1134 | LLJointState* current_joint_statep = &mJointStates[shared_data->mJointStateIndices[0]]; | 1154 | LLPointer<LLJointState> current_joint_state = getJointState(shared_data->mJointStateIndices[0]); |
1135 | LLQuaternion parent_rot = current_joint_statep->getJoint()->getParent()->getWorldRotation(); | 1155 | LLQuaternion parent_rot = current_joint_state->getJoint()->getParent()->getWorldRotation(); |
1136 | delta = delta * ~parent_rot; | 1156 | delta = delta * ~parent_rot; |
1137 | current_joint_statep->setPosition(current_joint_statep->getJoint()->getPosition() + delta); | 1157 | current_joint_state->setPosition(current_joint_state->getJoint()->getPosition() + delta); |
1138 | } | 1158 | } |
1139 | } | 1159 | } |
1140 | 1160 | ||
@@ -1145,7 +1165,6 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1145 | { | 1165 | { |
1146 | BOOL old_version = FALSE; | 1166 | BOOL old_version = FALSE; |
1147 | mJointMotionList = new LLKeyframeMotion::JointMotionList; | 1167 | mJointMotionList = new LLKeyframeMotion::JointMotionList; |
1148 | mJointMotionList->mNumJointMotions = 0; | ||
1149 | 1168 | ||
1150 | //------------------------------------------------------------------------- | 1169 | //------------------------------------------------------------------------- |
1151 | // get base priority | 1170 | // get base priority |
@@ -1261,40 +1280,38 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1261 | //------------------------------------------------------------------------- | 1280 | //------------------------------------------------------------------------- |
1262 | // get number of joint motions | 1281 | // get number of joint motions |
1263 | //------------------------------------------------------------------------- | 1282 | //------------------------------------------------------------------------- |
1264 | if (!dp.unpackU32(mJointMotionList->mNumJointMotions, "num_joints")) | 1283 | U32 num_motions = 0; |
1284 | if (!dp.unpackU32(num_motions, "num_joints")) | ||
1265 | { | 1285 | { |
1266 | llwarns << "can't read number of joints" << llendl; | 1286 | llwarns << "can't read number of joints" << llendl; |
1267 | return FALSE; | 1287 | return FALSE; |
1268 | } | 1288 | } |
1269 | 1289 | ||
1270 | if (mJointMotionList->mNumJointMotions == 0) | 1290 | if (num_motions == 0) |
1271 | { | 1291 | { |
1272 | llwarns << "no joints in animation" << llendl; | 1292 | llwarns << "no joints in animation" << llendl; |
1273 | return FALSE; | 1293 | return FALSE; |
1274 | } | 1294 | } |
1275 | else if (mJointMotionList->mNumJointMotions > LL_CHARACTER_MAX_JOINTS) | 1295 | else if (num_motions > LL_CHARACTER_MAX_JOINTS) |
1276 | { | 1296 | { |
1277 | llwarns << "too many joints in animation" << llendl; | 1297 | llwarns << "too many joints in animation" << llendl; |
1278 | return FALSE; | 1298 | return FALSE; |
1279 | } | 1299 | } |
1280 | 1300 | ||
1281 | mJointMotionList->mJointMotionArray = new JointMotion[mJointMotionList->mNumJointMotions]; | 1301 | mJointMotionList->mJointMotionArray.clear(); |
1282 | mJointStates = new LLJointState[mJointMotionList->mNumJointMotions]; | 1302 | mJointMotionList->mJointMotionArray.reserve(num_motions); |
1283 | 1303 | mJointStates.clear(); | |
1284 | if (!mJointMotionList->mJointMotionArray) | 1304 | mJointStates.reserve(num_motions); |
1285 | { | ||
1286 | mJointMotionList->mDuration = 0.0f; | ||
1287 | mJointMotionList->mEaseInDuration = 0.0f; | ||
1288 | mJointMotionList->mEaseOutDuration = 0.0f; | ||
1289 | return FALSE; | ||
1290 | } | ||
1291 | 1305 | ||
1292 | //------------------------------------------------------------------------- | 1306 | //------------------------------------------------------------------------- |
1293 | // initialize joint motions | 1307 | // initialize joint motions |
1294 | //------------------------------------------------------------------------- | 1308 | //------------------------------------------------------------------------- |
1295 | S32 k; | 1309 | |
1296 | for(U32 i=0; i<mJointMotionList->mNumJointMotions; ++i) | 1310 | for(U32 i=0; i<num_motions; ++i) |
1297 | { | 1311 | { |
1312 | JointMotion* joint_motion = new JointMotion; | ||
1313 | mJointMotionList->mJointMotionArray.push_back(joint_motion); | ||
1314 | |||
1298 | std::string joint_name; | 1315 | std::string joint_name; |
1299 | if (!dp.unpackString(joint_name, "joint_name")) | 1316 | if (!dp.unpackString(joint_name, "joint_name")) |
1300 | { | 1317 | { |
@@ -1316,9 +1333,12 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1316 | //return FALSE; | 1333 | //return FALSE; |
1317 | } | 1334 | } |
1318 | 1335 | ||
1319 | mJointMotionList->mJointMotionArray[i].mJointName = joint_name; | 1336 | joint_motion->mJointName = joint_name; |
1320 | mJointStates[i].setJoint( joint ); | 1337 | |
1321 | mJointStates[i].setUsage( 0 ); | 1338 | LLPointer<LLJointState> joint_state = new LLJointState; |
1339 | mJointStates.push_back(joint_state); | ||
1340 | joint_state->setJoint( joint ); | ||
1341 | joint_state->setUsage( 0 ); | ||
1322 | 1342 | ||
1323 | //--------------------------------------------------------------------- | 1343 | //--------------------------------------------------------------------- |
1324 | // get joint priority | 1344 | // get joint priority |
@@ -1330,36 +1350,36 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1330 | return FALSE; | 1350 | return FALSE; |
1331 | } | 1351 | } |
1332 | 1352 | ||
1333 | mJointMotionList->mJointMotionArray[i].mPriority = (LLJoint::JointPriority)joint_priority; | 1353 | joint_motion->mPriority = (LLJoint::JointPriority)joint_priority; |
1334 | if (joint_priority != LLJoint::USE_MOTION_PRIORITY && | 1354 | if (joint_priority != LLJoint::USE_MOTION_PRIORITY && |
1335 | joint_priority > mJointMotionList->mMaxPriority) | 1355 | joint_priority > mJointMotionList->mMaxPriority) |
1336 | { | 1356 | { |
1337 | mJointMotionList->mMaxPriority = (LLJoint::JointPriority)joint_priority; | 1357 | mJointMotionList->mMaxPriority = (LLJoint::JointPriority)joint_priority; |
1338 | } | 1358 | } |
1339 | 1359 | ||
1340 | mJointStates[i].setPriority((LLJoint::JointPriority)joint_priority); | 1360 | joint_state->setPriority((LLJoint::JointPriority)joint_priority); |
1341 | 1361 | ||
1342 | //--------------------------------------------------------------------- | 1362 | //--------------------------------------------------------------------- |
1343 | // scan rotation curve header | 1363 | // scan rotation curve header |
1344 | //--------------------------------------------------------------------- | 1364 | //--------------------------------------------------------------------- |
1345 | if (!dp.unpackS32(mJointMotionList->mJointMotionArray[i].mRotationCurve.mNumKeys, "num_rot_keys")) | 1365 | if (!dp.unpackS32(joint_motion->mRotationCurve.mNumKeys, "num_rot_keys")) |
1346 | { | 1366 | { |
1347 | llwarns << "can't read number of rotation keys" << llendl; | 1367 | llwarns << "can't read number of rotation keys" << llendl; |
1348 | return FALSE; | 1368 | return FALSE; |
1349 | } | 1369 | } |
1350 | 1370 | ||
1351 | mJointMotionList->mJointMotionArray[i].mRotationCurve.mInterpolationType = IT_LINEAR; | 1371 | joint_motion->mRotationCurve.mInterpolationType = IT_LINEAR; |
1352 | if (mJointMotionList->mJointMotionArray[i].mRotationCurve.mNumKeys != 0) | 1372 | if (joint_motion->mRotationCurve.mNumKeys != 0) |
1353 | { | 1373 | { |
1354 | mJointStates[i].setUsage(mJointStates[i].getUsage() | LLJointState::ROT ); | 1374 | joint_state->setUsage(joint_state->getUsage() | LLJointState::ROT ); |
1355 | } | 1375 | } |
1356 | 1376 | ||
1357 | //--------------------------------------------------------------------- | 1377 | //--------------------------------------------------------------------- |
1358 | // scan rotation curve keys | 1378 | // scan rotation curve keys |
1359 | //--------------------------------------------------------------------- | 1379 | //--------------------------------------------------------------------- |
1360 | RotationCurve *rCurve = &mJointMotionList->mJointMotionArray[i].mRotationCurve; | 1380 | RotationCurve *rCurve = &joint_motion->mRotationCurve; |
1361 | 1381 | ||
1362 | for (k = 0; k < mJointMotionList->mJointMotionArray[i].mRotationCurve.mNumKeys; k++) | 1382 | for (S32 k = 0; k < joint_motion->mRotationCurve.mNumKeys; k++) |
1363 | { | 1383 | { |
1364 | F32 time; | 1384 | F32 time; |
1365 | U16 time_short; | 1385 | U16 time_short; |
@@ -1424,24 +1444,24 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1424 | //--------------------------------------------------------------------- | 1444 | //--------------------------------------------------------------------- |
1425 | // scan position curve header | 1445 | // scan position curve header |
1426 | //--------------------------------------------------------------------- | 1446 | //--------------------------------------------------------------------- |
1427 | if (!dp.unpackS32(mJointMotionList->mJointMotionArray[i].mPositionCurve.mNumKeys, "num_pos_keys")) | 1447 | if (!dp.unpackS32(joint_motion->mPositionCurve.mNumKeys, "num_pos_keys")) |
1428 | { | 1448 | { |
1429 | llwarns << "can't read number of position keys" << llendl; | 1449 | llwarns << "can't read number of position keys" << llendl; |
1430 | return FALSE; | 1450 | return FALSE; |
1431 | } | 1451 | } |
1432 | 1452 | ||
1433 | mJointMotionList->mJointMotionArray[i].mPositionCurve.mInterpolationType = IT_LINEAR; | 1453 | joint_motion->mPositionCurve.mInterpolationType = IT_LINEAR; |
1434 | if (mJointMotionList->mJointMotionArray[i].mPositionCurve.mNumKeys != 0) | 1454 | if (joint_motion->mPositionCurve.mNumKeys != 0) |
1435 | { | 1455 | { |
1436 | mJointStates[i].setUsage(mJointStates[i].getUsage() | LLJointState::POS ); | 1456 | joint_state->setUsage(joint_state->getUsage() | LLJointState::POS ); |
1437 | } | 1457 | } |
1438 | 1458 | ||
1439 | //--------------------------------------------------------------------- | 1459 | //--------------------------------------------------------------------- |
1440 | // scan position curve keys | 1460 | // scan position curve keys |
1441 | //--------------------------------------------------------------------- | 1461 | //--------------------------------------------------------------------- |
1442 | PositionCurve *pCurve = &mJointMotionList->mJointMotionArray[i].mPositionCurve; | 1462 | PositionCurve *pCurve = &joint_motion->mPositionCurve; |
1443 | BOOL is_pelvis = mJointMotionList->mJointMotionArray[i].mJointName == "mPelvis"; | 1463 | BOOL is_pelvis = joint_motion->mJointName == "mPelvis"; |
1444 | for (k = 0; k < mJointMotionList->mJointMotionArray[i].mPositionCurve.mNumKeys; k++) | 1464 | for (S32 k = 0; k < joint_motion->mPositionCurve.mNumKeys; k++) |
1445 | { | 1465 | { |
1446 | U16 time_short; | 1466 | U16 time_short; |
1447 | PositionKey* pos_key = new PositionKey; | 1467 | PositionKey* pos_key = new PositionKey; |
@@ -1501,7 +1521,7 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1501 | } | 1521 | } |
1502 | } | 1522 | } |
1503 | 1523 | ||
1504 | mJointMotionList->mJointMotionArray[i].mUsage = mJointStates[i].getUsage(); | 1524 | joint_motion->mUsage = joint_state->getUsage(); |
1505 | } | 1525 | } |
1506 | 1526 | ||
1507 | //------------------------------------------------------------------------- | 1527 | //------------------------------------------------------------------------- |
@@ -1655,9 +1675,9 @@ BOOL LLKeyframeMotion::deserialize(LLDataPacker& dp) | |||
1655 | } | 1675 | } |
1656 | joint = parent; | 1676 | joint = parent; |
1657 | constraintp->mJointStateIndices[i] = -1; | 1677 | constraintp->mJointStateIndices[i] = -1; |
1658 | for (U32 j = 0; j < mJointMotionList->mNumJointMotions; j++) | 1678 | for (U32 j = 0; j < mJointMotionList->getNumJointMotions(); j++) |
1659 | { | 1679 | { |
1660 | if(mJointStates[j].getJoint() == joint) | 1680 | if(getJoint(j) == joint) |
1661 | { | 1681 | { |
1662 | constraintp->mJointStateIndices[i] = (S32)j; | 1682 | constraintp->mJointStateIndices[i] = (S32)j; |
1663 | break; | 1683 | break; |
@@ -1695,11 +1715,11 @@ BOOL LLKeyframeMotion::serialize(LLDataPacker& dp) const | |||
1695 | success &= dp.packF32(mJointMotionList->mEaseInDuration, "ease_in_duration"); | 1715 | success &= dp.packF32(mJointMotionList->mEaseInDuration, "ease_in_duration"); |
1696 | success &= dp.packF32(mJointMotionList->mEaseOutDuration, "ease_out_duration"); | 1716 | success &= dp.packF32(mJointMotionList->mEaseOutDuration, "ease_out_duration"); |
1697 | success &= dp.packU32(mJointMotionList->mHandPose, "hand_pose"); | 1717 | success &= dp.packU32(mJointMotionList->mHandPose, "hand_pose"); |
1698 | success &= dp.packU32(mJointMotionList->mNumJointMotions, "num_joints"); | 1718 | success &= dp.packU32(mJointMotionList->getNumJointMotions(), "num_joints"); |
1699 | 1719 | ||
1700 | for (U32 i = 0; i < mJointMotionList->mNumJointMotions; i++) | 1720 | for (U32 i = 0; i < mJointMotionList->getNumJointMotions(); i++) |
1701 | { | 1721 | { |
1702 | JointMotion* joint_motionp = &mJointMotionList->mJointMotionArray[i]; | 1722 | JointMotion* joint_motionp = mJointMotionList->getJointMotion(i); |
1703 | success &= dp.packString(joint_motionp->mJointName.c_str(), "joint_name"); | 1723 | success &= dp.packString(joint_motionp->mJointName.c_str(), "joint_name"); |
1704 | success &= dp.packS32(joint_motionp->mPriority, "joint_priority"); | 1724 | success &= dp.packS32(joint_motionp->mPriority, "joint_priority"); |
1705 | success &= dp.packS32(joint_motionp->mRotationCurve.mNumKeys, "num_rot_keys"); | 1725 | success &= dp.packS32(joint_motionp->mRotationCurve.mNumKeys, "num_rot_keys"); |
@@ -1806,13 +1826,14 @@ void LLKeyframeMotion::setPriority(S32 priority) | |||
1806 | mJointMotionList->mBasePriority = (LLJoint::JointPriority)priority; | 1826 | mJointMotionList->mBasePriority = (LLJoint::JointPriority)priority; |
1807 | mJointMotionList->mMaxPriority = mJointMotionList->mBasePriority; | 1827 | mJointMotionList->mMaxPriority = mJointMotionList->mBasePriority; |
1808 | 1828 | ||
1809 | for (U32 i = 0; i < mJointMotionList->mNumJointMotions; i++) | 1829 | for (U32 i = 0; i < mJointMotionList->getNumJointMotions(); i++) |
1810 | { | 1830 | { |
1811 | mJointMotionList->mJointMotionArray[i].mPriority = (LLJoint::JointPriority)llclamp( | 1831 | JointMotion* joint_motion = mJointMotionList->getJointMotion(i); |
1812 | (S32)mJointMotionList->mJointMotionArray[i].mPriority + priority_delta, | 1832 | joint_motion->mPriority = (LLJoint::JointPriority)llclamp( |
1833 | (S32)joint_motion->mPriority + priority_delta, | ||
1813 | (S32)LLJoint::LOW_PRIORITY, | 1834 | (S32)LLJoint::LOW_PRIORITY, |
1814 | (S32)LLJoint::HIGHEST_PRIORITY); | 1835 | (S32)LLJoint::HIGHEST_PRIORITY); |
1815 | mJointStates[i].setPriority(mJointMotionList->mJointMotionArray[i].mPriority); | 1836 | getJointState(i)->setPriority(joint_motion->mPriority); |
1816 | } | 1837 | } |
1817 | } | 1838 | } |
1818 | } | 1839 | } |
@@ -1888,11 +1909,13 @@ void LLKeyframeMotion::setLoopIn(F32 in_point) | |||
1888 | mJointMotionList->mLoopInPoint = in_point; | 1909 | mJointMotionList->mLoopInPoint = in_point; |
1889 | 1910 | ||
1890 | // set up loop keys | 1911 | // set up loop keys |
1891 | for (U32 i = 0; i < mJointMotionList->mNumJointMotions; i++) | 1912 | for (U32 i = 0; i < mJointMotionList->getNumJointMotions(); i++) |
1892 | { | 1913 | { |
1893 | PositionCurve* pos_curve = &mJointMotionList->mJointMotionArray[i].mPositionCurve; | 1914 | JointMotion* joint_motion = mJointMotionList->getJointMotion(i); |
1894 | RotationCurve* rot_curve = &mJointMotionList->mJointMotionArray[i].mRotationCurve; | 1915 | |
1895 | ScaleCurve* scale_curve = &mJointMotionList->mJointMotionArray[i].mScaleCurve; | 1916 | PositionCurve* pos_curve = &joint_motion->mPositionCurve; |
1917 | RotationCurve* rot_curve = &joint_motion->mRotationCurve; | ||
1918 | ScaleCurve* scale_curve = &joint_motion->mScaleCurve; | ||
1896 | 1919 | ||
1897 | pos_curve->mLoopInKey.mTime = mJointMotionList->mLoopInPoint; | 1920 | pos_curve->mLoopInKey.mTime = mJointMotionList->mLoopInPoint; |
1898 | rot_curve->mLoopInKey.mTime = mJointMotionList->mLoopInPoint; | 1921 | rot_curve->mLoopInKey.mTime = mJointMotionList->mLoopInPoint; |
@@ -1915,11 +1938,13 @@ void LLKeyframeMotion::setLoopOut(F32 out_point) | |||
1915 | mJointMotionList->mLoopOutPoint = out_point; | 1938 | mJointMotionList->mLoopOutPoint = out_point; |
1916 | 1939 | ||
1917 | // set up loop keys | 1940 | // set up loop keys |
1918 | for (U32 i = 0; i < mJointMotionList->mNumJointMotions; i++) | 1941 | for (U32 i = 0; i < mJointMotionList->getNumJointMotions(); i++) |
1919 | { | 1942 | { |
1920 | PositionCurve* pos_curve = &mJointMotionList->mJointMotionArray[i].mPositionCurve; | 1943 | JointMotion* joint_motion = mJointMotionList->getJointMotion(i); |
1921 | RotationCurve* rot_curve = &mJointMotionList->mJointMotionArray[i].mRotationCurve; | 1944 | |
1922 | ScaleCurve* scale_curve = &mJointMotionList->mJointMotionArray[i].mScaleCurve; | 1945 | PositionCurve* pos_curve = &joint_motion->mPositionCurve; |
1946 | RotationCurve* rot_curve = &joint_motion->mRotationCurve; | ||
1947 | ScaleCurve* scale_curve = &joint_motion->mScaleCurve; | ||
1923 | 1948 | ||
1924 | pos_curve->mLoopOutKey.mTime = mJointMotionList->mLoopOutPoint; | 1949 | pos_curve->mLoopOutKey.mTime = mJointMotionList->mLoopOutPoint; |
1925 | rot_curve->mLoopOutKey.mTime = mJointMotionList->mLoopOutPoint; | 1950 | rot_curve->mLoopOutKey.mTime = mJointMotionList->mLoopOutPoint; |
@@ -2020,10 +2045,10 @@ void LLKeyframeMotion::writeCAL3D(apr_file_t* fp) | |||
2020 | // </TRACK> | 2045 | // </TRACK> |
2021 | // </ANIMATION> | 2046 | // </ANIMATION> |
2022 | 2047 | ||
2023 | apr_file_printf(fp, "<ANIMATION VERSION=\"1000\" DURATION=\"%.5f\" NUMTRACKS=\"%d\">\n", getDuration(), mJointMotionList->mNumJointMotions); | 2048 | apr_file_printf(fp, "<ANIMATION VERSION=\"1000\" DURATION=\"%.5f\" NUMTRACKS=\"%d\">\n", getDuration(), mJointMotionList->getNumJointMotions()); |
2024 | for (U32 joint_index = 0; joint_index < mJointMotionList->mNumJointMotions; joint_index++) | 2049 | for (U32 joint_index = 0; joint_index < mJointMotionList->getNumJointMotions(); joint_index++) |
2025 | { | 2050 | { |
2026 | JointMotion* joint_motionp = &mJointMotionList->mJointMotionArray[joint_index]; | 2051 | JointMotion* joint_motionp = mJointMotionList->getJointMotion(joint_index); |
2027 | LLJoint* animated_joint = mCharacter->getJoint(joint_motionp->mJointName); | 2052 | LLJoint* animated_joint = mCharacter->getJoint(joint_motionp->mJointName); |
2028 | S32 joint_num = animated_joint->mJointNum + 1; | 2053 | S32 joint_num = animated_joint->mJointNum + 1; |
2029 | 2054 | ||
diff --git a/linden/indra/llcharacter/llkeyframemotion.h b/linden/indra/llcharacter/llkeyframemotion.h index ef3f6dd..0ad0181 100644 --- a/linden/indra/llcharacter/llkeyframemotion.h +++ b/linden/indra/llcharacter/llkeyframemotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -73,6 +73,11 @@ public: | |||
73 | // Destructor | 73 | // Destructor |
74 | virtual ~LLKeyframeMotion(); | 74 | virtual ~LLKeyframeMotion(); |
75 | 75 | ||
76 | private: | ||
77 | // private helper functions to wrap some asserts | ||
78 | LLPointer<LLJointState>& getJointState(U32 index); | ||
79 | LLJoint* getJoint(U32 index); | ||
80 | |||
76 | public: | 81 | public: |
77 | //------------------------------------------------------------------------- | 82 | //------------------------------------------------------------------------- |
78 | // functions to support MotionController and MotionRegistry | 83 | // functions to support MotionController and MotionRegistry |
@@ -388,7 +393,7 @@ public: | |||
388 | U32 mUsage; | 393 | U32 mUsage; |
389 | LLJoint::JointPriority mPriority; | 394 | LLJoint::JointPriority mPriority; |
390 | 395 | ||
391 | void update(LLJointState *joint_state, F32 time, F32 duration); | 396 | void update(LLJointState* joint_state, F32 time, F32 duration); |
392 | }; | 397 | }; |
393 | 398 | ||
394 | //------------------------------------------------------------------------- | 399 | //------------------------------------------------------------------------- |
@@ -397,8 +402,7 @@ public: | |||
397 | class JointMotionList | 402 | class JointMotionList |
398 | { | 403 | { |
399 | public: | 404 | public: |
400 | U32 mNumJointMotions; | 405 | std::vector<JointMotion*> mJointMotionArray; |
401 | JointMotion* mJointMotionArray; | ||
402 | F32 mDuration; | 406 | F32 mDuration; |
403 | BOOL mLoop; | 407 | BOOL mLoop; |
404 | F32 mLoopInPoint; | 408 | F32 mLoopInPoint; |
@@ -415,6 +419,8 @@ public: | |||
415 | JointMotionList(); | 419 | JointMotionList(); |
416 | ~JointMotionList(); | 420 | ~JointMotionList(); |
417 | U32 dumpDiagInfo(); | 421 | U32 dumpDiagInfo(); |
422 | JointMotion* getJointMotion(U32 index) const { llassert(index < mJointMotionArray.size()); return mJointMotionArray[index]; } | ||
423 | U32 getNumJointMotions() const { return mJointMotionArray.size(); } | ||
418 | }; | 424 | }; |
419 | 425 | ||
420 | 426 | ||
@@ -425,7 +431,7 @@ protected: | |||
425 | // Member Data | 431 | // Member Data |
426 | //------------------------------------------------------------------------- | 432 | //------------------------------------------------------------------------- |
427 | JointMotionList* mJointMotionList; | 433 | JointMotionList* mJointMotionList; |
428 | LLJointState* mJointStates; | 434 | std::vector<LLPointer<LLJointState> > mJointStates; |
429 | LLJoint* mPelvisp; | 435 | LLJoint* mPelvisp; |
430 | LLCharacter* mCharacter; | 436 | LLCharacter* mCharacter; |
431 | std::string mEmoteName; | 437 | std::string mEmoteName; |
diff --git a/linden/indra/llcharacter/llkeyframemotionparam.cpp b/linden/indra/llcharacter/llkeyframemotionparam.cpp index 12b7296..2dd935c 100644 --- a/linden/indra/llcharacter/llkeyframemotionparam.cpp +++ b/linden/indra/llcharacter/llkeyframemotionparam.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -61,7 +61,6 @@ BOOL LLKeyframeMotionParam::sortFunc(ParameterizedMotion *new_motion, Parameteri | |||
61 | //----------------------------------------------------------------------------- | 61 | //----------------------------------------------------------------------------- |
62 | LLKeyframeMotionParam::LLKeyframeMotionParam( const LLUUID &id) : LLMotion(id) | 62 | LLKeyframeMotionParam::LLKeyframeMotionParam( const LLUUID &id) : LLMotion(id) |
63 | { | 63 | { |
64 | mJointStates = NULL; | ||
65 | mDefaultKeyframeMotion = NULL; | 64 | mDefaultKeyframeMotion = NULL; |
66 | mCharacter = NULL; | 65 | mCharacter = NULL; |
67 | 66 | ||
diff --git a/linden/indra/llcharacter/llkeyframemotionparam.h b/linden/indra/llcharacter/llkeyframemotionparam.h index 75977ee..a5bc2cb 100644 --- a/linden/indra/llcharacter/llkeyframemotionparam.h +++ b/linden/indra/llcharacter/llkeyframemotionparam.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -145,7 +145,6 @@ protected: | |||
145 | 145 | ||
146 | typedef LLLinkedList < ParameterizedMotion > motion_list_t; | 146 | typedef LLLinkedList < ParameterizedMotion > motion_list_t; |
147 | LLAssocList <std::string, motion_list_t* > mParameterizedMotions; | 147 | LLAssocList <std::string, motion_list_t* > mParameterizedMotions; |
148 | LLJointState* mJointStates; | ||
149 | LLMotion* mDefaultKeyframeMotion; | 148 | LLMotion* mDefaultKeyframeMotion; |
150 | LLCharacter* mCharacter; | 149 | LLCharacter* mCharacter; |
151 | LLPoseBlender mPoseBlender; | 150 | LLPoseBlender mPoseBlender; |
diff --git a/linden/indra/llcharacter/llkeyframestandmotion.cpp b/linden/indra/llcharacter/llkeyframestandmotion.cpp index 9e850a4..6517681 100644 --- a/linden/indra/llcharacter/llkeyframestandmotion.cpp +++ b/linden/indra/llcharacter/llkeyframestandmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llkeyframestandmotion.h b/linden/indra/llcharacter/llkeyframestandmotion.h index 0fcda27..6772b6e 100644 --- a/linden/indra/llcharacter/llkeyframestandmotion.h +++ b/linden/indra/llcharacter/llkeyframestandmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -78,15 +78,15 @@ public: | |||
78 | 78 | ||
79 | BOOL mFlipFeet; | 79 | BOOL mFlipFeet; |
80 | 80 | ||
81 | LLJointState *mPelvisState; | 81 | LLPointer<LLJointState> mPelvisState; |
82 | 82 | ||
83 | LLJointState *mHipLeftState; | 83 | LLPointer<LLJointState> mHipLeftState; |
84 | LLJointState *mKneeLeftState; | 84 | LLPointer<LLJointState> mKneeLeftState; |
85 | LLJointState *mAnkleLeftState; | 85 | LLPointer<LLJointState> mAnkleLeftState; |
86 | 86 | ||
87 | LLJointState *mHipRightState; | 87 | LLPointer<LLJointState> mHipRightState; |
88 | LLJointState *mKneeRightState; | 88 | LLPointer<LLJointState> mKneeRightState; |
89 | LLJointState *mAnkleRightState; | 89 | LLPointer<LLJointState> mAnkleRightState; |
90 | 90 | ||
91 | LLJoint mPelvisJoint; | 91 | LLJoint mPelvisJoint; |
92 | 92 | ||
diff --git a/linden/indra/llcharacter/llkeyframewalkmotion.cpp b/linden/indra/llcharacter/llkeyframewalkmotion.cpp index 83c1c49..d5f6b81 100644 --- a/linden/indra/llcharacter/llkeyframewalkmotion.cpp +++ b/linden/indra/llcharacter/llkeyframewalkmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -143,6 +143,8 @@ LLWalkAdjustMotion::LLWalkAdjustMotion(const LLUUID &id) : LLMotion(id) | |||
143 | { | 143 | { |
144 | mLastTime = 0.f; | 144 | mLastTime = 0.f; |
145 | mName = "walk_adjust"; | 145 | mName = "walk_adjust"; |
146 | |||
147 | mPelvisState = new LLJointState; | ||
146 | } | 148 | } |
147 | 149 | ||
148 | //----------------------------------------------------------------------------- | 150 | //----------------------------------------------------------------------------- |
@@ -155,15 +157,15 @@ LLMotion::LLMotionInitStatus LLWalkAdjustMotion::onInitialize(LLCharacter *chara | |||
155 | mRightAnkleJoint = mCharacter->getJoint("mAnkleRight"); | 157 | mRightAnkleJoint = mCharacter->getJoint("mAnkleRight"); |
156 | 158 | ||
157 | mPelvisJoint = mCharacter->getJoint("mPelvis"); | 159 | mPelvisJoint = mCharacter->getJoint("mPelvis"); |
158 | mPelvisState.setJoint( mPelvisJoint ); | 160 | mPelvisState->setJoint( mPelvisJoint ); |
159 | if ( !mPelvisJoint ) | 161 | if ( !mPelvisJoint ) |
160 | { | 162 | { |
161 | llwarns << getName() << ": Can't get pelvis joint." << llendl; | 163 | llwarns << getName() << ": Can't get pelvis joint." << llendl; |
162 | return STATUS_FAILURE; | 164 | return STATUS_FAILURE; |
163 | } | 165 | } |
164 | 166 | ||
165 | mPelvisState.setUsage(LLJointState::POS); | 167 | mPelvisState->setUsage(LLJointState::POS); |
166 | addJointState( &mPelvisState ); | 168 | addJointState( mPelvisState ); |
167 | 169 | ||
168 | return STATUS_SUCCESS; | 170 | return STATUS_SUCCESS; |
169 | } | 171 | } |
@@ -178,7 +180,7 @@ BOOL LLWalkAdjustMotion::onActivate() | |||
178 | mAnimSpeed = 0.f; | 180 | mAnimSpeed = 0.f; |
179 | mAvgSpeed = 0.f; | 181 | mAvgSpeed = 0.f; |
180 | mRelativeDir = 1.f; | 182 | mRelativeDir = 1.f; |
181 | mPelvisState.setPosition(LLVector3::zero); | 183 | mPelvisState->setPosition(LLVector3::zero); |
182 | // store ankle positions for next frame | 184 | // store ankle positions for next frame |
183 | mLastLeftAnklePos = mCharacter->getPosGlobalFromAgent(mLeftAnkleJoint->getWorldPosition()); | 185 | mLastLeftAnklePos = mCharacter->getPosGlobalFromAgent(mLeftAnkleJoint->getWorldPosition()); |
184 | mLastRightAnklePos = mCharacter->getPosGlobalFromAgent(mRightAnkleJoint->getWorldPosition()); | 186 | mLastRightAnklePos = mCharacter->getPosGlobalFromAgent(mRightAnkleJoint->getWorldPosition()); |
@@ -271,7 +273,7 @@ BOOL LLWalkAdjustMotion::onUpdate(F32 time, U8* joint_mask) | |||
271 | 273 | ||
272 | // calculate ideal pelvis offset so that foot is glued to ground and damp towards it | 274 | // calculate ideal pelvis offset so that foot is glued to ground and damp towards it |
273 | // the amount of foot slippage this frame + the offset applied last frame | 275 | // the amount of foot slippage this frame + the offset applied last frame |
274 | mPelvisOffset = mPelvisState.getPosition() + lerp(LLVector3::zero, footCorrection, LLCriticalDamp::getInterpolant(0.2f)); | 276 | mPelvisOffset = mPelvisState->getPosition() + lerp(LLVector3::zero, footCorrection, LLCriticalDamp::getInterpolant(0.2f)); |
275 | 277 | ||
276 | // pelvis drift (along walk direction) | 278 | // pelvis drift (along walk direction) |
277 | mAvgCorrection = lerp(mAvgCorrection, footCorrection.mV[VX] * mRelativeDir, LLCriticalDamp::getInterpolant(0.1f)); | 279 | mAvgCorrection = lerp(mAvgCorrection, footCorrection.mV[VX] * mRelativeDir, LLCriticalDamp::getInterpolant(0.1f)); |
@@ -319,7 +321,7 @@ BOOL LLWalkAdjustMotion::onUpdate(F32 time, U8* joint_mask) | |||
319 | F32 drift_comp_max = llclamp(speed, 0.f, DRIFT_COMP_MAX_SPEED) / DRIFT_COMP_MAX_SPEED; | 321 | F32 drift_comp_max = llclamp(speed, 0.f, DRIFT_COMP_MAX_SPEED) / DRIFT_COMP_MAX_SPEED; |
320 | drift_comp_max *= DRIFT_COMP_MAX_TOTAL; | 322 | drift_comp_max *= DRIFT_COMP_MAX_TOTAL; |
321 | 323 | ||
322 | LLVector3 currentPelvisPos = mPelvisState.getJoint()->getPosition(); | 324 | LLVector3 currentPelvisPos = mPelvisState->getJoint()->getPosition(); |
323 | 325 | ||
324 | // NB: this is an ADDITIVE amount that is accumulated every frame, so clamping it alone won't do the trick | 326 | // NB: this is an ADDITIVE amount that is accumulated every frame, so clamping it alone won't do the trick |
325 | // must clamp with absolute position of pelvis in mind | 327 | // must clamp with absolute position of pelvis in mind |
@@ -328,7 +330,7 @@ BOOL LLWalkAdjustMotion::onUpdate(F32 time, U8* joint_mask) | |||
328 | mPelvisOffset.mV[VZ] = 0.f; | 330 | mPelvisOffset.mV[VZ] = 0.f; |
329 | 331 | ||
330 | // set position | 332 | // set position |
331 | mPelvisState.setPosition(mPelvisOffset); | 333 | mPelvisState->setPosition(mPelvisOffset); |
332 | 334 | ||
333 | mCharacter->setAnimationData("Pelvis Offset", &mPelvisOffset); | 335 | mCharacter->setAnimationData("Pelvis Offset", &mPelvisOffset); |
334 | 336 | ||
@@ -344,6 +346,17 @@ void LLWalkAdjustMotion::onDeactivate() | |||
344 | } | 346 | } |
345 | 347 | ||
346 | //----------------------------------------------------------------------------- | 348 | //----------------------------------------------------------------------------- |
349 | // LLFlyAdjustMotion::LLFlyAdjustMotion() | ||
350 | //----------------------------------------------------------------------------- | ||
351 | LLFlyAdjustMotion::LLFlyAdjustMotion(const LLUUID &id) | ||
352 | : LLMotion(id) | ||
353 | { | ||
354 | mName = "fly_adjust"; | ||
355 | |||
356 | mPelvisState = new LLJointState; | ||
357 | } | ||
358 | |||
359 | //----------------------------------------------------------------------------- | ||
347 | // LLFlyAdjustMotion::onInitialize() | 360 | // LLFlyAdjustMotion::onInitialize() |
348 | //----------------------------------------------------------------------------- | 361 | //----------------------------------------------------------------------------- |
349 | LLMotion::LLMotionInitStatus LLFlyAdjustMotion::onInitialize(LLCharacter *character) | 362 | LLMotion::LLMotionInitStatus LLFlyAdjustMotion::onInitialize(LLCharacter *character) |
@@ -351,15 +364,15 @@ LLMotion::LLMotionInitStatus LLFlyAdjustMotion::onInitialize(LLCharacter *charac | |||
351 | mCharacter = character; | 364 | mCharacter = character; |
352 | 365 | ||
353 | LLJoint* pelvisJoint = mCharacter->getJoint("mPelvis"); | 366 | LLJoint* pelvisJoint = mCharacter->getJoint("mPelvis"); |
354 | mPelvisState.setJoint( pelvisJoint ); | 367 | mPelvisState->setJoint( pelvisJoint ); |
355 | if ( !pelvisJoint ) | 368 | if ( !pelvisJoint ) |
356 | { | 369 | { |
357 | llwarns << getName() << ": Can't get pelvis joint." << llendl; | 370 | llwarns << getName() << ": Can't get pelvis joint." << llendl; |
358 | return STATUS_FAILURE; | 371 | return STATUS_FAILURE; |
359 | } | 372 | } |
360 | 373 | ||
361 | mPelvisState.setUsage(LLJointState::POS | LLJointState::ROT); | 374 | mPelvisState->setUsage(LLJointState::POS | LLJointState::ROT); |
362 | addJointState( &mPelvisState ); | 375 | addJointState( mPelvisState ); |
363 | 376 | ||
364 | return STATUS_SUCCESS; | 377 | return STATUS_SUCCESS; |
365 | } | 378 | } |
@@ -369,8 +382,8 @@ LLMotion::LLMotionInitStatus LLFlyAdjustMotion::onInitialize(LLCharacter *charac | |||
369 | //----------------------------------------------------------------------------- | 382 | //----------------------------------------------------------------------------- |
370 | BOOL LLFlyAdjustMotion::onActivate() | 383 | BOOL LLFlyAdjustMotion::onActivate() |
371 | { | 384 | { |
372 | mPelvisState.setPosition(LLVector3::zero); | 385 | mPelvisState->setPosition(LLVector3::zero); |
373 | mPelvisState.setRotation(LLQuaternion::DEFAULT); | 386 | mPelvisState->setRotation(LLQuaternion::DEFAULT); |
374 | mRoll = 0.f; | 387 | mRoll = 0.f; |
375 | return TRUE; | 388 | return TRUE; |
376 | } | 389 | } |
@@ -392,11 +405,11 @@ BOOL LLFlyAdjustMotion::onUpdate(F32 time, U8* joint_mask) | |||
392 | // llinfos << mRoll << llendl; | 405 | // llinfos << mRoll << llendl; |
393 | 406 | ||
394 | LLQuaternion roll(mRoll, LLVector3(0.f, 0.f, 1.f)); | 407 | LLQuaternion roll(mRoll, LLVector3(0.f, 0.f, 1.f)); |
395 | mPelvisState.setRotation(roll); | 408 | mPelvisState->setRotation(roll); |
396 | 409 | ||
397 | // F32 lerp_amt = LLCriticalDamp::getInterpolant(0.2f); | 410 | // F32 lerp_amt = LLCriticalDamp::getInterpolant(0.2f); |
398 | // | 411 | // |
399 | // LLVector3 pelvis_correction = mPelvisState.getPosition() - lerp(LLVector3::zero, mPelvisState.getJoint()->getPosition() + mPelvisState.getPosition(), lerp_amt); | 412 | // LLVector3 pelvis_correction = mPelvisState->getPosition() - lerp(LLVector3::zero, mPelvisState->getJoint()->getPosition() + mPelvisState->getPosition(), lerp_amt); |
400 | // mPelvisState.setPosition(pelvis_correction); | 413 | // mPelvisState->setPosition(pelvis_correction); |
401 | return TRUE; | 414 | return TRUE; |
402 | } | 415 | } |
diff --git a/linden/indra/llcharacter/llkeyframewalkmotion.h b/linden/indra/llcharacter/llkeyframewalkmotion.h index 3c5a0cb..1a4e39f 100644 --- a/linden/indra/llcharacter/llkeyframewalkmotion.h +++ b/linden/indra/llcharacter/llkeyframewalkmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -123,7 +123,7 @@ public: | |||
123 | LLCharacter *mCharacter; | 123 | LLCharacter *mCharacter; |
124 | LLJoint* mLeftAnkleJoint; | 124 | LLJoint* mLeftAnkleJoint; |
125 | LLJoint* mRightAnkleJoint; | 125 | LLJoint* mRightAnkleJoint; |
126 | LLJointState mPelvisState; | 126 | LLPointer<LLJointState> mPelvisState; |
127 | LLJoint* mPelvisJoint; | 127 | LLJoint* mPelvisJoint; |
128 | LLVector3d mLastLeftAnklePos; | 128 | LLVector3d mLastLeftAnklePos; |
129 | LLVector3d mLastRightAnklePos; | 129 | LLVector3d mLastRightAnklePos; |
@@ -141,7 +141,7 @@ class LLFlyAdjustMotion : public LLMotion | |||
141 | { | 141 | { |
142 | public: | 142 | public: |
143 | // Constructor | 143 | // Constructor |
144 | LLFlyAdjustMotion(const LLUUID &id) : LLMotion(id) {mName = "fly_adjust";} | 144 | LLFlyAdjustMotion(const LLUUID &id); |
145 | 145 | ||
146 | public: | 146 | public: |
147 | //------------------------------------------------------------------------- | 147 | //------------------------------------------------------------------------- |
@@ -173,7 +173,7 @@ protected: | |||
173 | // Member Data | 173 | // Member Data |
174 | //------------------------------------------------------------------------- | 174 | //------------------------------------------------------------------------- |
175 | LLCharacter *mCharacter; | 175 | LLCharacter *mCharacter; |
176 | LLJointState mPelvisState; | 176 | LLPointer<LLJointState> mPelvisState; |
177 | F32 mRoll; | 177 | F32 mRoll; |
178 | }; | 178 | }; |
179 | 179 | ||
diff --git a/linden/indra/llcharacter/llmotion.cpp b/linden/indra/llcharacter/llmotion.cpp index aa5e542..899796c 100644 --- a/linden/indra/llcharacter/llmotion.cpp +++ b/linden/indra/llcharacter/llmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -106,7 +106,7 @@ void LLMotion::fadeIn() | |||
106 | //----------------------------------------------------------------------------- | 106 | //----------------------------------------------------------------------------- |
107 | // addJointState() | 107 | // addJointState() |
108 | //----------------------------------------------------------------------------- | 108 | //----------------------------------------------------------------------------- |
109 | void LLMotion::addJointState(LLJointState* jointState) | 109 | void LLMotion::addJointState(const LLPointer<LLJointState>& jointState) |
110 | { | 110 | { |
111 | mPose.addJointState(jointState); | 111 | mPose.addJointState(jointState); |
112 | S32 priority = jointState->getPriority(); | 112 | S32 priority = jointState->getPriority(); |
diff --git a/linden/indra/llcharacter/llmotion.h b/linden/indra/llcharacter/llmotion.h index 1d21edc..188937d 100644 --- a/linden/indra/llcharacter/llmotion.h +++ b/linden/indra/llcharacter/llmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -163,7 +163,7 @@ protected: | |||
163 | // it will be deactivated | 163 | // it will be deactivated |
164 | virtual BOOL onActivate() = 0; | 164 | virtual BOOL onActivate() = 0; |
165 | 165 | ||
166 | void addJointState(LLJointState* jointState); | 166 | void addJointState(const LLPointer<LLJointState>& jointState); |
167 | 167 | ||
168 | protected: | 168 | protected: |
169 | LLPose mPose; | 169 | LLPose mPose; |
diff --git a/linden/indra/llcharacter/llmotioncontroller.cpp b/linden/indra/llcharacter/llmotioncontroller.cpp index 8dc90b8..d1a2a53 100644 --- a/linden/indra/llcharacter/llmotioncontroller.cpp +++ b/linden/indra/llcharacter/llmotioncontroller.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llmotioncontroller.h b/linden/indra/llcharacter/llmotioncontroller.h index 76f5c68..e66edcb 100644 --- a/linden/indra/llcharacter/llmotioncontroller.h +++ b/linden/indra/llcharacter/llmotioncontroller.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llmultigesture.cpp b/linden/indra/llcharacter/llmultigesture.cpp index 080627a..02016a0 100644 --- a/linden/indra/llcharacter/llmultigesture.cpp +++ b/linden/indra/llcharacter/llmultigesture.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llmultigesture.h b/linden/indra/llcharacter/llmultigesture.h index 23c9c0f..08748b7 100644 --- a/linden/indra/llcharacter/llmultigesture.h +++ b/linden/indra/llcharacter/llmultigesture.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llpose.cpp b/linden/indra/llcharacter/llpose.cpp index e74517f..3a6a221 100644 --- a/linden/indra/llcharacter/llpose.cpp +++ b/linden/indra/llcharacter/llpose.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -54,7 +54,7 @@ LLPose::~LLPose() | |||
54 | //----------------------------------------------------------------------------- | 54 | //----------------------------------------------------------------------------- |
55 | // getFirstJointState() | 55 | // getFirstJointState() |
56 | //----------------------------------------------------------------------------- | 56 | //----------------------------------------------------------------------------- |
57 | LLJointState *LLPose::getFirstJointState() | 57 | LLJointState* LLPose::getFirstJointState() |
58 | { | 58 | { |
59 | mListIter = mJointMap.begin(); | 59 | mListIter = mJointMap.begin(); |
60 | if (mListIter == mJointMap.end()) | 60 | if (mListIter == mJointMap.end()) |
@@ -86,7 +86,7 @@ LLJointState *LLPose::getNextJointState() | |||
86 | //----------------------------------------------------------------------------- | 86 | //----------------------------------------------------------------------------- |
87 | // addJointState() | 87 | // addJointState() |
88 | //----------------------------------------------------------------------------- | 88 | //----------------------------------------------------------------------------- |
89 | BOOL LLPose::addJointState(LLJointState *jointState) | 89 | BOOL LLPose::addJointState(const LLPointer<LLJointState>& jointState) |
90 | { | 90 | { |
91 | if (mJointMap.find(jointState->getJoint()->getName()) == mJointMap.end()) | 91 | if (mJointMap.find(jointState->getJoint()->getName()) == mJointMap.end()) |
92 | { | 92 | { |
@@ -98,7 +98,7 @@ BOOL LLPose::addJointState(LLJointState *jointState) | |||
98 | //----------------------------------------------------------------------------- | 98 | //----------------------------------------------------------------------------- |
99 | // removeJointState() | 99 | // removeJointState() |
100 | //----------------------------------------------------------------------------- | 100 | //----------------------------------------------------------------------------- |
101 | BOOL LLPose::removeJointState(LLJointState *jointState) | 101 | BOOL LLPose::removeJointState(const LLPointer<LLJointState>& jointState) |
102 | { | 102 | { |
103 | mJointMap.erase(jointState->getJoint()->getName()); | 103 | mJointMap.erase(jointState->getJoint()->getName()); |
104 | return TRUE; | 104 | return TRUE; |
@@ -199,7 +199,7 @@ LLJointStateBlender::~LLJointStateBlender() | |||
199 | //----------------------------------------------------------------------------- | 199 | //----------------------------------------------------------------------------- |
200 | // addJointState() | 200 | // addJointState() |
201 | //----------------------------------------------------------------------------- | 201 | //----------------------------------------------------------------------------- |
202 | BOOL LLJointStateBlender::addJointState(LLJointState *joint_state, S32 priority, BOOL additive_blend) | 202 | BOOL LLJointStateBlender::addJointState(const LLPointer<LLJointState>& joint_state, S32 priority, BOOL additive_blend) |
203 | { | 203 | { |
204 | llassert(joint_state); | 204 | llassert(joint_state); |
205 | 205 | ||
@@ -209,7 +209,7 @@ BOOL LLJointStateBlender::addJointState(LLJointState *joint_state, S32 priority, | |||
209 | 209 | ||
210 | for(S32 i = 0; i < JSB_NUM_JOINT_STATES; i++) | 210 | for(S32 i = 0; i < JSB_NUM_JOINT_STATES; i++) |
211 | { | 211 | { |
212 | if (NULL == mJointStates[i]) | 212 | if (mJointStates[i].isNull()) |
213 | { | 213 | { |
214 | mJointStates[i] = joint_state; | 214 | mJointStates[i] = joint_state; |
215 | mPriorities[i] = priority; | 215 | mPriorities[i] = priority; |
@@ -246,7 +246,7 @@ void LLJointStateBlender::blendJointStates(BOOL apply_now) | |||
246 | // we need at least one joint to blend | 246 | // we need at least one joint to blend |
247 | // if there is one, it will be in slot zero according to insertion logic | 247 | // if there is one, it will be in slot zero according to insertion logic |
248 | // instead of resetting joint state to default, just leave it unchanged from last frame | 248 | // instead of resetting joint state to default, just leave it unchanged from last frame |
249 | if (NULL == mJointStates[0]) | 249 | if (mJointStates[0].isNull()) |
250 | { | 250 | { |
251 | return; | 251 | return; |
252 | } | 252 | } |
@@ -275,7 +275,7 @@ void LLJointStateBlender::blendJointStates(BOOL apply_now) | |||
275 | sum_weights[SCALE_WEIGHT] = 0.f; | 275 | sum_weights[SCALE_WEIGHT] = 0.f; |
276 | 276 | ||
277 | for(S32 joint_state_index = 0; | 277 | for(S32 joint_state_index = 0; |
278 | joint_state_index < JSB_NUM_JOINT_STATES && mJointStates[joint_state_index] != NULL; | 278 | joint_state_index < JSB_NUM_JOINT_STATES && mJointStates[joint_state_index].notNull(); |
279 | joint_state_index++) | 279 | joint_state_index++) |
280 | { | 280 | { |
281 | LLJointState* jsp = mJointStates[joint_state_index]; | 281 | LLJointState* jsp = mJointStates[joint_state_index]; |
@@ -468,7 +468,7 @@ BOOL LLPoseBlender::addMotion(LLMotion* motion) | |||
468 | { | 468 | { |
469 | LLPose* pose = motion->getPose(); | 469 | LLPose* pose = motion->getPose(); |
470 | 470 | ||
471 | for(LLJointState *jsp = pose->getFirstJointState(); jsp; jsp = pose->getNextJointState()) | 471 | for(LLJointState* jsp = pose->getFirstJointState(); jsp; jsp = pose->getNextJointState()) |
472 | { | 472 | { |
473 | LLJoint *jointp = jsp->getJoint(); | 473 | LLJoint *jointp = jsp->getJoint(); |
474 | LLJointStateBlender* joint_blender; | 474 | LLJointStateBlender* joint_blender; |
diff --git a/linden/indra/llcharacter/llpose.h b/linden/indra/llcharacter/llpose.h index 5ea586f..f67a26b 100644 --- a/linden/indra/llcharacter/llpose.h +++ b/linden/indra/llcharacter/llpose.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -52,7 +52,7 @@ class LLPose | |||
52 | { | 52 | { |
53 | friend class LLPoseBlender; | 53 | friend class LLPoseBlender; |
54 | protected: | 54 | protected: |
55 | typedef std::map<std::string, LLJointState*> joint_map; | 55 | typedef std::map<std::string, LLPointer<LLJointState> > joint_map; |
56 | typedef joint_map::iterator joint_map_iterator; | 56 | typedef joint_map::iterator joint_map_iterator; |
57 | typedef joint_map::value_type joint_map_value_type; | 57 | typedef joint_map::value_type joint_map_value_type; |
58 | 58 | ||
@@ -61,19 +61,19 @@ protected: | |||
61 | joint_map_iterator mListIter; | 61 | joint_map_iterator mListIter; |
62 | public: | 62 | public: |
63 | // Iterate through jointStates | 63 | // Iterate through jointStates |
64 | LLJointState *getFirstJointState(); | 64 | LLJointState* getFirstJointState(); |
65 | LLJointState *getNextJointState(); | 65 | LLJointState* getNextJointState(); |
66 | LLJointState *findJointState(LLJoint *joint); | 66 | LLJointState* findJointState(LLJoint *joint); |
67 | LLJointState *findJointState(const std::string &name); | 67 | LLJointState* findJointState(const std::string &name); |
68 | public: | 68 | public: |
69 | // Constructor | 69 | // Constructor |
70 | LLPose() : mWeight(0.f) {} | 70 | LLPose() : mWeight(0.f) {} |
71 | // Destructor | 71 | // Destructor |
72 | ~LLPose(); | 72 | ~LLPose(); |
73 | // add a joint state in this pose | 73 | // add a joint state in this pose |
74 | BOOL addJointState(LLJointState *jointState); | 74 | BOOL addJointState(const LLPointer<LLJointState>& jointState); |
75 | // remove a joint state from this pose | 75 | // remove a joint state from this pose |
76 | BOOL removeJointState(LLJointState *jointState); | 76 | BOOL removeJointState(const LLPointer<LLJointState>& jointState); |
77 | // removes all joint states from this pose | 77 | // removes all joint states from this pose |
78 | BOOL removeAllJointStates(); | 78 | BOOL removeAllJointStates(); |
79 | // set weight for all joint states in this pose | 79 | // set weight for all joint states in this pose |
@@ -89,14 +89,14 @@ const S32 JSB_NUM_JOINT_STATES = 6; | |||
89 | class LLJointStateBlender | 89 | class LLJointStateBlender |
90 | { | 90 | { |
91 | protected: | 91 | protected: |
92 | LLJointState* mJointStates[JSB_NUM_JOINT_STATES]; | 92 | LLPointer<LLJointState> mJointStates[JSB_NUM_JOINT_STATES]; |
93 | S32 mPriorities[JSB_NUM_JOINT_STATES]; | 93 | S32 mPriorities[JSB_NUM_JOINT_STATES]; |
94 | BOOL mAdditiveBlends[JSB_NUM_JOINT_STATES]; | 94 | BOOL mAdditiveBlends[JSB_NUM_JOINT_STATES]; |
95 | public: | 95 | public: |
96 | LLJointStateBlender(); | 96 | LLJointStateBlender(); |
97 | ~LLJointStateBlender(); | 97 | ~LLJointStateBlender(); |
98 | void blendJointStates(BOOL apply_now = TRUE); | 98 | void blendJointStates(BOOL apply_now = TRUE); |
99 | BOOL addJointState(LLJointState *joint_state, S32 priority, BOOL additive_blend); | 99 | BOOL addJointState(const LLPointer<LLJointState>& joint_state, S32 priority, BOOL additive_blend); |
100 | void interpolate(F32 u); | 100 | void interpolate(F32 u); |
101 | void clear(); | 101 | void clear(); |
102 | void resetCachedJoint(); | 102 | void resetCachedJoint(); |
diff --git a/linden/indra/llcharacter/llstatemachine.cpp b/linden/indra/llcharacter/llstatemachine.cpp index 47cdfff..eab6e7f 100644 --- a/linden/indra/llcharacter/llstatemachine.cpp +++ b/linden/indra/llcharacter/llstatemachine.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llstatemachine.h b/linden/indra/llcharacter/llstatemachine.h index a4d3145..f46e4bf 100644 --- a/linden/indra/llcharacter/llstatemachine.h +++ b/linden/indra/llcharacter/llstatemachine.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/lltargetingmotion.cpp b/linden/indra/llcharacter/lltargetingmotion.cpp index 1676a08..0f160a4 100644 --- a/linden/indra/llcharacter/lltargetingmotion.cpp +++ b/linden/indra/llcharacter/lltargetingmotion.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -55,6 +55,8 @@ LLTargetingMotion::LLTargetingMotion(const LLUUID &id) : LLMotion(id) | |||
55 | { | 55 | { |
56 | mCharacter = NULL; | 56 | mCharacter = NULL; |
57 | mName = "targeting"; | 57 | mName = "targeting"; |
58 | |||
59 | mTorsoState = new LLJointState; | ||
58 | } | 60 | } |
59 | 61 | ||
60 | 62 | ||
@@ -87,11 +89,11 @@ LLMotion::LLMotionInitStatus LLTargetingMotion::onInitialize(LLCharacter *charac | |||
87 | return STATUS_FAILURE; | 89 | return STATUS_FAILURE; |
88 | } | 90 | } |
89 | 91 | ||
90 | mTorsoState.setJoint( mTorsoJoint ); | 92 | mTorsoState->setJoint( mTorsoJoint ); |
91 | 93 | ||
92 | // add joint states to the pose | 94 | // add joint states to the pose |
93 | mTorsoState.setUsage(LLJointState::ROT); | 95 | mTorsoState->setUsage(LLJointState::ROT); |
94 | addJointState( &mTorsoState ); | 96 | addJointState( mTorsoState ); |
95 | 97 | ||
96 | return STATUS_SUCCESS; | 98 | return STATUS_SUCCESS; |
97 | } | 99 | } |
@@ -127,7 +129,7 @@ BOOL LLTargetingMotion::onUpdate(F32 time, U8* joint_mask) | |||
127 | } | 129 | } |
128 | 130 | ||
129 | //LLVector3 target_plane_normal = LLVector3(1.f, 0.f, 0.f) * mPelvisJoint->getWorldRotation(); | 131 | //LLVector3 target_plane_normal = LLVector3(1.f, 0.f, 0.f) * mPelvisJoint->getWorldRotation(); |
130 | //LLVector3 torso_dir = LLVector3(1.f, 0.f, 0.f) * (mTorsoJoint->getWorldRotation() * mTorsoState.getRotation()); | 132 | //LLVector3 torso_dir = LLVector3(1.f, 0.f, 0.f) * (mTorsoJoint->getWorldRotation() * mTorsoState->getRotation()); |
131 | 133 | ||
132 | LLVector3 skyward(0.f, 0.f, 1.f); | 134 | LLVector3 skyward(0.f, 0.f, 1.f); |
133 | LLVector3 left(skyward % target); | 135 | LLVector3 left(skyward % target); |
@@ -151,14 +153,14 @@ BOOL LLTargetingMotion::onUpdate(F32 time, U8* joint_mask) | |||
151 | new_torso_rot = new_torso_rot * ~cur_torso_rot; | 153 | new_torso_rot = new_torso_rot * ~cur_torso_rot; |
152 | 154 | ||
153 | // slerp from current additive rotation to ideal additive rotation | 155 | // slerp from current additive rotation to ideal additive rotation |
154 | new_torso_rot = nlerp(slerp_amt, mTorsoState.getRotation(), new_torso_rot); | 156 | new_torso_rot = nlerp(slerp_amt, mTorsoState->getRotation(), new_torso_rot); |
155 | 157 | ||
156 | // constraint overall torso rotation | 158 | // constraint overall torso rotation |
157 | LLQuaternion total_rot = new_torso_rot * mTorsoJoint->getRotation(); | 159 | LLQuaternion total_rot = new_torso_rot * mTorsoJoint->getRotation(); |
158 | total_rot.constrain(F_PI_BY_TWO * 0.8f); | 160 | total_rot.constrain(F_PI_BY_TWO * 0.8f); |
159 | new_torso_rot = total_rot * ~mTorsoJoint->getRotation(); | 161 | new_torso_rot = total_rot * ~mTorsoJoint->getRotation(); |
160 | 162 | ||
161 | mTorsoState.setRotation(new_torso_rot); | 163 | mTorsoState->setRotation(new_torso_rot); |
162 | 164 | ||
163 | return result; | 165 | return result; |
164 | } | 166 | } |
diff --git a/linden/indra/llcharacter/lltargetingmotion.h b/linden/indra/llcharacter/lltargetingmotion.h index 1436c21..e83fb00 100644 --- a/linden/indra/llcharacter/lltargetingmotion.h +++ b/linden/indra/llcharacter/lltargetingmotion.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
@@ -111,7 +111,7 @@ public: | |||
111 | public: | 111 | public: |
112 | 112 | ||
113 | LLCharacter *mCharacter; | 113 | LLCharacter *mCharacter; |
114 | LLJointState mTorsoState; | 114 | LLPointer<LLJointState> mTorsoState; |
115 | LLJoint* mPelvisJoint; | 115 | LLJoint* mPelvisJoint; |
116 | LLJoint* mTorsoJoint; | 116 | LLJoint* mTorsoJoint; |
117 | LLJoint* mRightHandJoint; | 117 | LLJoint* mRightHandJoint; |
diff --git a/linden/indra/llcharacter/llvisualparam.cpp b/linden/indra/llcharacter/llvisualparam.cpp index d14664e..00b1072 100644 --- a/linden/indra/llcharacter/llvisualparam.cpp +++ b/linden/indra/llcharacter/llvisualparam.cpp | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |
diff --git a/linden/indra/llcharacter/llvisualparam.h b/linden/indra/llcharacter/llvisualparam.h index 177d08c..41b8a05 100644 --- a/linden/indra/llcharacter/llvisualparam.h +++ b/linden/indra/llcharacter/llvisualparam.h | |||
@@ -12,12 +12,12 @@ | |||
12 | * ("GPL"), unless you have obtained a separate licensing agreement | 12 | * ("GPL"), unless you have obtained a separate licensing agreement |
13 | * ("Other License"), formally executed by you and Linden Lab. Terms of | 13 | * ("Other License"), formally executed by you and Linden Lab. Terms of |
14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | 14 | * the GPL can be found in doc/GPL-license.txt in this distribution, or |
15 | * online at http://secondlife.com/developers/opensource/gplv2 | 15 | * online at http://secondlifegrid.net/programs/open_source/licensing/gplv2 |
16 | * | 16 | * |
17 | * There are special exceptions to the terms and conditions of the GPL as | 17 | * There are special exceptions to the terms and conditions of the GPL as |
18 | * it is applied to this Source Code. View the full text of the exception | 18 | * it is applied to this Source Code. View the full text of the exception |
19 | * in the file doc/FLOSS-exception.txt in this software distribution, or | 19 | * in the file doc/FLOSS-exception.txt in this software distribution, or |
20 | * online at http://secondlife.com/developers/opensource/flossexception | 20 | * online at http://secondlifegrid.net/programs/open_source/licensing/flossexception |
21 | * | 21 | * |
22 | * By copying, modifying or distributing this software, you acknowledge | 22 | * By copying, modifying or distributing this software, you acknowledge |
23 | * that you have read and understood your obligations described above, | 23 | * that you have read and understood your obligations described above, |