2001-10-22 05:27:40 +08:00
|
|
|
#include <osg/BoundingSphere>
|
2002-06-19 23:18:47 +08:00
|
|
|
#include <osg/BoundingBox>
|
2001-01-11 00:32:10 +08:00
|
|
|
|
|
|
|
using namespace osg;
|
|
|
|
|
|
|
|
void BoundingSphere::expandBy(const Vec3& v)
|
|
|
|
{
|
2002-06-19 23:18:47 +08:00
|
|
|
if (valid())
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
|
|
|
Vec3 dv = v-_center;
|
|
|
|
float r = dv.length();
|
|
|
|
if (r>_radius)
|
2001-09-20 05:08:56 +08:00
|
|
|
{
|
2001-01-11 00:32:10 +08:00
|
|
|
float dr = (r-_radius)*0.5f;
|
|
|
|
_center += dv*(dr/r);
|
|
|
|
_radius += dr;
|
2002-06-19 23:18:47 +08:00
|
|
|
} // else do nothing as vertex is within sphere.
|
2001-01-11 00:32:10 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_center = v;
|
|
|
|
_radius = 0.0f;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
|
2001-01-11 00:32:10 +08:00
|
|
|
void BoundingSphere::expandRadiusBy(const Vec3& v)
|
|
|
|
{
|
2002-06-19 23:18:47 +08:00
|
|
|
if (valid())
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
|
|
|
float r = (v-_center).length();
|
|
|
|
if (r>_radius) _radius = r;
|
|
|
|
// else do nothing as vertex is within sphere.
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_center = v;
|
|
|
|
_radius = 0.0f;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-09-20 05:08:56 +08:00
|
|
|
|
2001-01-11 00:32:10 +08:00
|
|
|
void BoundingSphere::expandBy(const BoundingSphere& sh)
|
|
|
|
{
|
2002-06-19 23:18:47 +08:00
|
|
|
if (sh.valid())
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
2002-06-19 23:18:47 +08:00
|
|
|
if (valid())
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
|
|
|
Vec3 dv = sh._center-_center;
|
|
|
|
float dv_len = dv.length();
|
|
|
|
if (dv_len+sh._radius>_radius)
|
|
|
|
{
|
|
|
|
Vec3 e1 = _center-(dv*(_radius/dv_len));
|
|
|
|
Vec3 e2 = sh._center+(dv*(sh._radius/dv_len));
|
|
|
|
_center = (e1+e2)*0.5f;
|
|
|
|
_radius = (e2-_center).length();
|
2001-09-20 05:08:56 +08:00
|
|
|
|
|
|
|
} // else do nothing as vertex is within sphere.
|
2001-01-11 00:32:10 +08:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_center = sh._center;
|
|
|
|
_radius = sh._radius;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2001-09-20 05:08:56 +08:00
|
|
|
|
|
|
|
|
2001-01-11 00:32:10 +08:00
|
|
|
void BoundingSphere::expandRadiusBy(const BoundingSphere& sh)
|
|
|
|
{
|
2002-06-19 23:18:47 +08:00
|
|
|
if (sh.valid())
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
2002-06-19 23:18:47 +08:00
|
|
|
if (valid())
|
2001-01-11 00:32:10 +08:00
|
|
|
{
|
|
|
|
float r = (sh._center-_center).length()+sh._radius;
|
|
|
|
if (r>_radius) _radius = r;
|
|
|
|
// else do nothing as vertex is within sphere.
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_center = sh._center;
|
|
|
|
_radius = sh._radius;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2002-06-19 23:18:47 +08:00
|
|
|
|
|
|
|
void BoundingSphere::expandBy(const BoundingBox& bb)
|
|
|
|
{
|
|
|
|
if (bb.valid())
|
|
|
|
{
|
|
|
|
if (valid())
|
|
|
|
{
|
|
|
|
BoundingBox newbb(bb);
|
|
|
|
|
|
|
|
for(unsigned int c=0;c<8;++c)
|
|
|
|
{
|
|
|
|
Vec3 v = bb.corner(c)-_center; // get the direction vector from corner
|
|
|
|
v.normalize(); // normalise it.
|
|
|
|
v *= -_radius; // move the vector in the opposite direction distance radius.
|
|
|
|
v += _center; // move to absolute position.
|
|
|
|
newbb.expandBy(v); // add it into the new bounding box.
|
|
|
|
}
|
|
|
|
|
|
|
|
_center = newbb.center();
|
|
|
|
_radius = newbb.radius();
|
|
|
|
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_center = bb.center();
|
|
|
|
_radius = bb.radius();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void BoundingSphere::expandRadiusBy(const BoundingBox& bb)
|
|
|
|
{
|
|
|
|
if (bb.valid())
|
|
|
|
{
|
|
|
|
if (valid())
|
|
|
|
{
|
|
|
|
for(unsigned int c=0;c<8;++c)
|
|
|
|
{
|
|
|
|
expandRadiusBy(bb.corner(c));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
_center = bb.center();
|
|
|
|
_radius = bb.radius();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|