aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llcharacter/llmotioncontroller.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llcharacter/llmotioncontroller.cpp122
1 files changed, 47 insertions, 75 deletions
diff --git a/linden/indra/llcharacter/llmotioncontroller.cpp b/linden/indra/llcharacter/llmotioncontroller.cpp
index 3e1456b..5545841 100644
--- a/linden/indra/llcharacter/llmotioncontroller.cpp
+++ b/linden/indra/llcharacter/llmotioncontroller.cpp
@@ -4,6 +4,7 @@
4 * 4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc. 5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 * 6 *
7 * Second Life Viewer Source Code
7 * The source code in this file ("Source Code") is provided by Linden Lab 8 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0 9 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement 10 * ("GPL"), unless you have obtained a separate licensing agreement
@@ -180,9 +181,9 @@ LLMotionController::~LLMotionController()
180//----------------------------------------------------------------------------- 181//-----------------------------------------------------------------------------
181void LLMotionController::deleteAllMotions() 182void LLMotionController::deleteAllMotions()
182{ 183{
183 mLoadingMotions.removeAllNodes(); 184 mLoadingMotions.clear();
184 mLoadedMotions.clear(); 185 mLoadedMotions.clear();
185 mActiveMotions.removeAllNodes(); 186 mActiveMotions.clear();
186 187
187 for_each(mAllMotions.begin(), mAllMotions.end(), DeletePairedPointer()); 188 for_each(mAllMotions.begin(), mAllMotions.end(), DeletePairedPointer());
188 mAllMotions.clear(); 189 mAllMotions.clear();
@@ -234,16 +235,16 @@ void LLMotionController::setTimeStep(F32 step)
234 if (step != 0.f) 235 if (step != 0.f)
235 { 236 {
236 // make sure timestamps conform to new quantum 237 // make sure timestamps conform to new quantum
237 for( LLMotion* motionp = mActiveMotions.getFirstData(); 238 for (motion_list_t::iterator iter = mActiveMotions.begin();
238 motionp != NULL; 239 iter != mActiveMotions.end(); ++iter)
239 motionp = mActiveMotions.getNextData() ) 240 {
240 { 241 LLMotion* motionp = *iter;
241 motionp->mActivationTimestamp = (F32)llfloor(motionp->mActivationTimestamp / step) * step; 242 motionp->mActivationTimestamp = (F32)llfloor(motionp->mActivationTimestamp / step) * step;
242 BOOL stopped = motionp->isStopped(); 243 BOOL stopped = motionp->isStopped();
243 motionp->setStopTime((F32)llfloor(motionp->getStopTime() / step) * step); 244 motionp->setStopTime((F32)llfloor(motionp->getStopTime() / step) * step);
244 motionp->setStopped(stopped); 245 motionp->setStopped(stopped);
245 motionp->mSendStopTimestamp = (F32)llfloor(motionp->mSendStopTimestamp / step) * step; 246 motionp->mSendStopTimestamp = (F32)llfloor(motionp->mSendStopTimestamp / step) * step;
246 } 247 }
247 } 248 }
248} 249}
249 250
@@ -257,23 +258,6 @@ void LLMotionController::setTimeFactor(F32 time_factor)
257} 258}
258 259
259//----------------------------------------------------------------------------- 260//-----------------------------------------------------------------------------
260// getFirstActiveMotion()
261//-----------------------------------------------------------------------------
262LLMotion* LLMotionController::getFirstActiveMotion()
263{
264 return mActiveMotions.getFirstData();
265}
266
267//-----------------------------------------------------------------------------
268// getNextActiveMotion()
269//-----------------------------------------------------------------------------
270LLMotion* LLMotionController::getNextActiveMotion()
271{
272 return mActiveMotions.getNextData();
273}
274
275
276//-----------------------------------------------------------------------------
277// setCharacter() 261// setCharacter()
278//----------------------------------------------------------------------------- 262//-----------------------------------------------------------------------------
279void LLMotionController::setCharacter(LLCharacter *character) 263void LLMotionController::setCharacter(LLCharacter *character)
@@ -300,17 +284,9 @@ void LLMotionController::removeMotion( const LLUUID& id)
300 { 284 {
301 stopMotionLocally(id, TRUE); 285 stopMotionLocally(id, TRUE);
302 286
303 mLoadingMotions.deleteData(motionp); 287 mLoadingMotions.erase(motionp);
304 std::deque<LLMotion*>::iterator motion_it; 288 mLoadedMotions.remove(motionp);
305 for (motion_it = mLoadedMotions.begin(); motion_it != mLoadedMotions.end(); ++motion_it) 289 mActiveMotions.remove(motionp);
306 {
307 if(*motion_it == motionp)
308 {
309 mLoadedMotions.erase(motion_it);
310 break;
311 }
312 }
313 mActiveMotions.deleteData(motionp);
314 mAllMotions.erase(id); 290 mAllMotions.erase(id);
315 delete motionp; 291 delete motionp;
316 } 292 }
@@ -351,7 +327,7 @@ LLMotion* LLMotionController::createMotion( const LLUUID &id )
351 delete motion; 327 delete motion;
352 return NULL; 328 return NULL;
353 case LLMotion::STATUS_HOLD: 329 case LLMotion::STATUS_HOLD:
354 mLoadingMotions.addData(motion); 330 mLoadingMotions.insert(motion);
355 break; 331 break;
356 case LLMotion::STATUS_SUCCESS: 332 case LLMotion::STATUS_SUCCESS:
357 // add motion to our list 333 // add motion to our list
@@ -470,10 +446,11 @@ void LLMotionController::updateMotionsByType(LLMotion::LLMotionBlendType anim_ty
470 memset(&last_joint_signature, 0, sizeof(U8) * LL_CHARACTER_MAX_JOINTS); 446 memset(&last_joint_signature, 0, sizeof(U8) * LL_CHARACTER_MAX_JOINTS);
471 447
472 // iterate through active motions in chronological order 448 // iterate through active motions in chronological order
473 for(LLMotion* motionp = mActiveMotions.getFirstData(); 449 for (motion_list_t::iterator iter = mActiveMotions.begin();
474 motionp != NULL; 450 iter != mActiveMotions.end(); )
475 motionp = mActiveMotions.getNextData())
476 { 451 {
452 motion_list_t::iterator curiter = iter++;
453 LLMotion* motionp = *curiter;
477 if (motionp->getBlendType() != anim_type) 454 if (motionp->getBlendType() != anim_type)
478 { 455 {
479 continue; 456 continue;
@@ -487,9 +464,8 @@ void LLMotionController::updateMotionsByType(LLMotion::LLMotionBlendType anim_ty
487 } 464 }
488 else 465 else
489 { 466 {
490 S32 i;
491 // NUM_JOINT_SIGNATURE_STRIDES should be multiple of 4 467 // NUM_JOINT_SIGNATURE_STRIDES should be multiple of 4
492 for (i = 0; i < NUM_JOINT_SIGNATURE_STRIDES; i++) 468 for (S32 i = 0; i < NUM_JOINT_SIGNATURE_STRIDES; i++)
493 { 469 {
494 U32 *current_signature = (U32*)&(mJointSignature[0][i * 4]); 470 U32 *current_signature = (U32*)&(mJointSignature[0][i * 4]);
495 U32 test_signature = *(U32*)&(motionp->mJointSignature[0][i * 4]); 471 U32 test_signature = *(U32*)&(motionp->mJointSignature[0][i * 4]);
@@ -745,16 +721,15 @@ void LLMotionController::updateMotion()
745 } 721 }
746 722
747 // query pending motions for completion 723 // query pending motions for completion
748 LLMotion* motionp; 724 for (motion_set_t::iterator iter = mLoadingMotions.begin();
749 725 iter != mLoadingMotions.end(); )
750 for ( motionp = mLoadingMotions.getFirstData();
751 motionp != NULL;
752 motionp = mLoadingMotions.getNextData() )
753 { 726 {
727 motion_set_t::iterator curiter = iter++;
728 LLMotion* motionp = *curiter;
754 LLMotion::LLMotionInitStatus status = motionp->onInitialize(mCharacter); 729 LLMotion::LLMotionInitStatus status = motionp->onInitialize(mCharacter);
755 if (status == LLMotion::STATUS_SUCCESS) 730 if (status == LLMotion::STATUS_SUCCESS)
756 { 731 {
757 mLoadingMotions.removeCurrentData(); 732 mLoadingMotions.erase(curiter);
758 // add motion to our loaded motion list 733 // add motion to our loaded motion list
759 addLoadedMotion(motionp); 734 addLoadedMotion(motionp);
760 // this motion should be playing 735 // this motion should be playing
@@ -767,7 +742,7 @@ void LLMotionController::updateMotion()
767 { 742 {
768 llinfos << "Motion " << motionp->getID() << " init failed." << llendl; 743 llinfos << "Motion " << motionp->getID() << " init failed." << llendl;
769 sRegistry.markBad(motionp->getID()); 744 sRegistry.markBad(motionp->getID());
770 mLoadingMotions.removeCurrentData(); 745 mLoadingMotions.erase(curiter);
771 mAllMotions.erase(motionp->getID()); 746 mAllMotions.erase(motionp->getID());
772 delete motionp; 747 delete motionp;
773 } 748 }
@@ -804,7 +779,7 @@ void LLMotionController::updateMotion()
804//----------------------------------------------------------------------------- 779//-----------------------------------------------------------------------------
805BOOL LLMotionController::activateMotion(LLMotion *motion, F32 time) 780BOOL LLMotionController::activateMotion(LLMotion *motion, F32 time)
806{ 781{
807 if (mLoadingMotions.checkData(motion)) 782 if (mLoadingMotions.find(motion) != mLoadingMotions.end())
808 { 783 {
809 // we want to start this motion, but we can't yet, so flag it as started 784 // we want to start this motion, but we can't yet, so flag it as started
810 motion->setStopped(FALSE); 785 motion->setStopped(FALSE);
@@ -835,7 +810,8 @@ BOOL LLMotionController::activateMotion(LLMotion *motion, F32 time)
835 motion->mSendStopTimestamp = F32_MAX; 810 motion->mSendStopTimestamp = F32_MAX;
836 } 811 }
837 812
838 mActiveMotions.addData(motion); 813 mActiveMotions.remove(motion); // in case it is already in the active list
814 mActiveMotions.push_front(motion);
839 815
840 motion->activate(); 816 motion->activate();
841 motion->onUpdate(0.f, mJointSignature[1]); 817 motion->onUpdate(0.f, mJointSignature[1]);
@@ -849,7 +825,7 @@ BOOL LLMotionController::activateMotion(LLMotion *motion, F32 time)
849BOOL LLMotionController::deactivateMotion(LLMotion *motion) 825BOOL LLMotionController::deactivateMotion(LLMotion *motion)
850{ 826{
851 motion->deactivate(); 827 motion->deactivate();
852 mActiveMotions.removeData(motion); 828 mActiveMotions.remove(motion);
853 829
854 return TRUE; 830 return TRUE;
855} 831}
@@ -857,22 +833,17 @@ BOOL LLMotionController::deactivateMotion(LLMotion *motion)
857//----------------------------------------------------------------------------- 833//-----------------------------------------------------------------------------
858// isMotionActive() 834// isMotionActive()
859//----------------------------------------------------------------------------- 835//-----------------------------------------------------------------------------
860BOOL LLMotionController::isMotionActive(LLMotion *motion) 836bool LLMotionController::isMotionActive(LLMotion *motion)
861{ 837{
862 if (motion && motion->isActive()) 838 return (motion && motion->isActive());
863 {
864 return TRUE;
865 }
866
867 return FALSE;
868} 839}
869 840
870//----------------------------------------------------------------------------- 841//-----------------------------------------------------------------------------
871// isMotionLoading() 842// isMotionLoading()
872//----------------------------------------------------------------------------- 843//-----------------------------------------------------------------------------
873BOOL LLMotionController::isMotionLoading(LLMotion* motion) 844bool LLMotionController::isMotionLoading(LLMotion* motion)
874{ 845{
875 return mLoadingMotions.checkData(motion); 846 return (mLoadingMotions.find(motion) != mLoadingMotions.end());
876} 847}
877 848
878 849
@@ -890,15 +861,15 @@ LLMotion *LLMotionController::findMotion(const LLUUID& id)
890//----------------------------------------------------------------------------- 861//-----------------------------------------------------------------------------
891void LLMotionController::flushAllMotions() 862void LLMotionController::flushAllMotions()
892{ 863{
893 LLDynamicArray<LLUUID> active_motions; 864 std::vector<std::pair<LLUUID,F32> > active_motions;
894 LLDynamicArray<F32> active_motion_times; 865 active_motions.reserve(mActiveMotions.size());
895 866 for (motion_list_t::iterator iter = mActiveMotions.begin();
896 for (LLMotion* motionp = mActiveMotions.getFirstData(); 867 iter != mActiveMotions.end(); )
897 motionp;
898 motionp = mActiveMotions.getNextData())
899 { 868 {
900 active_motions.put(motionp->getID()); 869 motion_list_t::iterator curiter = iter++;
901 active_motion_times.put(mTime - motionp->mActivationTimestamp); 870 LLMotion* motionp = *curiter;
871 F32 dtime = mTime - motionp->mActivationTimestamp;
872 active_motions.push_back(std::make_pair(motionp->getID(),dtime));
902 motionp->deactivate(); 873 motionp->deactivate();
903 } 874 }
904 875
@@ -910,9 +881,10 @@ void LLMotionController::flushAllMotions()
910 mCharacter->removeAnimationData("Hand Pose"); 881 mCharacter->removeAnimationData("Hand Pose");
911 882
912 // restart motions 883 // restart motions
913 for (S32 i = 0; i < active_motions.count(); i++) 884 for (std::vector<std::pair<LLUUID,F32> >::iterator iter = active_motions.begin();
885 iter != active_motions.end(); ++iter)
914 { 886 {
915 startMotion(active_motions[i], active_motion_times[i]); 887 startMotion(iter->first, iter->second);
916 } 888 }
917} 889}
918 890