aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs
diff options
context:
space:
mode:
authorRobert Adams2017-09-03 17:15:27 -0700
committerRobert Adams2017-09-03 17:15:27 -0700
commitf348f7fa90cf4784e0e173c122594ecc145d3bb8 (patch)
treec9eaa6f51f9af16935e48a2130dc340d8a8fbcfb /OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs
parentBulletSim; Update BulletSim.dll's and so's for raycast. (diff)
downloadopensim-SC-f348f7fa90cf4784e0e173c122594ecc145d3bb8.zip
opensim-SC-f348f7fa90cf4784e0e173c122594ecc145d3bb8.tar.gz
opensim-SC-f348f7fa90cf4784e0e173c122594ecc145d3bb8.tar.bz2
opensim-SC-f348f7fa90cf4784e0e173c122594ecc145d3bb8.tar.xz
BulletSim: first version of raycast. Only single contact point and no
filtering.
Diffstat (limited to 'OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs')
-rwxr-xr-xOpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs53
1 files changed, 31 insertions, 22 deletions
diff --git a/OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs b/OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs
index 046df56..bfa95c1 100755
--- a/OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs
+++ b/OpenSim/Region/PhysicsModules/BulletS/Tests/Raycast.cs
@@ -48,67 +48,76 @@ namespace OpenSim.Region.PhysicsModule.BulletS.Tests
48 // Documentation on attributes: http://www.nunit.org/index.php?p=attributes&r=2.6.1 48 // Documentation on attributes: http://www.nunit.org/index.php?p=attributes&r=2.6.1
49 // Documentation on assertions: http://www.nunit.org/index.php?p=assertions&r=2.6.1 49 // Documentation on assertions: http://www.nunit.org/index.php?p=assertions&r=2.6.1
50 50
51 BSScene PhysicsScene { get; set; } 51 BSScene _physicsScene { get; set; }
52 BSPrim TargetSphere { get; set; } 52 BSPrim _targetSphere { get; set; }
53 Vector3 TargetSpherePosition { get; set; } 53 Vector3 _targetSpherePosition { get; set; }
54 float simulationTimeStep = 0.089f; 54 float _simulationTimeStep = 0.089f;
55
56 uint _targetLocalID = 123;
55 57
56 [TestFixtureSetUp] 58 [TestFixtureSetUp]
57 public void Init() 59 public void Init()
58 { 60 {
59 Dictionary<string, string> engineParams = new Dictionary<string, string>(); 61 Dictionary<string, string> engineParams = new Dictionary<string, string>();
60 engineParams.Add("UseBulletRaycast", "true"); 62 engineParams.Add("UseBulletRaycast", "true");
61 PhysicsScene = BulletSimTestsUtil.CreateBasicPhysicsEngine(engineParams); 63 _physicsScene = BulletSimTestsUtil.CreateBasicPhysicsEngine(engineParams);
62 64
63 PrimitiveBaseShape pbs = PrimitiveBaseShape.CreateSphere(); 65 PrimitiveBaseShape pbs = PrimitiveBaseShape.CreateSphere();
64 Vector3 pos = new Vector3(100.0f, 100.0f, 50f); 66 Vector3 pos = new Vector3(100.0f, 100.0f, 50f);
65 pos.Z = PhysicsScene.TerrainManager.GetTerrainHeightAtXYZ(pos) + 2f; 67 _targetSpherePosition = pos;
66 TargetSpherePosition = pos;
67 Vector3 size = new Vector3(10f, 10f, 10f); 68 Vector3 size = new Vector3(10f, 10f, 10f);
68 pbs.Scale = size; 69 pbs.Scale = size;
69 Quaternion rot = Quaternion.Identity; 70 Quaternion rot = Quaternion.Identity;
70 bool isPhys = false; 71 bool isPhys = false;
71 uint localID = 123;
72 72
73 PhysicsScene.AddPrimShape("TargetSphere", pbs, pos, size, rot, isPhys, localID); 73 _physicsScene.AddPrimShape("TargetSphere", pbs, pos, size, rot, isPhys, _targetLocalID);
74 TargetSphere = (BSPrim)PhysicsScene.PhysObjects[localID]; 74 _targetSphere = (BSPrim)_physicsScene.PhysObjects[_targetLocalID];
75 // The actual prim shape creation happens at taint time 75 // The actual prim shape creation happens at taint time
76 PhysicsScene.ProcessTaints(); 76 _physicsScene.ProcessTaints();
77 77
78 } 78 }
79 79
80 [TestFixtureTearDown] 80 [TestFixtureTearDown]
81 public void TearDown() 81 public void TearDown()
82 { 82 {
83 if (PhysicsScene != null) 83 if (_physicsScene != null)
84 { 84 {
85 // The Dispose() will also free any physical objects in the scene 85 // The Dispose() will also free any physical objects in the scene
86 PhysicsScene.Dispose(); 86 _physicsScene.Dispose();
87 PhysicsScene = null; 87 _physicsScene = null;
88 } 88 }
89 } 89 }
90 90
91 // There is a 10x10x10 sphere at <100,100,50> 91 // There is a 10x10x10 sphere at <100,100,50>
92 // Shoot rays around the sphere and verify it hits and doesn't hit 92 // Shoot rays around the sphere and verify it hits and doesn't hit
93 // TestCase parameters are <x,y,z> of start and <x,y,z> of end and expected result 93 // TestCase parameters are <x,y,z> of start and <x,y,z> of end and expected result
94 [TestCase(20f, 20f, 50f, 50f, 50f, 50f, true)] // in front to sphere 94 [TestCase(100f, 50f, 50f, 100f, 150f, 50f, true, "Pass through sphere from front")]
95 [TestCase(20f, 20f, 100f, 50f, 50f, 50f, true)] // from above to sphere 95 [TestCase(50f, 100f, 50f, 150f, 100f, 50f, true, "Pass through sphere from side")]
96 [TestCase(50f, 50f, 50f, 150f, 150f, 50f, true)] // through sphere 96 [TestCase(50f, 50f, 50f, 150f, 150f, 50f, true, "Pass through sphere diaginally")]
97 [TestCase(50f, 50f, 65f, 150f, 150f, 65f, false)] // pass over sphere 97 [TestCase(100f, 100f, 100f, 100f, 100f, 20f, true, "Pass through sphere from above")]
98 public void RaycastAroundObject(float fromX, float fromY, float fromZ, float toX, float toY, float toZ, bool expected) { 98 [TestCase(20f, 20f, 50f, 80f, 80f, 50f, false, "Not reach sphere")]
99 [TestCase(50f, 50f, 65f, 150f, 150f, 65f, false, "Passed over sphere")]
100 public void RaycastAroundObject(float fromX, float fromY, float fromZ, float toX, float toY, float toZ, bool expected, string msg) {
99 Vector3 fromPos = new Vector3(fromX, fromY, fromZ); 101 Vector3 fromPos = new Vector3(fromX, fromY, fromZ);
100 Vector3 toPos = new Vector3(toX, toY, toZ); 102 Vector3 toPos = new Vector3(toX, toY, toZ);
101 Vector3 direction = toPos - fromPos; 103 Vector3 direction = toPos - fromPos;
102 float len = Vector3.Distance(fromPos, toPos); 104 float len = Vector3.Distance(fromPos, toPos);
103 105
104 List<ContactResult> results = PhysicsScene.RaycastWorld(fromPos, direction, len, 1); 106 List<ContactResult> results = _physicsScene.RaycastWorld(fromPos, direction, len, 1);
105 107
106 if (expected) { 108 if (expected) {
107 Assert.True(results.Count > 0); 109 // The test coordinates should generate a hit
110 Assert.True(results.Count != 0, msg + ": Did not return a hit but expected to.");
111 Assert.True(results.Count == 1, msg + ": Raycast returned not just one hit result.");
112 Assert.True(results[0].ConsumerID == _targetLocalID, msg + ": Raycast returned a collision object other than the target");
108 } 113 }
109 else 114 else
110 { 115 {
111 Assert.False(results.Count > 0); 116 // The test coordinates should not generate a hit
117 if (results.Count > 0)
118 {
119 Assert.False(results.Count > 0, msg + ": Returned a hit at " + results[0].Pos.ToString());
120 }
112 } 121 }
113 } 122 }
114 } 123 }