diff options
-rw-r--r-- | OpenSim/Region/Framework/Scenes/SceneObjectPart.cs | 48 |
1 files changed, 21 insertions, 27 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs index 1cdd567..97434bd 100644 --- a/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs +++ b/OpenSim/Region/Framework/Scenes/SceneObjectPart.cs | |||
@@ -4466,9 +4466,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
4466 | if (ParentGroup.Scene == null) | 4466 | if (ParentGroup.Scene == null) |
4467 | return; | 4467 | return; |
4468 | 4468 | ||
4469 | PhysicsActor pa = PhysActor; | 4469 | if (PhysActor == null) |
4470 | |||
4471 | if (pa == null) | ||
4472 | { | 4470 | { |
4473 | // It's not phantom anymore. So make sure the physics engine get's knowledge of it | 4471 | // It's not phantom anymore. So make sure the physics engine get's knowledge of it |
4474 | PhysActor = m_parentGroup.Scene.PhysicsScene.AddPrimShape( | 4472 | PhysActor = m_parentGroup.Scene.PhysicsScene.AddPrimShape( |
@@ -4480,38 +4478,34 @@ namespace OpenSim.Region.Framework.Scenes | |||
4480 | UsePhysics, | 4478 | UsePhysics, |
4481 | m_localId); | 4479 | m_localId); |
4482 | 4480 | ||
4483 | pa = PhysActor; | 4481 | PhysActor.SetMaterial(Material); |
4484 | if (pa != null) | 4482 | DoPhysicsPropertyUpdate(UsePhysics, true); |
4485 | { | ||
4486 | PhysActor.SetMaterial(Material); | ||
4487 | DoPhysicsPropertyUpdate(UsePhysics, true); | ||
4488 | 4483 | ||
4489 | if (!m_parentGroup.IsDeleted) | 4484 | if (!m_parentGroup.IsDeleted) |
4485 | { | ||
4486 | if (LocalId == m_parentGroup.RootPart.LocalId) | ||
4490 | { | 4487 | { |
4491 | if (LocalId == m_parentGroup.RootPart.LocalId) | 4488 | m_parentGroup.CheckSculptAndLoad(); |
4492 | { | ||
4493 | m_parentGroup.CheckSculptAndLoad(); | ||
4494 | } | ||
4495 | } | 4489 | } |
4490 | } | ||
4496 | 4491 | ||
4497 | if ( | 4492 | if ( |
4498 | ((AggregateScriptEvents & scriptEvents.collision) != 0) || | 4493 | ((AggregateScriptEvents & scriptEvents.collision) != 0) || |
4499 | ((AggregateScriptEvents & scriptEvents.collision_end) != 0) || | 4494 | ((AggregateScriptEvents & scriptEvents.collision_end) != 0) || |
4500 | ((AggregateScriptEvents & scriptEvents.collision_start) != 0) || | 4495 | ((AggregateScriptEvents & scriptEvents.collision_start) != 0) || |
4501 | ((AggregateScriptEvents & scriptEvents.land_collision_start) != 0) || | 4496 | ((AggregateScriptEvents & scriptEvents.land_collision_start) != 0) || |
4502 | ((AggregateScriptEvents & scriptEvents.land_collision) != 0) || | 4497 | ((AggregateScriptEvents & scriptEvents.land_collision) != 0) || |
4503 | ((AggregateScriptEvents & scriptEvents.land_collision_end) != 0) || | 4498 | ((AggregateScriptEvents & scriptEvents.land_collision_end) != 0) || |
4504 | (CollisionSound != UUID.Zero) | 4499 | (CollisionSound != UUID.Zero) |
4505 | ) | 4500 | ) |
4506 | { | 4501 | { |
4507 | PhysActor.OnCollisionUpdate += PhysicsCollision; | 4502 | PhysActor.OnCollisionUpdate += PhysicsCollision; |
4508 | PhysActor.SubscribeEvents(1000); | 4503 | PhysActor.SubscribeEvents(1000); |
4509 | } | ||
4510 | } | 4504 | } |
4511 | } | 4505 | } |
4512 | else // it already has a physical representation | 4506 | else // it already has a physical representation |
4513 | { | 4507 | { |
4514 | pa.IsPhysical = UsePhysics; | 4508 | PhysActor.IsPhysical = UsePhysics; |
4515 | 4509 | ||
4516 | DoPhysicsPropertyUpdate(UsePhysics, false); // Update physical status. If it's phantom this will remove the prim | 4510 | DoPhysicsPropertyUpdate(UsePhysics, false); // Update physical status. If it's phantom this will remove the prim |
4517 | 4511 | ||