diff options
Diffstat (limited to 'OpenSim')
-rw-r--r-- | OpenSim/Region/Framework/Scenes/KeyframeMotion.cs | 192 |
1 files changed, 92 insertions, 100 deletions
diff --git a/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs b/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs index 49b71e5..902e60b 100644 --- a/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs +++ b/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs | |||
@@ -323,22 +323,25 @@ namespace OpenSim.Region.Framework.Scenes | |||
323 | m_group = grp; | 323 | m_group = grp; |
324 | m_scene = grp.Scene; | 324 | m_scene = grp.Scene; |
325 | 325 | ||
326 | Vector3 grppos = grp.AbsolutePosition; | 326 | lock (m_frames) |
327 | Vector3 offset = grppos - m_serializedPosition; | 327 | { |
328 | // avoid doing it more than once | 328 | Vector3 grppos = grp.AbsolutePosition; |
329 | // current this will happen draging a prim to other region | 329 | Vector3 offset = grppos - m_serializedPosition; |
330 | m_serializedPosition = grppos; | 330 | // avoid doing it more than once |
331 | // current this will happen draging a prim to other region | ||
332 | m_serializedPosition = grppos; | ||
331 | 333 | ||
332 | m_basePosition += offset; | 334 | m_basePosition += offset; |
333 | m_currentFrame.Position += offset; | 335 | m_currentFrame.Position += offset; |
334 | 336 | ||
335 | m_nextPosition += offset; | 337 | m_nextPosition += offset; |
336 | 338 | ||
337 | for (int i = 0; i < m_frames.Count; i++) | 339 | for (int i = 0; i < m_frames.Count; i++) |
338 | { | 340 | { |
339 | Keyframe k = m_frames[i]; | 341 | Keyframe k = m_frames[i]; |
340 | k.Position += offset; | 342 | k.Position += offset; |
341 | m_frames[i]=k; | 343 | m_frames[i] = k; |
344 | } | ||
342 | } | 345 | } |
343 | 346 | ||
344 | if (m_running) | 347 | if (m_running) |
@@ -383,25 +386,28 @@ namespace OpenSim.Region.Framework.Scenes | |||
383 | m_keyframes.CopyTo(newmotion.m_keyframes, 0); | 386 | m_keyframes.CopyTo(newmotion.m_keyframes, 0); |
384 | } | 387 | } |
385 | 388 | ||
386 | newmotion.m_frames = new List<Keyframe>(m_frames); | 389 | lock (m_frames) |
390 | { | ||
391 | newmotion.m_frames = new List<Keyframe>(m_frames); | ||
387 | 392 | ||
388 | newmotion.m_basePosition = m_basePosition; | 393 | newmotion.m_basePosition = m_basePosition; |
389 | newmotion.m_baseRotation = m_baseRotation; | 394 | newmotion.m_baseRotation = m_baseRotation; |
390 | 395 | ||
391 | if (m_selected) | 396 | if (m_selected) |
392 | newmotion.m_serializedPosition = m_serializedPosition; | ||
393 | else | ||
394 | { | ||
395 | if (m_group != null) | ||
396 | newmotion.m_serializedPosition = m_group.AbsolutePosition; | ||
397 | else | ||
398 | newmotion.m_serializedPosition = m_serializedPosition; | 397 | newmotion.m_serializedPosition = m_serializedPosition; |
399 | } | 398 | else |
399 | { | ||
400 | if (m_group != null) | ||
401 | newmotion.m_serializedPosition = m_group.AbsolutePosition; | ||
402 | else | ||
403 | newmotion.m_serializedPosition = m_serializedPosition; | ||
404 | } | ||
400 | 405 | ||
401 | newmotion.m_currentFrame = m_currentFrame; | 406 | newmotion.m_currentFrame = m_currentFrame; |
402 | 407 | ||
403 | newmotion.m_iterations = m_iterations; | 408 | newmotion.m_iterations = m_iterations; |
404 | newmotion.m_running = m_running; | 409 | newmotion.m_running = m_running; |
410 | } | ||
405 | 411 | ||
406 | if (m_running && !m_waitingCrossing) | 412 | if (m_running && !m_waitingCrossing) |
407 | StartTimer(); | 413 | StartTimer(); |
@@ -520,7 +526,6 @@ namespace OpenSim.Region.Framework.Scenes | |||
520 | k.Position = pos; | 526 | k.Position = pos; |
521 | // k.Velocity = Vector3.Zero; | 527 | // k.Velocity = Vector3.Zero; |
522 | } | 528 | } |
523 | k.AngularVelocity = (Vector3)k.Position; | ||
524 | 529 | ||
525 | k.StartRotation = rot; | 530 | k.StartRotation = rot; |
526 | if (k.Rotation.HasValue) | 531 | if (k.Rotation.HasValue) |
@@ -654,27 +659,29 @@ namespace OpenSim.Region.Framework.Scenes | |||
654 | 659 | ||
655 | if (m_frames.Count == 0) | 660 | if (m_frames.Count == 0) |
656 | { | 661 | { |
657 | GetNextList(); | 662 | lock (m_frames) |
658 | |||
659 | if (m_frames.Count == 0) | ||
660 | { | 663 | { |
661 | Done(); | 664 | GetNextList(); |
662 | Scene scene = m_group.Scene; | ||
663 | 665 | ||
664 | IScriptModule[] scriptModules = scene.RequestModuleInterfaces<IScriptModule>(); | 666 | if (m_frames.Count == 0) |
665 | foreach (IScriptModule m in scriptModules) | ||
666 | { | 667 | { |
667 | if (m == null) | 668 | Done(); |
668 | continue; | 669 | Scene scene = m_group.Scene; |
669 | m.PostObjectEvent(m_group.RootPart.UUID, "moving_end", new object[0]); | ||
670 | } | ||
671 | 670 | ||
672 | return; | 671 | IScriptModule[] scriptModules = scene.RequestModuleInterfaces<IScriptModule>(); |
673 | } | 672 | foreach (IScriptModule m in scriptModules) |
673 | { | ||
674 | if (m == null) | ||
675 | continue; | ||
676 | m.PostObjectEvent(m_group.RootPart.UUID, "moving_end", new object[0]); | ||
677 | } | ||
674 | 678 | ||
675 | m_currentFrame = m_frames[0]; | 679 | return; |
676 | m_currentFrame.TimeMS += (int)tickDuration; | 680 | } |
677 | 681 | ||
682 | m_currentFrame = m_frames[0]; | ||
683 | m_currentFrame.TimeMS += (int)tickDuration; | ||
684 | } | ||
678 | //force a update on a keyframe transition | 685 | //force a update on a keyframe transition |
679 | update = true; | 686 | update = true; |
680 | } | 687 | } |
@@ -683,22 +690,26 @@ namespace OpenSim.Region.Framework.Scenes | |||
683 | 690 | ||
684 | // Do the frame processing | 691 | // Do the frame processing |
685 | double steps = (double)m_currentFrame.TimeMS / tickDuration; | 692 | double steps = (double)m_currentFrame.TimeMS / tickDuration; |
686 | 693 | ||
687 | if (steps <= 0.0) | 694 | if (steps <= 0.0) |
688 | { | 695 | { |
689 | m_group.RootPart.Velocity = Vector3.Zero; | 696 | m_group.RootPart.Velocity = Vector3.Zero; |
690 | m_group.RootPart.AngularVelocity = Vector3.Zero; | 697 | m_group.RootPart.AngularVelocity = Vector3.Zero; |
691 | 698 | ||
692 | m_nextPosition = NormalizeVector(m_currentFrame.AngularVelocity); | 699 | m_nextPosition = (Vector3)m_currentFrame.Position; |
693 | m_group.AbsolutePosition = m_nextPosition; | 700 | m_group.AbsolutePosition = m_nextPosition; |
694 | 701 | ||
695 | // we are sending imediate updates, no doing force a extra terseUpdate | 702 | // we are sending imediate updates, no doing force a extra terseUpdate |
696 | // m_group.UpdateGroupRotationR((Quaternion)m_currentFrame.Rotation); | 703 | // m_group.UpdateGroupRotationR((Quaternion)m_currentFrame.Rotation); |
697 | 704 | ||
698 | m_group.RootPart.RotationOffset = (Quaternion)m_currentFrame.Rotation; | 705 | m_group.RootPart.RotationOffset = (Quaternion)m_currentFrame.Rotation; |
699 | m_frames.RemoveAt(0); | 706 | |
700 | if (m_frames.Count > 0) | 707 | lock (m_frames) |
701 | m_currentFrame = m_frames[0]; | 708 | { |
709 | m_frames.RemoveAt(0); | ||
710 | if (m_frames.Count > 0) | ||
711 | m_currentFrame = m_frames[0]; | ||
712 | } | ||
702 | 713 | ||
703 | update = true; | 714 | update = true; |
704 | } | 715 | } |
@@ -714,7 +725,6 @@ namespace OpenSim.Region.Framework.Scenes | |||
714 | { | 725 | { |
715 | // m_group.AbsolutePosition += motionThisFrame; | 726 | // m_group.AbsolutePosition += motionThisFrame; |
716 | m_nextPosition = m_group.AbsolutePosition + motionThisFrame; | 727 | m_nextPosition = m_group.AbsolutePosition + motionThisFrame; |
717 | m_group.AbsolutePosition = m_nextPosition; | ||
718 | 728 | ||
719 | //m_group.RootPart.Velocity = v; | 729 | //m_group.RootPart.Velocity = v; |
720 | update = true; | 730 | update = true; |
@@ -726,43 +736,43 @@ namespace OpenSim.Region.Framework.Scenes | |||
726 | 736 | ||
727 | Quaternion step = Quaternion.Slerp(m_currentFrame.StartRotation, (Quaternion)m_currentFrame.Rotation, complete); | 737 | Quaternion step = Quaternion.Slerp(m_currentFrame.StartRotation, (Quaternion)m_currentFrame.Rotation, complete); |
728 | step.Normalize(); | 738 | step.Normalize(); |
729 | /* use simpler change detection | 739 | /* use simpler change detection |
730 | * float angle = 0; | 740 | * float angle = 0; |
731 | 741 | ||
732 | float aa = current.X * current.X + current.Y * current.Y + current.Z * current.Z + current.W * current.W; | 742 | float aa = current.X * current.X + current.Y * current.Y + current.Z * current.Z + current.W * current.W; |
733 | float bb = step.X * step.X + step.Y * step.Y + step.Z * step.Z + step.W * step.W; | 743 | float bb = step.X * step.X + step.Y * step.Y + step.Z * step.Z + step.W * step.W; |
734 | float aa_bb = aa * bb; | 744 | float aa_bb = aa * bb; |
735 | 745 | ||
736 | if (aa_bb == 0) | 746 | if (aa_bb == 0) |
737 | { | 747 | { |
738 | angle = 0; | 748 | angle = 0; |
739 | } | 749 | } |
740 | else | 750 | else |
741 | { | 751 | { |
742 | float ab = current.X * step.X + | 752 | float ab = current.X * step.X + |
743 | current.Y * step.Y + | 753 | current.Y * step.Y + |
744 | current.Z * step.Z + | 754 | current.Z * step.Z + |
745 | current.W * step.W; | 755 | current.W * step.W; |
746 | float q = (ab * ab) / aa_bb; | 756 | float q = (ab * ab) / aa_bb; |
747 | 757 | ||
748 | if (q > 1.0f) | 758 | if (q > 1.0f) |
749 | { | 759 | { |
750 | angle = 0; | 760 | angle = 0; |
751 | } | 761 | } |
752 | else | 762 | else |
753 | { | 763 | { |
754 | angle = (float)Math.Acos(2 * q - 1); | 764 | angle = (float)Math.Acos(2 * q - 1); |
755 | } | 765 | } |
756 | } | 766 | } |
757 | 767 | ||
758 | if (angle > 0.01f) | 768 | if (angle > 0.01f) |
759 | */ | 769 | */ |
760 | if (Math.Abs(step.X - current.X) > 0.001f | 770 | if (Math.Abs(step.X - current.X) > 0.001f |
761 | || Math.Abs(step.Y - current.Y) > 0.001f | 771 | || Math.Abs(step.Y - current.Y) > 0.001f |
762 | || Math.Abs(step.Z - current.Z) > 0.001f) | 772 | || Math.Abs(step.Z - current.Z) > 0.001f) |
763 | // assuming w is a dependente var | 773 | // assuming w is a dependente var |
764 | { | 774 | { |
765 | // m_group.UpdateGroupRotationR(step); | 775 | // m_group.UpdateGroupRotationR(step); |
766 | m_group.RootPart.RotationOffset = step; | 776 | m_group.RootPart.RotationOffset = step; |
767 | 777 | ||
768 | //m_group.RootPart.UpdateAngularVelocity(m_currentFrame.AngularVelocity / 2); | 778 | //m_group.RootPart.UpdateAngularVelocity(m_currentFrame.AngularVelocity / 2); |
@@ -773,29 +783,11 @@ namespace OpenSim.Region.Framework.Scenes | |||
773 | 783 | ||
774 | if (update) | 784 | if (update) |
775 | { | 785 | { |
786 | m_group.AbsolutePosition = m_nextPosition; | ||
776 | m_group.SendGroupRootTerseUpdate(); | 787 | m_group.SendGroupRootTerseUpdate(); |
777 | } | 788 | } |
778 | } | 789 | } |
779 | private Vector3 NormalizeVector(Vector3? pPosition) | ||
780 | { | ||
781 | if (pPosition == null) | ||
782 | return Vector3.Zero; | ||
783 | |||
784 | Vector3 tmp = (Vector3) pPosition; | ||
785 | 790 | ||
786 | while (tmp.X > Constants.RegionSize) | ||
787 | tmp.X -= Constants.RegionSize; | ||
788 | while (tmp.X < 0) | ||
789 | tmp.X += Constants.RegionSize; | ||
790 | while (tmp.Y > Constants.RegionSize) | ||
791 | tmp.Y -= Constants.RegionSize; | ||
792 | while (tmp.Y < 0) | ||
793 | tmp.Y += Constants.RegionSize; | ||
794 | |||
795 | return tmp; | ||
796 | |||
797 | |||
798 | } | ||
799 | public Byte[] Serialize() | 791 | public Byte[] Serialize() |
800 | { | 792 | { |
801 | StopTimer(); | 793 | StopTimer(); |