|
|
@ -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
|
|
|
|