keyframe: add more locks, change timming stop, added Suspend and resume
parent
02548bdc16
commit
18e4496d2d
|
@ -244,15 +244,18 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
|
|
||||||
private void StartTimer()
|
private void StartTimer()
|
||||||
|
{
|
||||||
|
lock (m_frames)
|
||||||
{
|
{
|
||||||
KeyframeTimer.Add(this);
|
KeyframeTimer.Add(this);
|
||||||
m_timerStopped = false;
|
m_timerStopped = false;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void StopTimer()
|
private void StopTimer()
|
||||||
{
|
{
|
||||||
|
lock (m_frames)
|
||||||
m_timerStopped = true;
|
m_timerStopped = true;
|
||||||
KeyframeTimer.Remove(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static KeyframeMotion FromData(SceneObjectGroup grp, Byte[] data)
|
public static KeyframeMotion FromData(SceneObjectGroup grp, Byte[] data)
|
||||||
|
@ -407,19 +410,18 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
m_running = false;
|
|
||||||
StopTimer();
|
StopTimer();
|
||||||
|
m_running = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void Stop()
|
public void Stop()
|
||||||
{
|
{
|
||||||
|
StopTimer();
|
||||||
m_running = false;
|
m_running = false;
|
||||||
m_isCrossing = false;
|
m_isCrossing = false;
|
||||||
m_waitingCrossing = false;
|
m_waitingCrossing = false;
|
||||||
|
|
||||||
StopTimer();
|
|
||||||
|
|
||||||
m_basePosition = m_group.AbsolutePosition;
|
m_basePosition = m_group.AbsolutePosition;
|
||||||
m_baseRotation = m_group.GroupRotation;
|
m_baseRotation = m_group.GroupRotation;
|
||||||
|
|
||||||
|
@ -432,14 +434,34 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
public void Pause()
|
public void Pause()
|
||||||
{
|
{
|
||||||
m_running = false;
|
|
||||||
StopTimer();
|
StopTimer();
|
||||||
|
m_running = false;
|
||||||
|
|
||||||
m_group.RootPart.Velocity = Vector3.Zero;
|
m_group.RootPart.Velocity = Vector3.Zero;
|
||||||
m_group.RootPart.AngularVelocity = Vector3.Zero;
|
m_group.RootPart.AngularVelocity = Vector3.Zero;
|
||||||
m_group.SendGroupRootTerseUpdate();
|
m_group.SendGroupRootTerseUpdate();
|
||||||
// m_group.RootPart.ScheduleTerseUpdate();
|
// m_group.RootPart.ScheduleTerseUpdate();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Suspend()
|
||||||
|
{
|
||||||
|
lock (m_frames)
|
||||||
|
{
|
||||||
|
if (m_timerStopped)
|
||||||
|
return;
|
||||||
|
m_timerStopped = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Resume()
|
||||||
|
{
|
||||||
|
lock (m_frames)
|
||||||
|
{
|
||||||
|
if (!m_timerStopped)
|
||||||
|
return;
|
||||||
|
if (m_running && !m_waitingCrossing)
|
||||||
|
StartTimer();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void GetNextList()
|
private void GetNextList()
|
||||||
|
@ -529,6 +551,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
pos = (Vector3)k.Position;
|
pos = (Vector3)k.Position;
|
||||||
rot = (Quaternion)k.Rotation;
|
rot = (Quaternion)k.Rotation;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
m_basePosition = pos;
|
m_basePosition = pos;
|
||||||
|
@ -539,6 +562,35 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
}
|
}
|
||||||
|
|
||||||
public void OnTimer(double tickDuration)
|
public void OnTimer(double tickDuration)
|
||||||
|
{
|
||||||
|
if (!Monitor.TryEnter(m_frames))
|
||||||
|
return;
|
||||||
|
if (m_timerStopped)
|
||||||
|
KeyframeTimer.Remove(this);
|
||||||
|
else
|
||||||
|
DoOnTimer(tickDuration);
|
||||||
|
Monitor.Exit(m_frames);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void Done()
|
||||||
|
{
|
||||||
|
KeyframeTimer.Remove(this);
|
||||||
|
m_timerStopped = true;
|
||||||
|
m_running = false;
|
||||||
|
m_isCrossing = false;
|
||||||
|
m_waitingCrossing = false;
|
||||||
|
|
||||||
|
m_basePosition = m_group.AbsolutePosition;
|
||||||
|
m_baseRotation = m_group.GroupRotation;
|
||||||
|
|
||||||
|
m_group.RootPart.Velocity = Vector3.Zero;
|
||||||
|
m_group.RootPart.AngularVelocity = Vector3.Zero;
|
||||||
|
m_group.SendGroupRootTerseUpdate();
|
||||||
|
// m_group.RootPart.ScheduleTerseUpdate();
|
||||||
|
m_frames.Clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void DoOnTimer(double tickDuration)
|
||||||
{
|
{
|
||||||
if (m_skipLoops > 0)
|
if (m_skipLoops > 0)
|
||||||
{
|
{
|
||||||
|
@ -546,8 +598,6 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_timerStopped) // trap events still in air even after a timer.stop
|
|
||||||
return;
|
|
||||||
|
|
||||||
if (m_group == null)
|
if (m_group == null)
|
||||||
return;
|
return;
|
||||||
|
@ -587,7 +637,7 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
if (m_frames.Count == 0)
|
if (m_frames.Count == 0)
|
||||||
{
|
{
|
||||||
Stop();
|
Done();
|
||||||
Scene scene = m_group.Scene;
|
Scene scene = m_group.Scene;
|
||||||
|
|
||||||
IScriptModule[] scriptModules = scene.RequestModuleInterfaces<IScriptModule>();
|
IScriptModule[] scriptModules = scene.RequestModuleInterfaces<IScriptModule>();
|
||||||
|
@ -686,11 +736,10 @@ namespace OpenSim.Region.Framework.Scenes
|
||||||
|
|
||||||
if (angle > 0.01f)
|
if (angle > 0.01f)
|
||||||
*/
|
*/
|
||||||
if(Math.Abs(step.X - current.X) > 0.001f
|
if (Math.Abs(step.X - current.X) > 0.001f
|
||||||
|| Math.Abs(step.Y - current.Y) > 0.001f
|
|| Math.Abs(step.Y - current.Y) > 0.001f
|
||||||
|| Math.Abs(step.Z - current.Z) > 0.001f)
|
|| Math.Abs(step.Z - current.Z) > 0.001f)
|
||||||
// assuming w is a dependente var
|
// assuming w is a dependente var
|
||||||
|
|
||||||
{
|
{
|
||||||
// m_group.UpdateGroupRotationR(step);
|
// m_group.UpdateGroupRotationR(step);
|
||||||
m_group.RootPart.RotationOffset = step;
|
m_group.RootPart.RotationOffset = step;
|
||||||
|
|
Loading…
Reference in New Issue