aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--OpenSim/Region/Framework/Scenes/Animation/ScenePresenceAnimator.cs167
1 files changed, 97 insertions, 70 deletions
diff --git a/OpenSim/Region/Framework/Scenes/Animation/ScenePresenceAnimator.cs b/OpenSim/Region/Framework/Scenes/Animation/ScenePresenceAnimator.cs
index 1017c1d..56b8b30 100644
--- a/OpenSim/Region/Framework/Scenes/Animation/ScenePresenceAnimator.cs
+++ b/OpenSim/Region/Framework/Scenes/Animation/ScenePresenceAnimator.cs
@@ -48,7 +48,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
48 48
49 public AnimationSet Animations 49 public AnimationSet Animations
50 { 50 {
51 get { return m_animations; } 51 get { return m_animations; }
52 } 52 }
53 protected AnimationSet m_animations = new AnimationSet(); 53 protected AnimationSet m_animations = new AnimationSet();
54 54
@@ -61,9 +61,9 @@ namespace OpenSim.Region.Framework.Scenes.Animation
61 private int m_animTickLand; 61 private int m_animTickLand;
62 private int m_animTickJump; 62 private int m_animTickJump;
63 63
64 public bool m_jumping = false; 64 public bool m_jumping = false;
65 65
66// private int m_landing = 0; 66 // private int m_landing = 0;
67 67
68 /// <summary> 68 /// <summary>
69 /// Is the avatar falling? 69 /// Is the avatar falling?
@@ -76,7 +76,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
76 /// The scene presence that this animator applies to 76 /// The scene presence that this animator applies to
77 /// </value> 77 /// </value>
78 protected ScenePresence m_scenePresence; 78 protected ScenePresence m_scenePresence;
79 79
80 public ScenePresenceAnimator(ScenePresence sp) 80 public ScenePresenceAnimator(ScenePresence sp)
81 { 81 {
82 m_scenePresence = sp; 82 m_scenePresence = sp;
@@ -91,7 +91,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
91 // m_log.DebugFormat("[SCENE PRESENCE ANIMATOR]: Adding animation {0} for {1}", animID, m_scenePresence.Name); 91 // m_log.DebugFormat("[SCENE PRESENCE ANIMATOR]: Adding animation {0} for {1}", animID, m_scenePresence.Name);
92 if (m_scenePresence.Scene.DebugAnimations) 92 if (m_scenePresence.Scene.DebugAnimations)
93 m_log.DebugFormat( 93 m_log.DebugFormat(
94 "[SCENE PRESENCE ANIMATOR]: Adding animation {0} {1} for {2}", 94 "[SCENE PRESENCE ANIMATOR]: Adding animation {0} {1} for {2}",
95 GetAnimName(animID), animID, m_scenePresence.Name); 95 GetAnimName(animID), animID, m_scenePresence.Name);
96 96
97 if (m_animations.Add(animID, m_scenePresence.ControllingClient.NextAnimationSequenceNumber, objectID)) 97 if (m_animations.Add(animID, m_scenePresence.ControllingClient.NextAnimationSequenceNumber, objectID))
@@ -113,7 +113,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
113 if (animID == UUID.Zero) 113 if (animID == UUID.Zero)
114 return; 114 return;
115 115
116// m_log.DebugFormat("[SCENE PRESENCE ANIMATOR]: Adding animation {0} {1} for {2}", animID, name, m_scenePresence.Name); 116 // m_log.DebugFormat("[SCENE PRESENCE ANIMATOR]: Adding animation {0} {1} for {2}", animID, name, m_scenePresence.Name);
117 117
118 AddAnimation(animID, objectID); 118 AddAnimation(animID, objectID);
119 } 119 }
@@ -133,7 +133,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
133 133
134 if (m_scenePresence.Scene.DebugAnimations) 134 if (m_scenePresence.Scene.DebugAnimations)
135 m_log.DebugFormat( 135 m_log.DebugFormat(
136 "[SCENE PRESENCE ANIMATOR]: Removing animation {0} {1} for {2}", 136 "[SCENE PRESENCE ANIMATOR]: Removing animation {0} {1} for {2}",
137 GetAnimName(animID), animID, m_scenePresence.Name); 137 GetAnimName(animID), animID, m_scenePresence.Name);
138 138
139 if (m_animations.Remove(animID, allowNoDefault)) 139 if (m_animations.Remove(animID, allowNoDefault))
@@ -155,7 +155,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
155 else 155 else
156 m_animations.Remove(animID, false); 156 m_animations.Remove(animID, false);
157 } 157 }
158 if(sendPack) 158 if (sendPack)
159 SendAnimPack(); 159 SendAnimPack();
160 } 160 }
161 161
@@ -201,9 +201,9 @@ namespace OpenSim.Region.Framework.Scenes.Animation
201 bool ret = false; 201 bool ret = false;
202 if (!m_scenePresence.IsChildAgent) 202 if (!m_scenePresence.IsChildAgent)
203 { 203 {
204// m_log.DebugFormat( 204 // m_log.DebugFormat(
205// "[SCENE PRESENCE ANIMATOR]: Setting movement animation {0} for {1}", 205 // "[SCENE PRESENCE ANIMATOR]: Setting movement animation {0} for {1}",
206// anim, m_scenePresence.Name); 206 // anim, m_scenePresence.Name);
207 207
208 if (aoSitGndAnim != UUID.Zero) 208 if (aoSitGndAnim != UUID.Zero)
209 { 209 {
@@ -299,29 +299,44 @@ namespace OpenSim.Region.Framework.Scenes.Animation
299 AgentManager.ControlFlags controlFlags = (AgentManager.ControlFlags)m_scenePresence.AgentControlFlags; 299 AgentManager.ControlFlags controlFlags = (AgentManager.ControlFlags)m_scenePresence.AgentControlFlags;
300 PhysicsActor actor = m_scenePresence.PhysicsActor; 300 PhysicsActor actor = m_scenePresence.PhysicsActor;
301 301
302
303// there is no point on having this meaningless movement values, much less in world coordenates
304// situation may change if vertical Axis of avatar is allowed to rotate.
305// then jumping etc will need some care
306
302 // Create forward and left vectors from the current avatar rotation 307 // Create forward and left vectors from the current avatar rotation
303 Matrix4 rotMatrix = Matrix4.CreateFromQuaternion(m_scenePresence.Rotation); 308 /* yes matrix are better, but getting it from the Quaternion will kill the advantage
304 Vector3 fwd = Vector3.Transform(Vector3.UnitX, rotMatrix); 309 Matrix4 rotMatrix = Matrix4.CreateFromQuaternion(m_scenePresence.Rotation);
305 Vector3 left = Vector3.Transform(Vector3.UnitY, rotMatrix); 310 Vector3 fwd = Vector3.Transform(Vector3.UnitX, rotMatrix);
311 Vector3 left = Vector3.Transform(Vector3.UnitY, rotMatrix);
312 */
313 // there is still a better way
314// Vector3 fwd = Vector3.UnitX * m_scenePresence.Rotation;
315// Vector3 left = Vector3.UnitY * m_scenePresence.Rotation;
306 316
307 // Check control flags 317 // Check control flags
308 bool heldForward = ((controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_AT_POS) == AgentManager.ControlFlags.AGENT_CONTROL_AT_POS || (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_AT_POS) == AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_AT_POS); 318 bool heldForward = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_AT_POS | AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_AT_POS)) != 0);
309 bool heldBack = ((controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_AT_NEG) == AgentManager.ControlFlags.AGENT_CONTROL_AT_NEG || (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_AT_NEG) == AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_AT_NEG); 319 bool heldBack = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_AT_NEG | AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_AT_NEG)) != 0);
310 bool heldLeft = ((controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_LEFT_POS) == AgentManager.ControlFlags.AGENT_CONTROL_LEFT_POS || (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_LEFT_POS) == AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_LEFT_POS); 320 bool heldLeft = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_LEFT_POS | AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_LEFT_POS)) != 0);
311 bool heldRight = ((controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_LEFT_NEG) == AgentManager.ControlFlags.AGENT_CONTROL_LEFT_NEG || (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_LEFT_NEG) == AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_LEFT_NEG); 321 bool heldRight = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_LEFT_NEG | AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_LEFT_NEG)) != 0);
312 bool heldTurnLeft = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_TURN_LEFT) == AgentManager.ControlFlags.AGENT_CONTROL_TURN_LEFT; 322 bool heldTurnLeft = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_TURN_LEFT) == AgentManager.ControlFlags.AGENT_CONTROL_TURN_LEFT;
313 bool heldTurnRight = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_TURN_RIGHT) == AgentManager.ControlFlags.AGENT_CONTROL_TURN_RIGHT; 323 bool heldTurnRight = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_TURN_RIGHT) == AgentManager.ControlFlags.AGENT_CONTROL_TURN_RIGHT;
314 bool heldUp = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_UP_POS) == AgentManager.ControlFlags.AGENT_CONTROL_UP_POS; 324// bool heldUp = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_UP_POS | AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_UP_POS)) != 0);
315 bool heldDown = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_UP_NEG) == AgentManager.ControlFlags.AGENT_CONTROL_UP_NEG; 325 // excluded nudge up so it doesn't trigger jump state
326 bool heldUp = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_UP_POS)) != 0);
327 bool heldDown = ((controlFlags & (AgentManager.ControlFlags.AGENT_CONTROL_UP_NEG | AgentManager.ControlFlags.AGENT_CONTROL_NUDGE_UP_NEG)) != 0);
316 //bool flying = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_FLY) == AgentManager.ControlFlags.AGENT_CONTROL_FLY; 328 //bool flying = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_FLY) == AgentManager.ControlFlags.AGENT_CONTROL_FLY;
317 //bool mouselook = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_MOUSELOOK) == AgentManager.ControlFlags.AGENT_CONTROL_MOUSELOOK; 329 //bool mouselook = (controlFlags & AgentManager.ControlFlags.AGENT_CONTROL_MOUSELOOK) == AgentManager.ControlFlags.AGENT_CONTROL_MOUSELOOK;
318 if (heldForward || heldBack || heldLeft || heldRight || heldUp || heldDown) 330
331 bool heldOnXY = (heldForward || heldBack || heldLeft || heldRight);
332 if (heldOnXY || heldUp || heldDown)
319 { 333 {
320 heldTurnLeft = false; 334 heldTurnLeft = false;
321 heldTurnRight = false; 335 heldTurnRight = false;
322 } 336 }
323 337
324 // Direction in which the avatar is trying to move 338 // Direction in which the avatar is trying to move
339/*
325 Vector3 move = Vector3.Zero; 340 Vector3 move = Vector3.Zero;
326 if (heldForward) { move.X += fwd.X; move.Y += fwd.Y; } 341 if (heldForward) { move.X += fwd.X; move.Y += fwd.Y; }
327 if (heldBack) { move.X -= fwd.X; move.Y -= fwd.Y; } 342 if (heldBack) { move.X -= fwd.X; move.Y -= fwd.Y; }
@@ -329,9 +344,11 @@ namespace OpenSim.Region.Framework.Scenes.Animation
329 if (heldRight) { move.X -= left.X; move.Y -= left.Y; } 344 if (heldRight) { move.X -= left.X; move.Y -= left.Y; }
330 if (heldUp) { move.Z += 1; } 345 if (heldUp) { move.Z += 1; }
331 if (heldDown) { move.Z -= 1; } 346 if (heldDown) { move.Z -= 1; }
347*/
348
332 349
333 // Is the avatar trying to move? 350 // Is the avatar trying to move?
334// bool moving = (move != Vector3.Zero); 351 // bool moving = (move != Vector3.Zero);
335 #endregion Inputs 352 #endregion Inputs
336 353
337 // no physics actor case 354 // no physics actor case
@@ -340,13 +357,13 @@ namespace OpenSim.Region.Framework.Scenes.Animation
340 // well what to do? 357 // well what to do?
341 358
342 currentControlState = motionControlStates.onsurface; 359 currentControlState = motionControlStates.onsurface;
343 if (move.X != 0f || move.Y != 0f) 360// if (move.X != 0f || move.Y != 0f)
361 if (heldOnXY)
344 return "WALK"; 362 return "WALK";
345 363
346 return "STAND"; 364 return "STAND";
347 } 365 }
348 366
349
350 #region Flying 367 #region Flying
351 368
352 bool isColliding = actor.IsColliding; 369 bool isColliding = actor.IsColliding;
@@ -360,15 +377,19 @@ namespace OpenSim.Region.Framework.Scenes.Animation
360 377
361 currentControlState = motionControlStates.flying; 378 currentControlState = motionControlStates.flying;
362 379
363 if (move.X != 0f || move.Y != 0f) 380// if (move.X != 0f || move.Y != 0f)
381 if (heldOnXY)
364 { 382 {
365 return (m_scenePresence.Scene.m_useFlySlow ? "FLYSLOW" : "FLY"); 383 return (m_scenePresence.Scene.m_useFlySlow ? "FLYSLOW" : "FLY");
366 } 384 }
367 else if (move.Z > 0f) 385// else if (move.Z > 0f)
386 else if (heldUp)
387
368 { 388 {
369 return "HOVER_UP"; 389 return "HOVER_UP";
370 } 390 }
371 else if (move.Z < 0f) 391// else if (move.Z < 0f)
392 else if (heldDown)
372 { 393 {
373 if (isColliding) 394 if (isColliding)
374 { 395 {
@@ -423,7 +444,8 @@ namespace OpenSim.Region.Framework.Scenes.Animation
423 } 444 }
424 445
425 // Check if the user has stopped walking just now 446 // Check if the user has stopped walking just now
426 if (CurrentMovementAnimation == "WALK" && (move == Vector3.Zero)) 447// if (CurrentMovementAnimation == "WALK" && move == Vector3.Zero))
448 if (CurrentMovementAnimation == "WALK" && !heldOnXY && !heldDown && !heldUp)
427 return "STAND"; 449 return "STAND";
428 450
429 return CurrentMovementAnimation; 451 return CurrentMovementAnimation;
@@ -435,8 +457,9 @@ namespace OpenSim.Region.Framework.Scenes.Animation
435 457
436 #region Jumping // section added for jumping... 458 #region Jumping // section added for jumping...
437 459
438 if (isColliding && move.Z > 0f && currentControlState != motionControlStates.jumping) 460// if (isColliding && move.Z > 0f && currentControlState != motionControlStates.jumping)
439 { 461 if (isColliding && heldUp && currentControlState != motionControlStates.jumping)
462 {
440 // Start jumping, prejump 463 // Start jumping, prejump
441 currentControlState = motionControlStates.jumping; 464 currentControlState = motionControlStates.jumping;
442 m_jumping = true; 465 m_jumping = true;
@@ -481,7 +504,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
481 currentControlState = motionControlStates.landing; 504 currentControlState = motionControlStates.landing;
482 m_animTickLand = Environment.TickCount; 505 m_animTickLand = Environment.TickCount;
483 // TODO: SOFT_LAND support 506 // TODO: SOFT_LAND support
484 float fallVsq =m_lastFallVelocity*m_lastFallVelocity; 507 float fallVsq = m_lastFallVelocity * m_lastFallVelocity;
485 if (fallVsq > 300f) // aprox 20*h 508 if (fallVsq > 300f) // aprox 20*h
486 return "STANDUP"; 509 return "STANDUP";
487 else if (fallVsq > 160f) 510 else if (fallVsq > 160f)
@@ -514,12 +537,15 @@ namespace OpenSim.Region.Framework.Scenes.Animation
514 537
515 538
516 // next section moved outside paren. and realigned for jumping 539 // next section moved outside paren. and realigned for jumping
517 if (move.X != 0f || move.Y != 0f) 540
541// if (move.X != 0f || move.Y != 0f)
542 if (heldOnXY)
518 { 543 {
519 currentControlState = motionControlStates.onsurface; 544 currentControlState = motionControlStates.onsurface;
520 Falling = false; 545 Falling = false;
521 // Walking / crouchwalking / running 546 // Walking / crouchwalking / running
522 if (move.Z < 0f) 547// if (move.Z < 0f)
548 if (heldDown)
523 { 549 {
524 return "CROUCHWALK"; 550 return "CROUCHWALK";
525 } 551 }
@@ -538,7 +564,8 @@ namespace OpenSim.Region.Framework.Scenes.Animation
538 currentControlState = motionControlStates.onsurface; 564 currentControlState = motionControlStates.onsurface;
539 Falling = false; 565 Falling = false;
540 // Not walking 566 // Not walking
541 if (move.Z < 0) 567// if (move.Z < 0)
568 if(heldDown)
542 return "CROUCH"; 569 return "CROUCH";
543 else if (heldTurnLeft) 570 else if (heldTurnLeft)
544 return "TURNLEFT"; 571 return "TURNLEFT";
@@ -558,7 +585,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
558 /// <returns>'true' if the animation was changed</returns> 585 /// <returns>'true' if the animation was changed</returns>
559 public bool UpdateMovementAnimations() 586 public bool UpdateMovementAnimations()
560 { 587 {
561// m_log.DebugFormat("[SCENE PRESENCE ANIMATOR]: Updating movement animations for {0}", m_scenePresence.Name); 588 // m_log.DebugFormat("[SCENE PRESENCE ANIMATOR]: Updating movement animations for {0}", m_scenePresence.Name);
562 589
563 bool ret = false; 590 bool ret = false;
564 lock (m_animations) 591 lock (m_animations)
@@ -568,9 +595,9 @@ namespace OpenSim.Region.Framework.Scenes.Animation
568 { 595 {
569 CurrentMovementAnimation = newMovementAnimation; 596 CurrentMovementAnimation = newMovementAnimation;
570 597
571// m_log.DebugFormat( 598 // m_log.DebugFormat(
572// "[SCENE PRESENCE ANIMATOR]: Determined animation {0} for {1} in UpdateMovementAnimations()", 599 // "[SCENE PRESENCE ANIMATOR]: Determined animation {0} for {1} in UpdateMovementAnimations()",
573// CurrentMovementAnimation, m_scenePresence.Name); 600 // CurrentMovementAnimation, m_scenePresence.Name);
574 601
575 // Only set it if it's actually changed, give a script 602 // Only set it if it's actually changed, give a script
576 // a chance to stop a default animation 603 // a chance to stop a default animation
@@ -606,19 +633,19 @@ namespace OpenSim.Region.Framework.Scenes.Animation
606 m_animations.GetArrays(out animIDs, out sequenceNums, out objectIDs); 633 m_animations.GetArrays(out animIDs, out sequenceNums, out objectIDs);
607 return animIDs; 634 return animIDs;
608 } 635 }
609 636
610 public BinBVHAnimation GenerateRandomAnimation() 637 public BinBVHAnimation GenerateRandomAnimation()
611 { 638 {
612 int rnditerations = 3; 639 int rnditerations = 3;
613 BinBVHAnimation anim = new BinBVHAnimation(); 640 BinBVHAnimation anim = new BinBVHAnimation();
614 List<string> parts = new List<string>(); 641 List<string> parts = new List<string>();
615 parts.Add("mPelvis");parts.Add("mHead");parts.Add("mTorso"); 642 parts.Add("mPelvis"); parts.Add("mHead"); parts.Add("mTorso");
616 parts.Add("mHipLeft");parts.Add("mHipRight");parts.Add("mHipLeft");parts.Add("mKneeLeft"); 643 parts.Add("mHipLeft"); parts.Add("mHipRight"); parts.Add("mHipLeft"); parts.Add("mKneeLeft");
617 parts.Add("mKneeRight");parts.Add("mCollarLeft");parts.Add("mCollarRight");parts.Add("mNeck"); 644 parts.Add("mKneeRight"); parts.Add("mCollarLeft"); parts.Add("mCollarRight"); parts.Add("mNeck");
618 parts.Add("mElbowLeft");parts.Add("mElbowRight");parts.Add("mWristLeft");parts.Add("mWristRight"); 645 parts.Add("mElbowLeft"); parts.Add("mElbowRight"); parts.Add("mWristLeft"); parts.Add("mWristRight");
619 parts.Add("mShoulderLeft");parts.Add("mShoulderRight");parts.Add("mAnkleLeft");parts.Add("mAnkleRight"); 646 parts.Add("mShoulderLeft"); parts.Add("mShoulderRight"); parts.Add("mAnkleLeft"); parts.Add("mAnkleRight");
620 parts.Add("mEyeRight");parts.Add("mChest");parts.Add("mToeLeft");parts.Add("mToeRight"); 647 parts.Add("mEyeRight"); parts.Add("mChest"); parts.Add("mToeLeft"); parts.Add("mToeRight");
621 parts.Add("mFootLeft");parts.Add("mFootRight");parts.Add("mEyeLeft"); 648 parts.Add("mFootLeft"); parts.Add("mFootRight"); parts.Add("mEyeLeft");
622 anim.HandPose = 1; 649 anim.HandPose = 1;
623 anim.InPoint = 0; 650 anim.InPoint = 0;
624 anim.OutPoint = (rnditerations * .10f); 651 anim.OutPoint = (rnditerations * .10f);
@@ -642,12 +669,12 @@ namespace OpenSim.Region.Framework.Scenes.Animation
642 for (int i = 0; i < rnditerations; i++) 669 for (int i = 0; i < rnditerations; i++)
643 { 670 {
644 anim.Joints[j].rotationkeys[i] = new binBVHJointKey(); 671 anim.Joints[j].rotationkeys[i] = new binBVHJointKey();
645 anim.Joints[j].rotationkeys[i].time = (i*.10f); 672 anim.Joints[j].rotationkeys[i].time = (i * .10f);
646 anim.Joints[j].rotationkeys[i].key_element.X = ((float) rnd.NextDouble()*2 - 1); 673 anim.Joints[j].rotationkeys[i].key_element.X = ((float)rnd.NextDouble() * 2 - 1);
647 anim.Joints[j].rotationkeys[i].key_element.Y = ((float) rnd.NextDouble()*2 - 1); 674 anim.Joints[j].rotationkeys[i].key_element.Y = ((float)rnd.NextDouble() * 2 - 1);
648 anim.Joints[j].rotationkeys[i].key_element.Z = ((float) rnd.NextDouble()*2 - 1); 675 anim.Joints[j].rotationkeys[i].key_element.Z = ((float)rnd.NextDouble() * 2 - 1);
649 anim.Joints[j].positionkeys[i] = new binBVHJointKey(); 676 anim.Joints[j].positionkeys[i] = new binBVHJointKey();
650 anim.Joints[j].positionkeys[i].time = (i*.10f); 677 anim.Joints[j].positionkeys[i].time = (i * .10f);
651 anim.Joints[j].positionkeys[i].key_element.X = 0; 678 anim.Joints[j].positionkeys[i].key_element.X = 0;
652 anim.Joints[j].positionkeys[i].key_element.Y = 0; 679 anim.Joints[j].positionkeys[i].key_element.Y = 0;
653 anim.Joints[j].positionkeys[i].key_element.Z = 0; 680 anim.Joints[j].positionkeys[i].key_element.Z = 0;
@@ -674,22 +701,22 @@ namespace OpenSim.Region.Framework.Scenes.Animation
674 /// <param name="objectIDs"></param> 701 /// <param name="objectIDs"></param>
675 public void SendAnimPack(UUID[] animations, int[] seqs, UUID[] objectIDs) 702 public void SendAnimPack(UUID[] animations, int[] seqs, UUID[] objectIDs)
676 { 703 {
677/* 704 /*
678 if (m_scenePresence.IsChildAgent) 705 if (m_scenePresence.IsChildAgent)
679 return; 706 return;
680 707
681// m_log.DebugFormat( 708 // m_log.DebugFormat(
682// "[SCENE PRESENCE ANIMATOR]: Sending anim pack with animations '{0}', sequence '{1}', uuids '{2}'", 709 // "[SCENE PRESENCE ANIMATOR]: Sending anim pack with animations '{0}', sequence '{1}', uuids '{2}'",
683// string.Join(",", Array.ConvertAll<UUID, string>(animations, a => a.ToString())), 710 // string.Join(",", Array.ConvertAll<UUID, string>(animations, a => a.ToString())),
684// string.Join(",", Array.ConvertAll<int, string>(seqs, s => s.ToString())), 711 // string.Join(",", Array.ConvertAll<int, string>(seqs, s => s.ToString())),
685// string.Join(",", Array.ConvertAll<UUID, string>(objectIDs, o => o.ToString()))); 712 // string.Join(",", Array.ConvertAll<UUID, string>(objectIDs, o => o.ToString())));
686 713
687 m_scenePresence.Scene.ForEachClient( 714 m_scenePresence.Scene.ForEachClient(
688 delegate(IClientAPI client) 715 delegate(IClientAPI client)
689 { 716 {
690 client.SendAnimations(animations, seqs, m_scenePresence.ControllingClient.AgentId, objectIDs); 717 client.SendAnimations(animations, seqs, m_scenePresence.ControllingClient.AgentId, objectIDs);
691 }); 718 });
692 */ 719 */
693 m_scenePresence.SendAnimPack(animations, seqs, objectIDs); 720 m_scenePresence.SendAnimPack(animations, seqs, objectIDs);
694 } 721 }
695 722
@@ -699,7 +726,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
699 sequenceNums = null; 726 sequenceNums = null;
700 objectIDs = null; 727 objectIDs = null;
701 728
702 if(m_animations != null) 729 if (m_animations != null)
703 m_animations.GetArrays(out animIDs, out sequenceNums, out objectIDs); 730 m_animations.GetArrays(out animIDs, out sequenceNums, out objectIDs);
704 } 731 }
705 732
@@ -722,7 +749,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
722 public void SendAnimPack() 749 public void SendAnimPack()
723 { 750 {
724 //m_log.Debug("Sending animation pack to all"); 751 //m_log.Debug("Sending animation pack to all");
725 752
726 if (m_scenePresence.IsChildAgent) 753 if (m_scenePresence.IsChildAgent)
727 return; 754 return;
728 755
@@ -732,7 +759,7 @@ namespace OpenSim.Region.Framework.Scenes.Animation
732 759
733 m_animations.GetArrays(out animIDs, out sequenceNums, out objectIDs); 760 m_animations.GetArrays(out animIDs, out sequenceNums, out objectIDs);
734 761
735// SendAnimPack(animIDs, sequenceNums, objectIDs); 762 // SendAnimPack(animIDs, sequenceNums, objectIDs);
736 m_scenePresence.SendAnimPack(animIDs, sequenceNums, objectIDs); 763 m_scenePresence.SendAnimPack(animIDs, sequenceNums, objectIDs);
737 } 764 }
738 765