|
|
@ -7,6 +7,10 @@
|
|
|
|
#include <osg/Matrixd>
|
|
|
|
#include <osg/Matrixd>
|
|
|
|
#include <osg/Quat>
|
|
|
|
#include <osg/Quat>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include <osgUtil/LineSegmentIntersector>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#include "mask.hpp"
|
|
|
|
|
|
|
|
|
|
|
|
namespace CSVRender
|
|
|
|
namespace CSVRender
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
|
@ -481,10 +485,30 @@ namespace CSVRender
|
|
|
|
{
|
|
|
|
{
|
|
|
|
static const int DefaultStartDistance = 10000.f;
|
|
|
|
static const int DefaultStartDistance = 10000.f;
|
|
|
|
|
|
|
|
|
|
|
|
osg::Vec3d eye, up;
|
|
|
|
// Try to intelligently pick focus object
|
|
|
|
getCamera()->getViewMatrixAsLookAt(eye, mCenter, up, DefaultStartDistance);
|
|
|
|
osg::ref_ptr<osgUtil::LineSegmentIntersector> intersector (new osgUtil::LineSegmentIntersector(
|
|
|
|
|
|
|
|
osgUtil::Intersector::PROJECTION, osg::Vec3d(0, 0, 0), LocalForward));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
intersector->setIntersectionLimit(osgUtil::LineSegmentIntersector::LIMIT_NEAREST);
|
|
|
|
|
|
|
|
osgUtil::IntersectionVisitor visitor(intersector);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
visitor.setTraversalMask(Mask_Reference | Mask_Terrain);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
getCamera()->accept(visitor);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
osg::Vec3d eye, center, up;
|
|
|
|
|
|
|
|
getCamera()->getViewMatrixAsLookAt(eye, center, up, DefaultStartDistance);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (intersector->getIntersections().begin() != intersector->getIntersections().end())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mCenter = intersector->getIntersections().begin()->getWorldIntersectPoint();
|
|
|
|
|
|
|
|
mDistance = (eye - center).length();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mCenter = center;
|
|
|
|
mDistance = DefaultStartDistance;
|
|
|
|
mDistance = DefaultStartDistance;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
mInitialized = true;
|
|
|
|
mInitialized = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|