From 9480da06b971e7ffa500c33399cdb2114a39637f Mon Sep 17 00:00:00 2001 From: UbitUmarov Date: Wed, 2 Nov 2016 21:42:32 +0000 Subject: only add a prim to physics in PhysicsShapeType if changing from type none. when viewers change ExtraPhysics parameters, send back the new values. --- .../Region/ClientStack/Linden/UDP/LLClientView.cs | 1 - OpenSim/Region/Framework/Scenes/SceneGraph.cs | 2 +- OpenSim/Region/Framework/Scenes/SceneObjectPart.cs | 97 ++++++++++------------ 3 files changed, 43 insertions(+), 57 deletions(-) diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs index ad25bc8..17e4400 100644 --- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs +++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs @@ -2920,7 +2920,6 @@ namespace OpenSim.Region.ClientStack.LindenUDP { m_log.Error("Unable to send part Physics Proprieties - exception: " + ex.ToString()); } - part.UpdatePhysRequired = false; } } diff --git a/OpenSim/Region/Framework/Scenes/SceneGraph.cs b/OpenSim/Region/Framework/Scenes/SceneGraph.cs index 238ec8e..1141f54 100755 --- a/OpenSim/Region/Framework/Scenes/SceneGraph.cs +++ b/OpenSim/Region/Framework/Scenes/SceneGraph.cs @@ -1660,7 +1660,7 @@ namespace OpenSim.Region.Framework.Scenes if (part != null) { part.UpdateExtraPhysics(PhysData); - if (part.UpdatePhysRequired && remoteClient != null) + if (remoteClient != null) remoteClient.SendPartPhysicsProprieties(part); } } diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs index 06d767d..9d1dca2 100644 --- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs +++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs @@ -1222,7 +1222,6 @@ namespace OpenSim.Region.Framework.Scenes } public UpdateRequired UpdateFlag { get; set; } - public bool UpdatePhysRequired { get; set; } /// /// Used for media on a prim. @@ -1637,7 +1636,6 @@ namespace OpenSim.Region.Framework.Scenes if(ParentGroup != null) ParentGroup.HasGroupChanged = true; ScheduleFullUpdateIfNone(); - UpdatePhysRequired = true; } } } @@ -1729,7 +1727,7 @@ namespace OpenSim.Region.Framework.Scenes set { byte oldv = m_physicsShapeType; - + if (value >= 0 && value <= (byte)PhysShapeType.convex) { if (value == (byte)PhysShapeType.none && ParentGroup != null && ParentGroup.RootPart == this) @@ -1748,28 +1746,21 @@ namespace OpenSim.Region.Framework.Scenes { ParentGroup.Scene.RemovePhysicalPrim(1); RemoveFromPhysics(); - Stop(); +// Stop(); } } else if (PhysActor == null) { - ApplyPhysics((uint)Flags, VolumeDetectActive, false); - UpdatePhysicsSubscribedEvents(); + if(oldv == (byte)PhysShapeType.none) + { + ApplyPhysics((uint)Flags, VolumeDetectActive, false); + UpdatePhysicsSubscribedEvents(); + } } else - { PhysActor.PhysicsShapeType = m_physicsShapeType; -// if (Shape.SculptEntry) -// CheckSculptAndLoad(); - } - if (ParentGroup != null) - ParentGroup.HasGroupChanged = true; - } - - if (m_physicsShapeType != value) - { - UpdatePhysRequired = true; + ParentGroup.HasGroupChanged = true; } } } @@ -1782,17 +1773,16 @@ namespace OpenSim.Region.Framework.Scenes if (value >=1 && value <= 22587.0) { m_density = value; - UpdatePhysRequired = true; - } - ScheduleFullUpdateIfNone(); + ScheduleFullUpdateIfNone(); - if (ParentGroup != null) - ParentGroup.HasGroupChanged = true; + if (ParentGroup != null) + ParentGroup.HasGroupChanged = true; - PhysicsActor pa = PhysActor; - if (pa != null) - pa.Density = Density; + PhysicsActor pa = PhysActor; + if (pa != null) + pa.Density = m_density; + } } } @@ -1804,17 +1794,16 @@ namespace OpenSim.Region.Framework.Scenes if( value >= -1 && value <=28.0f) { m_gravitymod = value; - UpdatePhysRequired = true; - } - ScheduleFullUpdateIfNone(); + ScheduleFullUpdateIfNone(); - if (ParentGroup != null) - ParentGroup.HasGroupChanged = true; + if (ParentGroup != null) + ParentGroup.HasGroupChanged = true; - PhysicsActor pa = PhysActor; - if (pa != null) - pa.GravModifier = GravityModifier; + PhysicsActor pa = PhysActor; + if (pa != null) + pa.GravModifier = m_gravitymod; + } } } @@ -1826,17 +1815,16 @@ namespace OpenSim.Region.Framework.Scenes if (value >= 0 && value <= 255.0f) { m_friction = value; - UpdatePhysRequired = true; - } - ScheduleFullUpdateIfNone(); + ScheduleFullUpdateIfNone(); - if (ParentGroup != null) - ParentGroup.HasGroupChanged = true; + if (ParentGroup != null) + ParentGroup.HasGroupChanged = true; - PhysicsActor pa = PhysActor; - if (pa != null) - pa.Friction = Friction; + PhysicsActor pa = PhysActor; + if (pa != null) + pa.Friction = m_friction; + } } } @@ -1848,17 +1836,16 @@ namespace OpenSim.Region.Framework.Scenes if (value >= 0 && value <= 1.0f) { m_bounce = value; - UpdatePhysRequired = true; - } - ScheduleFullUpdateIfNone(); + ScheduleFullUpdateIfNone(); - if (ParentGroup != null) - ParentGroup.HasGroupChanged = true; + if (ParentGroup != null) + ParentGroup.HasGroupChanged = true; - PhysicsActor pa = PhysActor; - if (pa != null) - pa.Restitution = Restitution; + PhysicsActor pa = PhysActor; + if (pa != null) + pa.Restitution = m_bounce; + } } } @@ -4541,24 +4528,24 @@ SendFullUpdateToClient(remoteClient, Position) ignores position parameter } } - public void UpdateExtraPhysics(ExtraPhysicsData physdata) { if (physdata.PhysShapeType == PhysShapeType.invalid || ParentGroup == null) return; - if (PhysicsShapeType != (byte)physdata.PhysShapeType) - { - PhysicsShapeType = (byte)physdata.PhysShapeType; - - } + byte newtype = (byte)physdata.PhysShapeType; + if (PhysicsShapeType != newtype) + PhysicsShapeType = newtype; if(Density != physdata.Density) Density = physdata.Density; + if(GravityModifier != physdata.GravitationModifier) GravityModifier = physdata.GravitationModifier; + if(Friction != physdata.Friction) Friction = physdata.Friction; + if(Restitution != physdata.Bounce) Restitution = physdata.Bounce; } -- cgit v1.1