aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/Framework
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/Framework')
-rw-r--r--OpenSim/Region/Framework/Scenes/KeyframeMotion.cs79
1 files changed, 64 insertions, 15 deletions
diff --git a/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs b/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs
index 4d153da..49b71e5 100644
--- a/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs
+++ b/OpenSim/Region/Framework/Scenes/KeyframeMotion.cs
@@ -265,14 +265,17 @@ namespace OpenSim.Region.Framework.Scenes
265 265
266 private void StartTimer() 266 private void StartTimer()
267 { 267 {
268 KeyframeTimer.Add(this); 268 lock (m_frames)
269 m_timerStopped = false; 269 {
270 KeyframeTimer.Add(this);
271 m_timerStopped = false;
272 }
270 } 273 }
271 274
272 private void StopTimer() 275 private void StopTimer()
273 { 276 {
274 m_timerStopped = true; 277 lock (m_frames)
275 KeyframeTimer.Remove(this); 278 m_timerStopped = true;
276 } 279 }
277 280
278 public static KeyframeMotion FromData(SceneObjectGroup grp, Byte[] data) 281 public static KeyframeMotion FromData(SceneObjectGroup grp, Byte[] data)
@@ -427,19 +430,18 @@ namespace OpenSim.Region.Framework.Scenes
427 } 430 }
428 else 431 else
429 { 432 {
430 m_running = false;
431 StopTimer(); 433 StopTimer();
434 m_running = false;
432 } 435 }
433 } 436 }
434 437
435 public void Stop() 438 public void Stop()
436 { 439 {
440 StopTimer();
437 m_running = false; 441 m_running = false;
438 m_isCrossing = false; 442 m_isCrossing = false;
439 m_waitingCrossing = false; 443 m_waitingCrossing = false;
440 444
441 StopTimer();
442
443 m_basePosition = m_group.AbsolutePosition; 445 m_basePosition = m_group.AbsolutePosition;
444 m_baseRotation = m_group.GroupRotation; 446 m_baseRotation = m_group.GroupRotation;
445 447
@@ -452,14 +454,34 @@ namespace OpenSim.Region.Framework.Scenes
452 454
453 public void Pause() 455 public void Pause()
454 { 456 {
455 m_running = false;
456 StopTimer(); 457 StopTimer();
458 m_running = false;
457 459
458 m_group.RootPart.Velocity = Vector3.Zero; 460 m_group.RootPart.Velocity = Vector3.Zero;
459 m_group.RootPart.AngularVelocity = Vector3.Zero; 461 m_group.RootPart.AngularVelocity = Vector3.Zero;
460 m_group.SendGroupRootTerseUpdate(); 462 m_group.SendGroupRootTerseUpdate();
461// m_group.RootPart.ScheduleTerseUpdate(); 463// m_group.RootPart.ScheduleTerseUpdate();
464 }
462 465
466 public void Suspend()
467 {
468 lock (m_frames)
469 {
470 if (m_timerStopped)
471 return;
472 m_timerStopped = true;
473 }
474 }
475
476 public void Resume()
477 {
478 lock (m_frames)
479 {
480 if (!m_timerStopped)
481 return;
482 if (m_running && !m_waitingCrossing)
483 StartTimer();
484 }
463 } 485 }
464 486
465 private void GetNextList() 487 private void GetNextList()
@@ -550,6 +572,7 @@ namespace OpenSim.Region.Framework.Scenes
550 572
551 pos = (Vector3)k.Position; 573 pos = (Vector3)k.Position;
552 rot = (Quaternion)k.Rotation; 574 rot = (Quaternion)k.Rotation;
575
553 } 576 }
554 577
555 m_basePosition = pos; 578 m_basePosition = pos;
@@ -561,14 +584,41 @@ namespace OpenSim.Region.Framework.Scenes
561 584
562 public void OnTimer(double tickDuration) 585 public void OnTimer(double tickDuration)
563 { 586 {
587 if (!Monitor.TryEnter(m_frames))
588 return;
589 if (m_timerStopped)
590 KeyframeTimer.Remove(this);
591 else
592 DoOnTimer(tickDuration);
593 Monitor.Exit(m_frames);
594 }
595
596 private void Done()
597 {
598 KeyframeTimer.Remove(this);
599 m_timerStopped = true;
600 m_running = false;
601 m_isCrossing = false;
602 m_waitingCrossing = false;
603
604 m_basePosition = m_group.AbsolutePosition;
605 m_baseRotation = m_group.GroupRotation;
606
607 m_group.RootPart.Velocity = Vector3.Zero;
608 m_group.RootPart.AngularVelocity = Vector3.Zero;
609 m_group.SendGroupRootTerseUpdate();
610 // m_group.RootPart.ScheduleTerseUpdate();
611 m_frames.Clear();
612 }
613
614 private void DoOnTimer(double tickDuration)
615 {
564 if (m_skipLoops > 0) 616 if (m_skipLoops > 0)
565 { 617 {
566 m_skipLoops--; 618 m_skipLoops--;
567 return; 619 return;
568 } 620 }
569 621
570 if (m_timerStopped) // trap events still in air even after a timer.stop
571 return;
572 622
573 if (m_group == null) 623 if (m_group == null)
574 return; 624 return;
@@ -608,7 +658,7 @@ namespace OpenSim.Region.Framework.Scenes
608 658
609 if (m_frames.Count == 0) 659 if (m_frames.Count == 0)
610 { 660 {
611 Stop(); 661 Done();
612 Scene scene = m_group.Scene; 662 Scene scene = m_group.Scene;
613 663
614 IScriptModule[] scriptModules = scene.RequestModuleInterfaces<IScriptModule>(); 664 IScriptModule[] scriptModules = scene.RequestModuleInterfaces<IScriptModule>();
@@ -707,11 +757,10 @@ namespace OpenSim.Region.Framework.Scenes
707 757
708 if (angle > 0.01f) 758 if (angle > 0.01f)
709*/ 759*/
710 if(Math.Abs(step.X - current.X) > 0.001f 760 if (Math.Abs(step.X - current.X) > 0.001f
711 || Math.Abs(step.Y - current.Y) > 0.001f 761 || Math.Abs(step.Y - current.Y) > 0.001f
712 || Math.Abs(step.Z - current.Z) > 0.001f) 762 || Math.Abs(step.Z - current.Z) > 0.001f)
713 // assuming w is a dependente var 763 // assuming w is a dependente var
714
715 { 764 {
716// m_group.UpdateGroupRotationR(step); 765// m_group.UpdateGroupRotationR(step);
717 m_group.RootPart.RotationOffset = step; 766 m_group.RootPart.RotationOffset = step;