From a18d45fbdcda9dead222ca45e1b8057c3090cf14 Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Mon, 12 Jun 2017 16:19:29 +0100 Subject: fix some issues on ubOde physics shape type changes --- .../Region/PhysicsModules/ubOde/ODEMeshWorker.cs | 10 +++++----- OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs | 23 ++++++++++++---------- 2 files changed, 18 insertions(+), 15 deletions(-) (limited to 'OpenSim/Region/PhysicsModules') diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODEMeshWorker.cs b/OpenSim/Region/PhysicsModules/ubOde/ODEMeshWorker.cs index a5ee2c9..dc87a78 100644 --- a/OpenSim/Region/PhysicsModules/ubOde/ODEMeshWorker.cs +++ b/OpenSim/Region/PhysicsModules/ubOde/ODEMeshWorker.cs @@ -80,7 +80,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde public float MeshSculptphysicalLOD = 32; - private OpenSim.Framework.BlockingQueue createqueue = new OpenSim.Framework.BlockingQueue(); + private OpenSim.Framework.BlockingQueue workQueue = new OpenSim.Framework.BlockingQueue(); private bool m_running; private Thread m_thread; @@ -110,7 +110,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde while(m_running) { - ODEPhysRepData nextRep = createqueue.Dequeue(); + ODEPhysRepData nextRep = workQueue.Dequeue(); if(!m_running) return; if (nextRep == null) @@ -139,7 +139,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde try { m_thread.Abort(); - createqueue.Clear(); + workQueue.Clear(); } catch { @@ -196,7 +196,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde repData.meshState = MeshState.loadingAsset; repData.comand = meshWorkerCmnds.getmesh; - createqueue.Enqueue(repData); + workQueue.Enqueue(repData); } } @@ -242,7 +242,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde if (needsMeshing(repData)) // no need for pbs now? { repData.comand = meshWorkerCmnds.changefull; - createqueue.Enqueue(repData); + workQueue.Enqueue(repData); } } else diff --git a/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs b/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs index 9bf71f7..4bed0d2 100644 --- a/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs +++ b/OpenSim/Region/PhysicsModules/ubOde/ODEPrim.cs @@ -165,6 +165,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde private float m_density; private byte m_shapetype; + private byte m_fakeShapetype; public bool _zeroFlag; private bool m_lastUpdateSent; @@ -420,7 +421,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde { if (value.IsFinite()) { - _parent_scene.m_meshWorker.ChangeActorPhysRep(this, _pbs, value, m_shapetype); + _parent_scene.m_meshWorker.ChangeActorPhysRep(this, _pbs, value, m_fakeShapetype); } else { @@ -630,7 +631,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde set { // AddChange(changes.Shape, value); - _parent_scene.m_meshWorker.ChangeActorPhysRep(this, value, _size, m_shapetype); + _parent_scene.m_meshWorker.ChangeActorPhysRep(this, value, _size, m_fakeShapetype); } } @@ -638,11 +639,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde { get { - return m_shapetype; + return m_fakeShapetype; } set { - m_shapetype = value; + m_fakeShapetype = value; _parent_scene.m_meshWorker.ChangeActorPhysRep(this, _pbs, _size, value); } } @@ -1329,7 +1330,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde _triMeshData = IntPtr.Zero; - m_shapetype = _shapeType; + m_fakeShapetype = _shapeType; m_lastdoneSelected = false; m_isSelected = false; @@ -1346,7 +1347,7 @@ namespace OpenSim.Region.PhysicsModule.ubOde AddChange(changes.Add, null); // get basic mass parameters - ODEPhysRepData repData = _parent_scene.m_meshWorker.NewActorPhysRep(this, _pbs, _size, m_shapetype); + ODEPhysRepData repData = _parent_scene.m_meshWorker.NewActorPhysRep(this, _pbs, _size, _shapeType); primVolume = repData.volume; m_OBB = repData.OBB; @@ -3161,7 +3162,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde { _size = repData.size; //?? _pbs = repData.pbs; - m_shapetype = repData.shapetype; m_mesh = repData.mesh; @@ -3200,9 +3200,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde { repData.size = _size; repData.pbs = _pbs; - repData.shapetype = m_shapetype; + repData.shapetype = m_fakeShapetype; _parent_scene.m_meshWorker.RequestMesh(repData); } + else + m_shapetype = repData.shapetype; } private void changePhysRepData(ODEPhysRepData repData) @@ -3236,7 +3238,6 @@ namespace OpenSim.Region.PhysicsModule.ubOde _size = repData.size; _pbs = repData.pbs; - m_shapetype = repData.shapetype; m_mesh = repData.mesh; @@ -3287,9 +3288,11 @@ namespace OpenSim.Region.PhysicsModule.ubOde { repData.size = _size; repData.pbs = _pbs; - repData.shapetype = m_shapetype; + repData.shapetype = m_fakeShapetype; _parent_scene.m_meshWorker.RequestMesh(repData); } + else + m_shapetype = repData.shapetype; } private void changeFloatOnWater(bool newval) -- cgit v1.1