Transform3D transform3D = new Transform3D();
trunkTransformGroup.getTransform(transform3D);
// check bottom of trunk
Shape3D bottom = trunkCylinder.getShape(Cylinder.BOTTOM);
BoundingBox bottomBounds = (BoundingBox) bottom.getBounds();
Point3d lowerBottom = new Point3d();
bottomBounds.getLower(lowerBottom);
Point3d movedLowerBottom = new Point3d();
transform3D.transform(lowerBottom, movedLowerBottom);
Point3d upperBottom = new Point3d();
bottomBounds.getUpper(upperBottom);
Point3d movedUpperBottom = new Point3d();
transform3D.transform(upperBottom, movedUpperBottom);
PointTestHelper.assertPointEquals(expectedLowerBottom, lowerBottom, 0.02, 0.0001, 0.02);
PointTestHelper.assertPointEquals(expectedMovedLowerBottom, movedLowerBottom, 0.02, 0.0001, 0.02);
PointTestHelper.assertPointEquals(expectedUpperBottom, upperBottom, 0.02, 0.0001, 0.02);
PointTestHelper.assertPointEquals(expectedMovedUpperBottom, movedUpperBottom, 0.02, 0.0001, 0.02);
// check top of trunk
Shape3D top = trunkCylinder.getShape(Cylinder.TOP);
BoundingBox topBounds = (BoundingBox) top.getBounds();
Point3d lowerTop = new Point3d();
topBounds.getLower(lowerTop);
Point3d movedLowerTop = new Point3d();
transform3D.transform(lowerTop, movedLowerTop);
Point3d upperTop = new Point3d();
topBounds.getUpper(upperTop);
Point3d movedUpperTop = new Point3d();
transform3D.transform(upperTop, movedUpperTop);
PointTestHelper.assertPointEquals(expectedLowerTop, lowerTop, 0.02, 0.0001, 0.02);
PointTestHelper.assertPointEquals(expectedMovedLowerTop, movedLowerTop, 0.02, 0.0001, 0.02);
PointTestHelper.assertPointEquals(expectedUpperTop, upperTop, 0.02, 0.0001, 0.02);