mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-09 21:42:13 +00:00
37 lines
991 B
C++
37 lines
991 B
C++
|
#include "util.hpp"
|
||
|
|
||
|
namespace SceneUtil
|
||
|
{
|
||
|
|
||
|
void transformBoundingSphere (const osg::Matrix& matrix, osg::BoundingSphere& bsphere)
|
||
|
{
|
||
|
osg::BoundingSphere::vec_type xdash = bsphere._center;
|
||
|
xdash.x() += bsphere._radius;
|
||
|
xdash = xdash*matrix;
|
||
|
|
||
|
osg::BoundingSphere::vec_type ydash = bsphere._center;
|
||
|
ydash.y() += bsphere._radius;
|
||
|
ydash = ydash*matrix;
|
||
|
|
||
|
osg::BoundingSphere::vec_type zdash = bsphere._center;
|
||
|
zdash.z() += bsphere._radius;
|
||
|
zdash = zdash*matrix;
|
||
|
|
||
|
bsphere._center = bsphere._center*matrix;
|
||
|
|
||
|
xdash -= bsphere._center;
|
||
|
osg::BoundingSphere::value_type len_xdash = xdash.length();
|
||
|
|
||
|
ydash -= bsphere._center;
|
||
|
osg::BoundingSphere::value_type len_ydash = ydash.length();
|
||
|
|
||
|
zdash -= bsphere._center;
|
||
|
osg::BoundingSphere::value_type len_zdash = zdash.length();
|
||
|
|
||
|
bsphere._radius = len_xdash;
|
||
|
if (bsphere._radius<len_ydash) bsphere._radius = len_ydash;
|
||
|
if (bsphere._radius<len_zdash) bsphere._radius = len_zdash;
|
||
|
}
|
||
|
|
||
|
}
|