diff options
Diffstat (limited to 'OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs')
-rw-r--r-- | OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs | 149 |
1 files changed, 101 insertions, 48 deletions
diff --git a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs index 11fd721..5b47fc0 100644 --- a/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs +++ b/OpenSim/Region/Framework/Scenes/SceneObjectGroup.cs | |||
@@ -725,16 +725,21 @@ namespace OpenSim.Region.Framework.Scenes | |||
725 | { | 725 | { |
726 | m_isSelected = value; | 726 | m_isSelected = value; |
727 | // Tell physics engine that group is selected | 727 | // Tell physics engine that group is selected |
728 | if (m_rootPart.PhysActor != null) | 728 | |
729 | PhysicsActor pa = m_rootPart.PhysActor; | ||
730 | if (pa != null) | ||
729 | { | 731 | { |
730 | m_rootPart.PhysActor.Selected = value; | 732 | pa.Selected = value; |
733 | |||
731 | // Pass it on to the children. | 734 | // Pass it on to the children. |
732 | SceneObjectPart[] parts = m_parts.GetArray(); | 735 | SceneObjectPart[] parts = m_parts.GetArray(); |
733 | for (int i = 0; i < parts.Length; i++) | 736 | for (int i = 0; i < parts.Length; i++) |
734 | { | 737 | { |
735 | SceneObjectPart child = parts[i]; | 738 | SceneObjectPart child = parts[i]; |
736 | if (child.PhysActor != null) | 739 | |
737 | child.PhysActor.Selected = value; | 740 | PhysicsActor childPa = child.PhysActor; |
741 | if (childPa != null) | ||
742 | childPa.Selected = value; | ||
738 | } | 743 | } |
739 | } | 744 | } |
740 | if (RootPart.KeyframeMotion != null) | 745 | if (RootPart.KeyframeMotion != null) |
@@ -2166,29 +2171,58 @@ namespace OpenSim.Region.Framework.Scenes | |||
2166 | } | 2171 | } |
2167 | else | 2172 | else |
2168 | { | 2173 | { |
2169 | if (RootPart.PhysActor != null) | 2174 | PhysicsActor pa = RootPart.PhysActor; |
2175 | |||
2176 | if (pa != null) | ||
2170 | { | 2177 | { |
2171 | RootPart.PhysActor.AddForce(impulse, true); | 2178 | pa.AddForce(impulse, true); |
2172 | m_scene.PhysicsScene.AddPhysicsActorTaint(RootPart.PhysActor); | 2179 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); |
2173 | } | 2180 | } |
2174 | } | 2181 | } |
2175 | } | 2182 | } |
2176 | 2183 | ||
2177 | public void applyAngularImpulse(Vector3 impulse) | 2184 | public void applyAngularImpulse(Vector3 impulse) |
2178 | { | 2185 | { |
2179 | if (RootPart.PhysActor != null) | 2186 | PhysicsActor pa = RootPart.PhysActor; |
2187 | |||
2188 | if (pa != null) | ||
2180 | { | 2189 | { |
2181 | if (!IsAttachment) | 2190 | if (!IsAttachment) |
2182 | { | 2191 | { |
2183 | RootPart.PhysActor.AddAngularForce(impulse, true); | 2192 | pa.AddAngularForce(impulse, true); |
2184 | m_scene.PhysicsScene.AddPhysicsActorTaint(RootPart.PhysActor); | 2193 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); |
2194 | } | ||
2195 | } | ||
2196 | } | ||
2197 | |||
2198 | public void setAngularImpulse(Vector3 impulse) | ||
2199 | { | ||
2200 | PhysicsActor pa = RootPart.PhysActor; | ||
2201 | |||
2202 | if (pa != null) | ||
2203 | { | ||
2204 | if (!IsAttachment) | ||
2205 | { | ||
2206 | pa.Torque = impulse; | ||
2207 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); | ||
2185 | } | 2208 | } |
2186 | } | 2209 | } |
2187 | } | 2210 | } |
2188 | 2211 | ||
2189 | public Vector3 GetTorque() | 2212 | public Vector3 GetTorque() |
2190 | { | 2213 | { |
2191 | return RootPart.Torque; | 2214 | PhysicsActor pa = RootPart.PhysActor; |
2215 | |||
2216 | if (pa != null) | ||
2217 | { | ||
2218 | if (!IsAttachment) | ||
2219 | { | ||
2220 | Vector3 torque = pa.Torque; | ||
2221 | return torque; | ||
2222 | } | ||
2223 | } | ||
2224 | |||
2225 | return Vector3.Zero; | ||
2192 | } | 2226 | } |
2193 | 2227 | ||
2194 | // This is used by both Double-Click Auto-Pilot and llMoveToTarget() in an attached object | 2228 | // This is used by both Double-Click Auto-Pilot and llMoveToTarget() in an attached object |
@@ -2204,19 +2238,23 @@ namespace OpenSim.Region.Framework.Scenes | |||
2204 | } | 2238 | } |
2205 | else | 2239 | else |
2206 | { | 2240 | { |
2207 | if (RootPart.PhysActor != null) | 2241 | PhysicsActor pa = RootPart.PhysActor; |
2242 | |||
2243 | if (pa != null) | ||
2208 | { | 2244 | { |
2209 | RootPart.PhysActor.PIDTarget = target; | 2245 | pa.PIDTarget = target; |
2210 | RootPart.PhysActor.PIDTau = tau; | 2246 | pa.PIDTau = tau; |
2211 | RootPart.PhysActor.PIDActive = true; | 2247 | pa.PIDActive = true; |
2212 | } | 2248 | } |
2213 | } | 2249 | } |
2214 | } | 2250 | } |
2215 | 2251 | ||
2216 | public void stopMoveToTarget() | 2252 | public void stopMoveToTarget() |
2217 | { | 2253 | { |
2218 | if (RootPart.PhysActor != null) | 2254 | PhysicsActor pa = RootPart.PhysActor; |
2219 | RootPart.PhysActor.PIDActive = false; | 2255 | |
2256 | if (pa != null) | ||
2257 | pa.PIDActive = false; | ||
2220 | } | 2258 | } |
2221 | 2259 | ||
2222 | public void rotLookAt(Quaternion target, float strength, float damping) | 2260 | public void rotLookAt(Quaternion target, float strength, float damping) |
@@ -2267,18 +2305,20 @@ namespace OpenSim.Region.Framework.Scenes | |||
2267 | /// <param name="tau">Number of seconds over which to reach target</param> | 2305 | /// <param name="tau">Number of seconds over which to reach target</param> |
2268 | public void SetHoverHeight(float height, PIDHoverType hoverType, float tau) | 2306 | public void SetHoverHeight(float height, PIDHoverType hoverType, float tau) |
2269 | { | 2307 | { |
2270 | if (RootPart.PhysActor != null) | 2308 | PhysicsActor pa = RootPart.PhysActor; |
2309 | |||
2310 | if (pa != null) | ||
2271 | { | 2311 | { |
2272 | if (height != 0f) | 2312 | if (height != 0f) |
2273 | { | 2313 | { |
2274 | RootPart.PhysActor.PIDHoverHeight = height; | 2314 | pa.PIDHoverHeight = height; |
2275 | RootPart.PhysActor.PIDHoverType = hoverType; | 2315 | pa.PIDHoverType = hoverType; |
2276 | RootPart.PhysActor.PIDTau = tau; | 2316 | pa.PIDTau = tau; |
2277 | RootPart.PhysActor.PIDHoverActive = true; | 2317 | pa.PIDHoverActive = true; |
2278 | } | 2318 | } |
2279 | else | 2319 | else |
2280 | { | 2320 | { |
2281 | RootPart.PhysActor.PIDHoverActive = false; | 2321 | pa.PIDHoverActive = false; |
2282 | } | 2322 | } |
2283 | } | 2323 | } |
2284 | } | 2324 | } |
@@ -2771,10 +2811,10 @@ namespace OpenSim.Region.Framework.Scenes | |||
2771 | linkPart.ParentID = 0; | 2811 | linkPart.ParentID = 0; |
2772 | linkPart.LinkNum = 0; | 2812 | linkPart.LinkNum = 0; |
2773 | 2813 | ||
2774 | if (linkPart.PhysActor != null) | 2814 | PhysicsActor linkPartPa = linkPart.PhysActor; |
2775 | { | 2815 | |
2776 | m_scene.PhysicsScene.RemovePrim(linkPart.PhysActor); | 2816 | if (linkPartPa != null) |
2777 | } | 2817 | m_scene.PhysicsScene.RemovePrim(linkPartPa); |
2778 | 2818 | ||
2779 | // We need to reset the child part's position | 2819 | // We need to reset the child part's position |
2780 | // ready for life as a separate object after being a part of another object | 2820 | // ready for life as a separate object after being a part of another object |
@@ -2875,17 +2915,19 @@ namespace OpenSim.Region.Framework.Scenes | |||
2875 | { | 2915 | { |
2876 | if (m_scene.EventManager.TriggerGroupMove(UUID, pos)) | 2916 | if (m_scene.EventManager.TriggerGroupMove(UUID, pos)) |
2877 | { | 2917 | { |
2878 | if (m_rootPart.PhysActor != null) | 2918 | PhysicsActor pa = m_rootPart.PhysActor; |
2919 | |||
2920 | if (pa != null) | ||
2879 | { | 2921 | { |
2880 | if (m_rootPart.PhysActor.IsPhysical) | 2922 | if (pa.IsPhysical) |
2881 | { | 2923 | { |
2882 | if (!m_rootPart.BlockGrab) | 2924 | if (!m_rootPart.BlockGrab) |
2883 | { | 2925 | { |
2884 | Vector3 llmoveforce = pos - AbsolutePosition; | 2926 | Vector3 llmoveforce = pos - AbsolutePosition; |
2885 | Vector3 grabforce = llmoveforce; | 2927 | Vector3 grabforce = llmoveforce; |
2886 | grabforce = (grabforce / 10) * m_rootPart.PhysActor.Mass; | 2928 | grabforce = (grabforce / 10) * pa.Mass; |
2887 | m_rootPart.PhysActor.AddForce(grabforce, true); | 2929 | pa.AddForce(grabforce, true); |
2888 | m_scene.PhysicsScene.AddPhysicsActorTaint(m_rootPart.PhysActor); | 2930 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); |
2889 | } | 2931 | } |
2890 | } | 2932 | } |
2891 | else | 2933 | else |
@@ -2915,9 +2957,11 @@ namespace OpenSim.Region.Framework.Scenes | |||
2915 | { | 2957 | { |
2916 | if (m_scene.EventManager.TriggerGroupSpinStart(UUID)) | 2958 | if (m_scene.EventManager.TriggerGroupSpinStart(UUID)) |
2917 | { | 2959 | { |
2918 | if (m_rootPart.PhysActor != null) | 2960 | PhysicsActor pa = m_rootPart.PhysActor; |
2961 | |||
2962 | if (pa != null) | ||
2919 | { | 2963 | { |
2920 | if (m_rootPart.PhysActor.IsPhysical) | 2964 | if (pa.IsPhysical) |
2921 | { | 2965 | { |
2922 | m_rootPart.IsWaitingForFirstSpinUpdatePacket = true; | 2966 | m_rootPart.IsWaitingForFirstSpinUpdatePacket = true; |
2923 | } | 2967 | } |
@@ -2958,12 +3002,13 @@ namespace OpenSim.Region.Framework.Scenes | |||
2958 | // but it will result in over-shoot or under-shoot of the target orientation. | 3002 | // but it will result in over-shoot or under-shoot of the target orientation. |
2959 | // For the end user, this means that ctrl+shift+drag can be used for relative, | 3003 | // For the end user, this means that ctrl+shift+drag can be used for relative, |
2960 | // but not absolute, adjustments of orientation for physical prims. | 3004 | // but not absolute, adjustments of orientation for physical prims. |
2961 | |||
2962 | if (m_scene.EventManager.TriggerGroupSpin(UUID, newOrientation)) | 3005 | if (m_scene.EventManager.TriggerGroupSpin(UUID, newOrientation)) |
2963 | { | 3006 | { |
2964 | if (m_rootPart.PhysActor != null) | 3007 | PhysicsActor pa = m_rootPart.PhysActor; |
3008 | |||
3009 | if (pa != null) | ||
2965 | { | 3010 | { |
2966 | if (m_rootPart.PhysActor.IsPhysical) | 3011 | if (pa.IsPhysical) |
2967 | { | 3012 | { |
2968 | if (m_rootPart.IsWaitingForFirstSpinUpdatePacket) | 3013 | if (m_rootPart.IsWaitingForFirstSpinUpdatePacket) |
2969 | { | 3014 | { |
@@ -2989,9 +3034,9 @@ namespace OpenSim.Region.Framework.Scenes | |||
2989 | 3034 | ||
2990 | //m_log.Error("SCENE OBJECT GROUP]: rotation axis is " + rotationAxis); | 3035 | //m_log.Error("SCENE OBJECT GROUP]: rotation axis is " + rotationAxis); |
2991 | Vector3 spinforce = new Vector3(rotationAxis.X, rotationAxis.Y, rotationAxis.Z); | 3036 | Vector3 spinforce = new Vector3(rotationAxis.X, rotationAxis.Y, rotationAxis.Z); |
2992 | spinforce = (spinforce/8) * m_rootPart.PhysActor.Mass; // 8 is an arbitrary torque scaling factor | 3037 | spinforce = (spinforce/8) * pa.Mass; // 8 is an arbitrary torque scaling factor |
2993 | m_rootPart.PhysActor.AddAngularForce(spinforce,true); | 3038 | pa.AddAngularForce(spinforce,true); |
2994 | m_scene.PhysicsScene.AddPhysicsActorTaint(m_rootPart.PhysActor); | 3039 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); |
2995 | } | 3040 | } |
2996 | } | 3041 | } |
2997 | else | 3042 | else |
@@ -3199,8 +3244,10 @@ namespace OpenSim.Region.Framework.Scenes | |||
3199 | { | 3244 | { |
3200 | part.UpdateShape(shapeBlock); | 3245 | part.UpdateShape(shapeBlock); |
3201 | 3246 | ||
3202 | if (part.PhysActor != null) | 3247 | PhysicsActor pa = m_rootPart.PhysActor; |
3203 | m_scene.PhysicsScene.AddPhysicsActorTaint(part.PhysActor); | 3248 | |
3249 | if (pa != null) | ||
3250 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); | ||
3204 | } | 3251 | } |
3205 | } | 3252 | } |
3206 | 3253 | ||
@@ -3218,7 +3265,9 @@ namespace OpenSim.Region.Framework.Scenes | |||
3218 | scale.Y = Math.Min(scale.Y, Scene.m_maxNonphys); | 3265 | scale.Y = Math.Min(scale.Y, Scene.m_maxNonphys); |
3219 | scale.Z = Math.Min(scale.Z, Scene.m_maxNonphys); | 3266 | scale.Z = Math.Min(scale.Z, Scene.m_maxNonphys); |
3220 | 3267 | ||
3221 | if (RootPart.PhysActor != null && RootPart.PhysActor.IsPhysical) | 3268 | PhysicsActor pa = m_rootPart.PhysActor; |
3269 | |||
3270 | if (pa != null && pa.IsPhysical) | ||
3222 | { | 3271 | { |
3223 | scale.X = Math.Min(scale.X, Scene.m_maxPhys); | 3272 | scale.X = Math.Min(scale.X, Scene.m_maxPhys); |
3224 | scale.Y = Math.Min(scale.Y, Scene.m_maxPhys); | 3273 | scale.Y = Math.Min(scale.Y, Scene.m_maxPhys); |
@@ -3243,7 +3292,7 @@ namespace OpenSim.Region.Framework.Scenes | |||
3243 | float f = 1.0f; | 3292 | float f = 1.0f; |
3244 | float a = 1.0f; | 3293 | float a = 1.0f; |
3245 | 3294 | ||
3246 | if (RootPart.PhysActor != null && RootPart.PhysActor.IsPhysical) | 3295 | if (pa != null && pa.IsPhysical) |
3247 | { | 3296 | { |
3248 | if (oldSize.X * x > m_scene.m_maxPhys) | 3297 | if (oldSize.X * x > m_scene.m_maxPhys) |
3249 | { | 3298 | { |
@@ -3558,13 +3607,17 @@ namespace OpenSim.Region.Framework.Scenes | |||
3558 | // needs to be called with phys building true | 3607 | // needs to be called with phys building true |
3559 | Quaternion axRot = rot; | 3608 | Quaternion axRot = rot; |
3560 | Quaternion oldParentRot = m_rootPart.RotationOffset; | 3609 | Quaternion oldParentRot = m_rootPart.RotationOffset; |
3561 | 3610 | ||
3611 | m_rootPart.StoreUndoState(); | ||
3562 | //Don't use UpdateRotation because it schedules an update prematurely | 3612 | //Don't use UpdateRotation because it schedules an update prematurely |
3563 | m_rootPart.RotationOffset = rot; | 3613 | m_rootPart.RotationOffset = rot; |
3564 | if (m_rootPart.PhysActor != null) | 3614 | |
3615 | PhysicsActor pa = m_rootPart.PhysActor; | ||
3616 | |||
3617 | if (pa != null) | ||
3565 | { | 3618 | { |
3566 | m_rootPart.PhysActor.Orientation = m_rootPart.RotationOffset; | 3619 | pa.Orientation = m_rootPart.RotationOffset; |
3567 | m_scene.PhysicsScene.AddPhysicsActorTaint(m_rootPart.PhysActor); | 3620 | m_scene.PhysicsScene.AddPhysicsActorTaint(pa); |
3568 | } | 3621 | } |
3569 | 3622 | ||
3570 | SceneObjectPart[] parts = m_parts.GetArray(); | 3623 | SceneObjectPart[] parts = m_parts.GetArray(); |