Merge pull request #2231 from akortunov/warnfix

Get rid of C-style limits in the shadows code
pull/541/head
Chris Djali 6 years ago committed by GitHub
commit c328c4a010
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -30,6 +30,8 @@ namespace {
using namespace osgShadow; using namespace osgShadow;
using namespace SceneUtil; using namespace SceneUtil;
#define dbl_max std::numeric_limits<double>::max()
////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////
// fragment shader // fragment shader
// //
@ -928,7 +930,7 @@ void MWShadowTechnique::cull(osgUtil::CullVisitor& cv)
viewProjectionMatrix(2,3)==0.0; viewProjectionMatrix(2,3)==0.0;
double minZNear = 0.0; double minZNear = 0.0;
double maxZFar = DBL_MAX; double maxZFar = dbl_max;
if (cachedNearFarMode==osg::CullSettings::DO_NOT_COMPUTE_NEAR_FAR) if (cachedNearFarMode==osg::CullSettings::DO_NOT_COMPUTE_NEAR_FAR)
{ {
@ -1088,8 +1090,8 @@ void MWShadowTechnique::cull(osgUtil::CullVisitor& cv)
double yRange = (clsb._bb.yMax()-clsb._bb.yMin()); double yRange = (clsb._bb.yMax()-clsb._bb.yMin());
osg::Matrixd cornerConverter = osg::Matrixd::inverse(projectionMatrix) * osg::Matrixd::inverse(viewMatrix) * *cv.getModelViewMatrix(); osg::Matrixd cornerConverter = osg::Matrixd::inverse(projectionMatrix) * osg::Matrixd::inverse(viewMatrix) * *cv.getModelViewMatrix();
double minZ = DBL_MAX; double minZ = dbl_max;
double maxZ = -DBL_MAX; double maxZ = -dbl_max;
clsb._bb._max[2] = 1.0; clsb._bb._max[2] = 1.0;
for (unsigned int i = 0; i < 8; i++) for (unsigned int i = 0; i < 8; i++)
{ {
@ -1777,7 +1779,7 @@ bool MWShadowTechnique::computeShadowCameraSettings(Frustum& frustum, LightData&
} }
else else
{ {
double zMax=-DBL_MAX; double zMax=-dbl_max;
OSG_INFO<<"lightDir = "<<positionedLight.lightDir<<std::endl; OSG_INFO<<"lightDir = "<<positionedLight.lightDir<<std::endl;
OSG_INFO<<"lightPos3 = "<<positionedLight.lightPos3<<std::endl; OSG_INFO<<"lightPos3 = "<<positionedLight.lightPos3<<std::endl;
@ -2155,13 +2157,13 @@ struct ConvexHull
{ {
center += *itr; center += *itr;
center.x() = osg::maximum(center.x(), -DBL_MAX); center.x() = osg::maximum(center.x(), -dbl_max);
center.y() = osg::maximum(center.y(), -DBL_MAX); center.y() = osg::maximum(center.y(), -dbl_max);
center.z() = osg::maximum(center.z(), -DBL_MAX); center.z() = osg::maximum(center.z(), -dbl_max);
center.x() = osg::minimum(center.x(), DBL_MAX); center.x() = osg::minimum(center.x(), dbl_max);
center.y() = osg::minimum(center.y(), DBL_MAX); center.y() = osg::minimum(center.y(), dbl_max);
center.z() = osg::minimum(center.z(), DBL_MAX); center.z() = osg::minimum(center.z(), dbl_max);
} }
center /= double(intersections.size()); center /= double(intersections.size());
@ -2227,7 +2229,7 @@ struct ConvexHull
double min(unsigned int index) const double min(unsigned int index) const
{ {
double m = DBL_MAX; double m = dbl_max;
for(Edges::const_iterator itr = _edges.begin(); for(Edges::const_iterator itr = _edges.begin();
itr != _edges.end(); itr != _edges.end();
++itr) ++itr)
@ -2241,7 +2243,7 @@ struct ConvexHull
double max(unsigned int index) const double max(unsigned int index) const
{ {
double m = -DBL_MAX; double m = -dbl_max;
for(Edges::const_iterator itr = _edges.begin(); for(Edges::const_iterator itr = _edges.begin();
itr != _edges.end(); itr != _edges.end();
++itr) ++itr)
@ -2255,7 +2257,7 @@ struct ConvexHull
double minRatio(const osg::Vec3d& eye, unsigned int index) const double minRatio(const osg::Vec3d& eye, unsigned int index) const
{ {
double m = DBL_MAX; double m = dbl_max;
osg::Vec3d delta; osg::Vec3d delta;
double ratio; double ratio;
for(Edges::const_iterator itr = _edges.begin(); for(Edges::const_iterator itr = _edges.begin();
@ -2277,7 +2279,7 @@ struct ConvexHull
double maxRatio(const osg::Vec3d& eye, unsigned int index) const double maxRatio(const osg::Vec3d& eye, unsigned int index) const
{ {
double m = -DBL_MAX; double m = -dbl_max;
osg::Vec3d delta; osg::Vec3d delta;
double ratio; double ratio;
for(Edges::const_iterator itr = _edges.begin(); for(Edges::const_iterator itr = _edges.begin();
@ -2321,10 +2323,10 @@ struct RenderLeafBounds
clip_min_x(-1.0), clip_max_x(1.0), clip_min_x(-1.0), clip_max_x(1.0),
clip_min_y(-1.0), clip_max_y(1.0), clip_min_y(-1.0), clip_max_y(1.0),
clip_min_z(-1.0), clip_max_z(1.0), clip_min_z(-1.0), clip_max_z(1.0),
clip_min_x_ratio(-DBL_MAX), clip_max_x_ratio(DBL_MAX), clip_min_x_ratio(-dbl_max), clip_max_x_ratio(dbl_max),
clip_min_z_ratio(-DBL_MAX), clip_max_z_ratio(DBL_MAX), clip_min_z_ratio(-dbl_max), clip_max_z_ratio(dbl_max),
min_x_ratio(DBL_MAX), max_x_ratio(-DBL_MAX), min_x_ratio(dbl_max), max_x_ratio(-dbl_max),
min_z_ratio(DBL_MAX), max_z_ratio(-DBL_MAX), min_z_ratio(dbl_max), max_z_ratio(-dbl_max),
min_x(1.0), max_x(-1.0), min_x(1.0), max_x(-1.0),
min_y(1.0), max_y(-1.0), min_y(1.0), max_y(-1.0),
min_z(1.0), max_z(-1.0) min_z(1.0), max_z(-1.0)
@ -2336,12 +2338,12 @@ struct RenderLeafBounds
{ {
computeRatios = false; computeRatios = false;
light_p = p; light_p = p;
clip_min_x = -DBL_MAX; clip_max_x = DBL_MAX; clip_min_x = -dbl_max; clip_max_x = dbl_max;
clip_min_y = -DBL_MAX; clip_max_y = DBL_MAX; clip_min_y = -dbl_max; clip_max_y = dbl_max;
clip_min_z = -DBL_MAX; clip_max_z = DBL_MAX; clip_min_z = -dbl_max; clip_max_z = dbl_max;
min_x = DBL_MAX; max_x = -DBL_MAX; min_x = dbl_max; max_x = -dbl_max;
min_y = DBL_MAX; max_y = -DBL_MAX; min_y = dbl_max; max_y = -dbl_max;
min_z = DBL_MAX; max_z = -DBL_MAX; min_z = dbl_max; max_z = -dbl_max;
} }
void set(const osg::Matrixd& p, osg::Vec3d& e_ls, double nr) void set(const osg::Matrixd& p, osg::Vec3d& e_ls, double nr)
@ -2808,11 +2810,11 @@ bool MWShadowTechnique::adjustPerspectiveShadowMapCameraSettings(osgUtil::Render
double min_x_ratio = 0.0; double min_x_ratio = 0.0;
double max_x_ratio = 0.0; double max_x_ratio = 0.0;
double min_z_ratio = FLT_MAX; double min_z_ratio = dbl_max;
double max_z_ratio = -FLT_MAX; double max_z_ratio = -dbl_max;
min_x_ratio = convexHull.valid() ? convexHull.minRatio(virtual_eye,0) : -DBL_MAX; min_x_ratio = convexHull.valid() ? convexHull.minRatio(virtual_eye,0) : -dbl_max;
max_x_ratio = convexHull.valid() ? convexHull.maxRatio(virtual_eye,0) : DBL_MAX; max_x_ratio = convexHull.valid() ? convexHull.maxRatio(virtual_eye,0) : dbl_max;
//min_z_ratio = convexHull.minRatio(virtual_eye,2); //min_z_ratio = convexHull.minRatio(virtual_eye,2);
//max_z_ratio = convexHull.maxRatio(virtual_eye,2); //max_z_ratio = convexHull.maxRatio(virtual_eye,2);
@ -2856,9 +2858,9 @@ bool MWShadowTechnique::adjustPerspectiveShadowMapCameraSettings(osgUtil::Render
if (rli.min_x_ratio>min_x_ratio) min_x_ratio = rli.min_x_ratio; if (rli.min_x_ratio>min_x_ratio) min_x_ratio = rli.min_x_ratio;
if (rli.max_x_ratio<max_x_ratio) max_x_ratio = rli.max_x_ratio; if (rli.max_x_ratio<max_x_ratio) max_x_ratio = rli.max_x_ratio;
if (min_z_ratio == FLT_MAX || rli.min_z_ratio > min_z_ratio) if (min_z_ratio == dbl_max || rli.min_z_ratio > min_z_ratio)
min_z_ratio = rli.min_z_ratio; min_z_ratio = rli.min_z_ratio;
if (max_z_ratio == -FLT_MAX || rli.max_z_ratio < max_z_ratio) if (max_z_ratio == -dbl_max || rli.max_z_ratio < max_z_ratio)
max_z_ratio = rli.max_z_ratio; max_z_ratio = rli.max_z_ratio;
} }
#endif #endif

Loading…
Cancel
Save