Iterator<ContactPoint> i = g.getContacts();
while (i.hasNext()) {
ContactPoint cp = i.next();
System.out.println(cp.point);
System.out.println("dist="+cp.distance);
result.add(new Vector3(cp.point));
}
// expected contact points, in counter clock-wise order
expect.clear();
expect.add(new Vector3(0.5,0.75,0.5));
expect.add(new Vector3(-0.5,0.75,0.5));
expect.add(new Vector3(-0.5,0.75,-0.5));
expect.add(new Vector3(0.5,0.75,-0.5));
// check
assertTrue(verifyPolygon(expect, result));
/*
* Test 2, displace along negative y-axis
*/
// displace box2
body2.setPosition(0, -1.5, 0);
// run contact point generation
g.run();
// extract contact points
result.clear();
i = g.getContacts();
while (i.hasNext()) {
ContactPoint cp = i.next();
System.out.println(cp.point);
System.out.println("dist="+cp.distance);
result.add(new Vector3(cp.point));
}
// expected contact points, in counter clock-wise order
expect.clear();
expect.add(new Vector3( 0.5,-0.75,-0.5));
expect.add(new Vector3(-0.5,-0.75,-0.5));
expect.add(new Vector3(-0.5,-0.75, 0.5));
expect.add(new Vector3( 0.5,-0.75, 0.5));
// check
assertTrue(verifyPolygon(expect, result));
/*
* Test 3, displace along positive x-axis
*/
// displace box2
body2.setPosition(1.5, 0, 0);
// run contact point generation
g.run();
// extract contact points
result.clear();
i = g.getContacts();
while (i.hasNext()) {
ContactPoint cp = i.next();
System.out.println(cp.point);
System.out.println("dist="+cp.distance);
result.add(new Vector3(cp.point));
}
// expected contact points, in counter clock-wise order
expect.clear();
expect.add(new Vector3( 0.75, 0.5, 0.5));
expect.add(new Vector3( 0.75, 0.5,-0.5));
expect.add(new Vector3( 0.75,-0.5,-0.5));
expect.add(new Vector3( 0.75,-0.5, 0.5));
// check
assertTrue(verifyPolygon(expect, result));
}