trying new jitter method for soft shadows, getting better
git-svn-id: svn://anubis/fart/trunk@257 7f9b0f55-74a9-4bce-be96-3c2cd072584d
This commit is contained in:
parent
eb14077ab7
commit
57a4e6ed8a
@ -28,7 +28,7 @@ class Light
|
||||
}
|
||||
const Color & getSpecularColor() const { return m_specular_color; }
|
||||
|
||||
void setJitter(int j) { m_jitter = j; }
|
||||
void setJitter(int j) { m_jitter = j >= 1 ? j : 1; }
|
||||
int getJitter() const { return m_jitter; }
|
||||
|
||||
void setRadius(double r) { m_radius = r; }
|
||||
|
@ -1,5 +1,5 @@
|
||||
|
||||
#include <math.h> /* exp(), pow() */
|
||||
#include <math.h> /* exp(), pow(), M_PI */
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <string>
|
||||
@ -224,12 +224,28 @@ Color Scene::computePhong(const refptr<Material> material,
|
||||
it != m_lights.end();
|
||||
it++)
|
||||
{
|
||||
for (int jitter_index = 0, jitter_max = (*it)->getJitter();
|
||||
jitter_index < jitter_max;
|
||||
jitter_index++)
|
||||
Vector lightC = (*it)->getPosition();
|
||||
double lightRadius = (*it)->getRadius();
|
||||
Vector directionToLightC = lightC - surfacePoint;
|
||||
Vector lightPlaneX = directionToLightC.getPerpendicular().normalize();
|
||||
Vector lightPlaneY = (directionToLightC * lightPlaneX).normalize();
|
||||
int jitter_samples = 0, jitter_level = (*it)->getJitter();;
|
||||
for (int jitter_index = 0; jitter_index < jitter_level; jitter_index++)
|
||||
{
|
||||
Vector lightPosition = (*it)->getJitterPosition(jitter_index);
|
||||
Vector directionToLight = lightPosition - surfacePoint;
|
||||
#if 0
|
||||
double offset = ((double)rand()) / RAND_MAX * M_2_PI;
|
||||
#endif
|
||||
double offset = 0.0;
|
||||
double jitterRadius = jitter_index * lightRadius
|
||||
/ (jitter_level - 0.5);
|
||||
for (int i = 0, num = (int) (M_PI * jitter_index) + 1; i < num; i++)
|
||||
{
|
||||
jitter_samples++;
|
||||
double jitter_angle = offset + i * M_2_PI / num;
|
||||
Vector jitterPosition = lightC
|
||||
+ lightPlaneX * jitterRadius * cos(jitter_angle)
|
||||
+ lightPlaneY * jitterRadius * sin(jitter_angle);
|
||||
Vector directionToLight = jitterPosition - surfacePoint;
|
||||
directionToLight.normalize();
|
||||
Vector reflectedLightDirection =
|
||||
directionToLight.reflect(surfaceNormal);
|
||||
@ -237,7 +253,7 @@ Color Scene::computePhong(const refptr<Material> material,
|
||||
Ray surfaceToLight(surfacePoint, directionToLight);
|
||||
Color light_contribution =
|
||||
calculateLightContribution(surfaceToLight.shift(0.0001),
|
||||
lightPosition);
|
||||
jitterPosition);
|
||||
|
||||
if ( light_contribution.r > 0.0
|
||||
|| light_contribution.g > 0.0
|
||||
@ -250,8 +266,7 @@ Color Scene::computePhong(const refptr<Material> material,
|
||||
result += diffuseColor
|
||||
* (*it)->getDiffuseColor()
|
||||
* diffuse_coef
|
||||
* light_contribution
|
||||
/ jitter_max;
|
||||
* light_contribution;
|
||||
}
|
||||
|
||||
/* calculate the specular term */
|
||||
@ -261,12 +276,13 @@ Color Scene::computePhong(const refptr<Material> material,
|
||||
result += specularColor
|
||||
* (*it)->getSpecularColor()
|
||||
* pow(specular_coef, shininess)
|
||||
* light_contribution
|
||||
/ jitter_max;
|
||||
* light_contribution;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
result /= jitter_samples;
|
||||
}
|
||||
|
||||
return result;
|
||||
}
|
||||
|
@ -15,7 +15,7 @@ scene
|
||||
light
|
||||
{
|
||||
position <-1, -3, 4>
|
||||
jitter 50
|
||||
jitter 3
|
||||
}
|
||||
|
||||
plane
|
||||
|
@ -87,6 +87,22 @@ Color & Color::operator*=(const Color & other)
|
||||
return *this;
|
||||
}
|
||||
|
||||
Color & Color::operator/=(double scale)
|
||||
{
|
||||
r /= scale;
|
||||
g /= scale;
|
||||
b /= scale;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Color & Color::operator/=(const Color & other)
|
||||
{
|
||||
r /= other.r;
|
||||
g /= other.g;
|
||||
b /= other.b;
|
||||
return *this;
|
||||
}
|
||||
|
||||
Color operator+(const Color & c1, const Color & c2)
|
||||
{
|
||||
return Color(c1.r + c2.r, c1.g + c2.g, c1.b + c2.b);
|
||||
|
@ -23,6 +23,8 @@ class Color
|
||||
Color & operator-=(const Color & other);
|
||||
Color & operator*=(double scale);
|
||||
Color & operator*=(const Color & other);
|
||||
Color & operator/=(double scale);
|
||||
Color & operator/=(const Color & other);
|
||||
|
||||
static const Color black;
|
||||
static const Color white;
|
||||
|
@ -83,7 +83,7 @@ Vector Vector::reflect(const Vector & target) const
|
||||
return (*this) + me_to_proj * 2.0;
|
||||
}
|
||||
|
||||
Vector Vector::getPerpendicularVector() const
|
||||
Vector Vector::getPerpendicular() const
|
||||
{
|
||||
Vector t = *this;
|
||||
t.normalize();
|
||||
|
@ -20,7 +20,7 @@ class Vector
|
||||
Vector proj(const Vector & target) const;
|
||||
Vector reflect(const Vector & target) const;
|
||||
operator double() const { return mag(); }
|
||||
Vector getPerpendicularVector() const;
|
||||
Vector getPerpendicular() const;
|
||||
|
||||
protected:
|
||||
double m_array[3];
|
||||
|
Loading…
x
Reference in New Issue
Block a user