Return check for distance when we try to reuse data (bug #6026)

pull/3084/head
Andrei Kortunov 4 years ago
parent 2042a66cf3
commit 3e281f625d

@ -141,9 +141,9 @@ ViewData *ViewDataMap::getViewData(osg::Object *viewer, const osg::Vec3f& viewPo
vd = found->second;
needsUpdate = false;
if (!(vd->suitableToUse(activeGrid) && (vd->getViewPoint()-viewPoint).length2() < mReuseDistance*mReuseDistance && vd->getWorldUpdateRevision() >= mWorldUpdateRevision))
if (!vd->suitableToUse(activeGrid) || (vd->getViewPoint()-viewPoint).length2() >= mReuseDistance*mReuseDistance || vd->getWorldUpdateRevision() < mWorldUpdateRevision)
{
float shortestDist = std::numeric_limits<float>::max();
float shortestDist = mReuseDistance*mReuseDistance;
const ViewData* mostSuitableView = nullptr;
for (const ViewData* other : mUsedViews)
{
@ -157,11 +157,16 @@ ViewData *ViewDataMap::getViewData(osg::Object *viewer, const osg::Vec3f& viewPo
}
}
}
if (mostSuitableView && mostSuitableView != vd)
if (mostSuitableView)
{
vd->copyFrom(*mostSuitableView);
return vd;
}
else
{
vd->setViewPoint(viewPoint);
needsUpdate = true;
}
}
if (!vd->suitableToUse(activeGrid))
{

Loading…
Cancel
Save