diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/Physics/Manager/PhysicsScene.cs | 89 |
1 files changed, 86 insertions, 3 deletions
diff --git a/OpenSim/Region/Physics/Manager/PhysicsScene.cs b/OpenSim/Region/Physics/Manager/PhysicsScene.cs index 488900e..a442cf0 100644 --- a/OpenSim/Region/Physics/Manager/PhysicsScene.cs +++ b/OpenSim/Region/Physics/Manager/PhysicsScene.cs | |||
@@ -38,11 +38,40 @@ namespace OpenSim.Region.Physics.Manager | |||
38 | 38 | ||
39 | public delegate void RaycastCallback(bool hitYN, Vector3 collisionPoint, uint localid, float distance, Vector3 normal); | 39 | public delegate void RaycastCallback(bool hitYN, Vector3 collisionPoint, uint localid, float distance, Vector3 normal); |
40 | public delegate void RayCallback(List<ContactResult> list); | 40 | public delegate void RayCallback(List<ContactResult> list); |
41 | public delegate void SitAvatarCallback(int status, uint partID, Vector3 offset, Quaternion Orientation); | ||
41 | 42 | ||
42 | public delegate void JointMoved(PhysicsJoint joint); | 43 | public delegate void JointMoved(PhysicsJoint joint); |
43 | public delegate void JointDeactivated(PhysicsJoint joint); | 44 | public delegate void JointDeactivated(PhysicsJoint joint); |
44 | public delegate void JointErrorMessage(PhysicsJoint joint, string message); // this refers to an "error message due to a problem", not "amount of joint constraint violation" | 45 | public delegate void JointErrorMessage(PhysicsJoint joint, string message); // this refers to an "error message due to a problem", not "amount of joint constraint violation" |
45 | 46 | ||
47 | public enum RayFilterFlags:ushort | ||
48 | { | ||
49 | // the flags | ||
50 | water = 0x01, | ||
51 | land = 0x02, | ||
52 | agent = 0x04, | ||
53 | nonphysical = 0x08, | ||
54 | physical = 0x10, | ||
55 | phantom = 0x20, | ||
56 | volumedtc = 0x40, | ||
57 | |||
58 | // ray cast colision control (may only work for meshs) | ||
59 | BackFaceCull = 0x4000, | ||
60 | ClosestHit = 0x8000, | ||
61 | |||
62 | // some combinations | ||
63 | LSLPhanton = phantom | volumedtc, | ||
64 | PrimsNonPhantom = nonphysical | physical, | ||
65 | PrimsNonPhantomAgents = nonphysical | physical | agent, | ||
66 | |||
67 | AllPrims = nonphysical | phantom | volumedtc | physical, | ||
68 | AllButLand = agent | nonphysical | physical | phantom | volumedtc, | ||
69 | |||
70 | ClosestAndBackCull = ClosestHit | BackFaceCull, | ||
71 | |||
72 | All = 0x3f | ||
73 | } | ||
74 | |||
46 | public delegate void RequestAssetDelegate(UUID assetID, AssetReceivedDelegate callback); | 75 | public delegate void RequestAssetDelegate(UUID assetID, AssetReceivedDelegate callback); |
47 | public delegate void AssetReceivedDelegate(AssetBase asset); | 76 | public delegate void AssetReceivedDelegate(AssetBase asset); |
48 | 77 | ||
@@ -57,6 +86,8 @@ namespace OpenSim.Region.Physics.Manager | |||
57 | public Vector3 Normal; | 86 | public Vector3 Normal; |
58 | } | 87 | } |
59 | 88 | ||
89 | |||
90 | |||
60 | public abstract class PhysicsScene | 91 | public abstract class PhysicsScene |
61 | { | 92 | { |
62 | // private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); | 93 | // private static readonly ILog m_log = LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType); |
@@ -97,8 +128,10 @@ namespace OpenSim.Region.Physics.Manager | |||
97 | /// <param name="size"></param> | 128 | /// <param name="size"></param> |
98 | /// <param name="isFlying"></param> | 129 | /// <param name="isFlying"></param> |
99 | /// <returns></returns> | 130 | /// <returns></returns> |
100 | public abstract PhysicsActor AddAvatar(string avName, Vector3 position, Vector3 size, bool isFlying); | 131 | public virtual PhysicsActor AddAvatar(string avName, Vector3 position, Vector3 size, bool isFlying) |
101 | 132 | { | |
133 | return null; | ||
134 | } | ||
102 | /// <summary> | 135 | /// <summary> |
103 | /// Add an avatar | 136 | /// Add an avatar |
104 | /// </summary> | 137 | /// </summary> |
@@ -115,6 +148,12 @@ namespace OpenSim.Region.Physics.Manager | |||
115 | return ret; | 148 | return ret; |
116 | } | 149 | } |
117 | 150 | ||
151 | public virtual PhysicsActor AddAvatar(uint localID, string avName, Vector3 position, Vector3 size, float feetOffset, bool isFlying) | ||
152 | { | ||
153 | PhysicsActor ret = AddAvatar(localID, avName, position, size, isFlying); | ||
154 | return ret; | ||
155 | } | ||
156 | |||
118 | /// <summary> | 157 | /// <summary> |
119 | /// Remove an avatar. | 158 | /// Remove an avatar. |
120 | /// </summary> | 159 | /// </summary> |
@@ -130,6 +169,25 @@ namespace OpenSim.Region.Physics.Manager | |||
130 | public abstract PhysicsActor AddPrimShape(string primName, PrimitiveBaseShape pbs, Vector3 position, | 169 | public abstract PhysicsActor AddPrimShape(string primName, PrimitiveBaseShape pbs, Vector3 position, |
131 | Vector3 size, Quaternion rotation, bool isPhysical, uint localid); | 170 | Vector3 size, Quaternion rotation, bool isPhysical, uint localid); |
132 | 171 | ||
172 | public virtual PhysicsActor AddPrimShape(string primName, PhysicsActor parent, PrimitiveBaseShape pbs, Vector3 position, | ||
173 | uint localid, byte[] sdata) | ||
174 | { | ||
175 | return null; | ||
176 | } | ||
177 | |||
178 | public virtual PhysicsActor AddPrimShape(string primName, PrimitiveBaseShape pbs, Vector3 position, | ||
179 | Vector3 size, Quaternion rotation, bool isPhysical, bool isPhantom, uint localid) | ||
180 | { | ||
181 | return AddPrimShape(primName, pbs, position, size, rotation, isPhysical, localid); | ||
182 | } | ||
183 | |||
184 | |||
185 | public virtual PhysicsActor AddPrimShape(string primName, PrimitiveBaseShape pbs, Vector3 position, | ||
186 | Vector3 size, Quaternion rotation, bool isPhysical, bool isPhantom, byte shapetype, uint localid) | ||
187 | { | ||
188 | return AddPrimShape(primName, pbs, position, size, rotation, isPhysical, localid); | ||
189 | } | ||
190 | |||
133 | public virtual float TimeDilation | 191 | public virtual float TimeDilation |
134 | { | 192 | { |
135 | get { return 1.0f; } | 193 | get { return 1.0f; } |
@@ -197,6 +255,9 @@ namespace OpenSim.Region.Physics.Manager | |||
197 | 255 | ||
198 | public abstract void AddPhysicsActorTaint(PhysicsActor prim); | 256 | public abstract void AddPhysicsActorTaint(PhysicsActor prim); |
199 | 257 | ||
258 | |||
259 | public virtual void PrepareSimulation() { } | ||
260 | |||
200 | /// <summary> | 261 | /// <summary> |
201 | /// Perform a simulation of the current physics scene over the given timestep. | 262 | /// Perform a simulation of the current physics scene over the given timestep. |
202 | /// </summary> | 263 | /// </summary> |
@@ -241,7 +302,7 @@ namespace OpenSim.Region.Physics.Manager | |||
241 | } | 302 | } |
242 | 303 | ||
243 | public virtual void Combine(PhysicsScene pScene, Vector3 offset, Vector3 extents) {} | 304 | public virtual void Combine(PhysicsScene pScene, Vector3 offset, Vector3 extents) {} |
244 | 305 | public virtual void CombineTerrain(float[] heightMap, Vector3 pOffset) {} | |
245 | public virtual void UnCombine(PhysicsScene pScene) {} | 306 | public virtual void UnCombine(PhysicsScene pScene) {} |
246 | 307 | ||
247 | /// <summary> | 308 | /// <summary> |
@@ -279,5 +340,27 @@ namespace OpenSim.Region.Physics.Manager | |||
279 | { | 340 | { |
280 | return new List<ContactResult>(); | 341 | return new List<ContactResult>(); |
281 | } | 342 | } |
343 | |||
344 | public virtual object RaycastWorld(Vector3 position, Vector3 direction, float length, int Count, RayFilterFlags filter) | ||
345 | { | ||
346 | return null; | ||
347 | } | ||
348 | |||
349 | public virtual bool SuportsRaycastWorldFiltered() | ||
350 | { | ||
351 | return false; | ||
352 | } | ||
353 | |||
354 | public virtual void RaycastActor(PhysicsActor actor, Vector3 position, Vector3 direction, float length, RaycastCallback retMethod){} | ||
355 | public virtual void RaycastActor(PhysicsActor actor, Vector3 position, Vector3 direction, float length, int Count, RayCallback retMethod) { } | ||
356 | public virtual List<ContactResult> RaycastActor(PhysicsActor actor, Vector3 position, Vector3 direction, float length, int Count) | ||
357 | { | ||
358 | return new List<ContactResult>(); | ||
359 | } | ||
360 | |||
361 | public virtual int SitAvatar(PhysicsActor actor, Vector3 AbsolutePosition, Vector3 CameraPosition, Vector3 offset, Vector3 AvatarSize, SitAvatarCallback PhysicsSitResponse) | ||
362 | { | ||
363 | return 0; | ||
364 | } | ||
282 | } | 365 | } |
283 | } | 366 | } |