本文整理汇总了C++中PointLight::position方法的典型用法代码示例。如果您正苦于以下问题:C++ PointLight::position方法的具体用法?C++ PointLight::position怎么用?C++ PointLight::position使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类PointLight
的用法示例。
在下文中一共展示了PointLight::position方法的11个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: sqrt
Vector3
Lambert::shade(const Ray& ray, const HitInfo& hit, const Scene& scene) const
{
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const Lights *lightlist = scene.lights();
// loop over all of the lights
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Vector3 l = pLight->position() - hit.P;
// the inverse-squared falloff
float falloff = l.length2();
// normalize the light direction
l /= sqrt(falloff);
// get the irradiance
Vector3 irradiance = (pLight->color() * pLight->wattage()) * std::max(0.0f, dot(hit.N, l)) / (4.0 * PI * falloff);
L += irradiance * (m_kd / PI);
}
return L;
}
示例2: glFinish
void
Scene::raytraceImage(Camera *cam, Image *img)
{
Ray ray;
HitInfo hitInfo;
Vector3 shadeResult;
bIntersect = 0;
tIntersect = 0;
bool useShadows = false;
// loop over all pixels in the image
for (int j = 0; j < img->height(); ++j)
{
for (int i = 0; i < img->width(); ++i)
{
ray = cam->eyeRay(i, j, img->width(), img->height());
hitInfo.boxHit = 0;
hitInfo.triHit = 0;
if (trace(hitInfo, ray))
{
// printf("Traced...\n");
hitInfo.u = i;
hitInfo.v = j;
const Material * mat = hitInfo.material;
shadeResult = mat->shade(ray, hitInfo, *this);
if (useShadows) {
Lights::const_iterator lightIter;
ray.o = hitInfo.P;
for (lightIter = m_lights.begin(); lightIter != m_lights.end(); lightIter++)
{
PointLight* pLight = *lightIter;
ray.d = pLight->position() - hitInfo.P;
ray.d.normalize();
ray.o = ray.o + ray.d * epsilon;
if (trace(hitInfo, ray)) {
if (hitInfo.t > EPSILON) {
shadeResult = Vector3(0);
break;
}
}
}
}
img->setPixel(i, j, shadeResult);
}
// bIntersect += hitInfo.boxHit;
tIntersect += hitInfo.triHit;
bIntersect += hitInfo.boxHit;
}
img->drawScanline(j);
glFinish();
// printf("Rendering Progress: %.3f%%\r", j/float(img->height())*100.0f);
fflush(stdout);
}
printf("Rendering Progress: 100.000%\n");
debug("done Raytracing!\n");
printStats();
}
示例3: sqrt
Vector3
SpecularRefractionShading::shade(const Ray& ray, const HitInfo& hit, const Scene& scene) const
{
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const Lights *lightlist = scene.lights();
// loop over all of the lights
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Vector3 l = pLight->position() - hit.P;
// the inverse-squared falloff
float falloff = l.length2();
// normalize the light direction
l /= sqrt(falloff);
// get the diffuse component
float nDotL = dot(hit.N, l);
Vector3 result = pLight->color();
result *= m_kd;
L += std::max(0.0f, nDotL / falloff * pLight->wattage() / PI) * result;
Vector3 r = (-l + 2 * dot(l, hit.N) * hit.N).normalized();
float eDotR = dot(viewDir, r);
eDotR = 0.0f > eDotR ? 0.0f : 1.0f < eDotR ? 1.0f : eDotR; // clamp it to [0..1]
eDotR = pow(eDotR, 3);
L += std::max(0.0f, eDotR * falloff * pLight->wattage());
}
// add the ambient component
L += m_ka;
return L;
}
示例4: sqrt
Vector3
Lambert::shade(const Ray& ray, const HitInfo& hit, const Scene& scene, int bounce)
{
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const PointLights *lightlist = scene.lights();
// loop over all of the lights
PointLights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Vector3 l = pLight->position() - hit.P;
// the inverse-squared falloff
float falloff = l.length2();
// normalize the light direction
l /= sqrt(falloff);
// get the diffuse component
float nDotL = dot(hit.N, l);
Vector3 result = pLight->color();
result *= m_kd;
L += std::max(0.0f, nDotL/falloff * pLight->wattage() / PI) * result;
}
// add the ambient component
L += m_ka;
return L;
}
示例5: r
Vector3
Lambert::shade(const Ray& ray, const HitInfo& hit, const Scene& scene) const
{
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const Lights *lightlist = scene.lights();
// reflectance
if (m_ks != 0 && ray.times <3) {
Vector3 Wr = -2 * dot(ray.d, hit.N) * hit.N + ray.d;
Wr.normalize();
Ray r(hit.P + (EPSILON * Wr), Wr);
HitInfo hi;
r.times = ray.times + 1;
if(scene.trace(hi, r))
L += m_spec * m_ks * hi.material->shade(r, hi, scene);
}
// cellular noise texture
if(m_noisiness > 0) {
float at[3] = { hit.P.x, hit.P.y, hit.P.z };
const long mO = 3;
float F[mO];
float delta[mO][3];
unsigned long *ID = new unsigned long();
WorleyNoise::noise3D(at, mO, F, delta, ID);
L += m_noisiness * (0.5f * (F[2] - F[1]));// + PerlinNoise::noise(at[0], at[1], at[2]));
}
// loop over all of the lights
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Vector3 l = pLight->position() - hit.P;
// the inverse-squared falloff
float falloff = l.length2();
// normalize the light direction
l /= sqrt(falloff);
// get the diffuse component
float nDotL = dot(hit.N, l);
Vector3 result = pLight->color();
result *= f_diff * m_kd;
L += std::max(0.0f, nDotL/falloff * pLight->wattage() / PI) * result;
// highlights
//if (m_ks != 0)
L += m_spec * pLight->color() * m_ks * max(0.f, pow(dot(viewDir, l), SPECULAR_CONST));
// / dot(hit.N, l);
}
// refraction
if (m_trans != 0 && ray.times <3) {
float n = (ray.times % 2 == 0) ? (ENV_INDEX / m_refInd) : (m_refInd / ENV_INDEX);
float wn = dot(viewDir, hit.N);
if (wn < 0) wn = -wn;
Vector3 Wt = -1 * n * (viewDir - wn * hit.N) -
sqrtf(1 - (n * n) * (1 - wn * wn)) * hit.N;
Wt.normalize();
Ray r(hit.P + (EPSILON * Wt), Wt);
r.times = ray.times + 1;
HitInfo hi;
if (scene.trace(hi, r))
L += m_trans * m_kt * hi.material->shade(r, hi, scene);
}
// add the ambient component
L += m_ka;
if(DO_BOUNCE && ray.times < BOUNCES) {
float v = rand() / (float)RAND_MAX;
float u = rand() / (float)RAND_MAX;
Vector3 coord = hemisphereSample_cos(u,v);
Vector3 unv = Vector3(rand() / (float)RAND_MAX, rand() / (float)RAND_MAX, rand() / (float)RAND_MAX);
Vector3 v1 = cross(hit.N, unv);
Vector3 v2 = cross(v1, hit.N);
Vector3 dir = coord.x * v1 + coord.z * hit.N + coord.y * v2;
dir.normalize();
Ray r(hit.P, dir);
r.times = ray.times + 1;
HitInfo hi;
if(scene.trace(hi, r))
L+= m_kd * dot(r.d, hit.N) * hit.material->shade(r, hi, scene);
}
return L;
//.........这里部分代码省略.........
示例6: BRDF
Vector3
RefractiveInterface::shade(const Ray& ray, const HitInfo& hit, const Scene& scene, const bool& isFront) const
{
Ray rayLight;
HitInfo hitLight;
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const PointLights *plightlist = scene.pointLights();
// loop over all of the POINT lights
PointLights::const_iterator plightIter;
for (plightIter = plightlist->begin(); plightIter != plightlist->end(); plightIter++)
{
PointLight* pLight = *plightIter;
Vector3 l = pLight->position() - hit.P;
rayLight.o = hit.P;
rayLight.d = l.normalized();
Vector3 brdf = BRDF(rayLight.d, hit.N, -ray.d, isFront);
if (brdf == 0) continue;
if (scene.trace(hitLight, rayLight, 0.0001, l.length())) continue;
// the inverse-squared falloff
float falloff = l.length2();
float nDotL = fabs(dot(hit.N, l));
Vector3 result = pLight->color();
L += nDotL / falloff * pLight->wattage() *brdf * result;
}
const AreaLights *alightlist = scene.areaLights();
// loop over all of the lights
AreaLights::const_iterator alightIter;
for (alightIter = alightlist->begin(); alightIter != alightlist->end(); alightIter++)
{
AreaLight* aLight = *alightIter;
vec3pdf vp = aLight->randPt();
Vector3 l = vp.v - hit.P; // shoot a shadow ray to a random point on the area light
rayLight.o = hit.P;
rayLight.d = l.normalized();
Vector3 brdf = BRDF(rayLight.d, hit.N, -ray.d, isFront);
if (brdf == 0) continue;
// if the shadow ray hits the "backside of the light" continue to the next area light
if (!aLight->intersect(hitLight, rayLight)){
continue;
}
// if the shadow ray is occluded by another (hence the "skip") object continue the next light
if (scene.trace(hitLight, rayLight, aLight, 0.0001, l.length())){
continue;
}
// the inverse-squared falloff
float falloff = l.length2();
float nDotL = fabs(dot(hit.N, l));
Vector3 result = aLight->color();
L += std::max(0.0f, dot(hitLight.N, -l))* 0.0f, nDotL / falloff*
aLight->wattage() / aLight->area() *brdf * result / (vp.p);
}
// add the ambient component
L += m_ka;
return L;
}
示例7: reflect
//Blinn-Phong shading model
Vector3
Specular::shade(Ray& ray, const HitInfo& hit, const Scene& scene) const
{
Vector3 reflected = Vector3(0.0f, 0.0f, 0.0f);
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
//scale down intensity of light in proportion to num of ray bounces
Vector3 attenuation = k_s * ( 1 / (ray.numBounces+1));
const Lights *lightlist = scene.lights();
// loop over all of the lights
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
//find reflected vector, given normal and incident light direction
PointLight* pLight = *lightIter;
//light vector points from hit point to light
Vector3 l = pLight->position() - hit.P;
//why did we use ray.d here instead of l? Would just need to change calculation a bit
//to use l
reflected = ray.d - 2.0f * (dot(hit.N, ray.d)) * hit.N;
if (ray.numBounces < maxBounces)
{
//trace from reflected vector now
Ray reflect(ray.numBounces + 1);
reflect.o = hit.P;
reflect.d = reflected;
HitInfo hitReflect;
if (scene.trace(hitReflect, reflect, 0.008f))
{
//get color from object hit
//printf("Bounced reflected ray hit something!\n");
L += attenuation * hitReflect.material->shade(reflect, hitReflect, scene);
}
else
{
//get color from background
L += Vector3(0,0,0.5f);//bgColor;
}
}
//Get halfway vector
Vector3 h = (L + -1 * ray.d).normalize();
Ray shadow_ray(0);
HitInfo hi;
shadow_ray.o = hit.P;
shadow_ray.d = l;
//std::cout<<"M = "<<M<< " hit.N = "<<hit.N<<std::endl;
if (scene.trace(hi, shadow_ray, 0.001f, sqrt(l.length2())))
{
// We are in shadow
}
else
{
//get color of light
Vector3 color = pLight->color();
//flip vector from eye so points from hit point back to eye
//L += k_s * color * pow(std::max(0.0f, dot(h, hit.N)), shinyExp);
//L += attenuation * color * pow(std::max(0.0f, dot(reflected, -ray.d)), shinyExp);
//Specular Highlights
//This is separate from the reflection calculation because it
//needs to be dependent on just the shinyExp
//https://en.wikipedia.org/wiki/Specular_highlight
//Specular calculation for ABSORBED light
L += attenuation * pow(std::max(0.0f, dot(h, hit.N)), 50* shinyExp);
//check entering or exiting and change n1/n2 n2/n1
//dot product ray.dot.normal
//Specular Refraction
//L += attenuation * color * pow(std::max(0.0f, dot(wt, -ray.d)), shinyExp);
//std::cout<<"Final Refraction vector = "<<(k_s * color * pow(std::max(0.0f,
//dot(wt,ray.d)), shinyExp))<<std::endl;
}
}
return L;
}
示例8: sqrt
Vector3
PencilShader::shade(const Ray& ray, const HitInfo& hit, const Scene& scene) const
{
int m = 0;
int totalRays = 0;
float step = (float)RAD_H/SAMPLES;
std::vector<Vector3> normals;
std::vector<HitInfo> hits;
for(float r = step; r <= RAD_H; r+=step){
float theta_step = (2.0*M_PI)/(pow(2, r+2));
for(float theta = 0; theta <= 2.0*M_PI; theta += theta_step){
totalRays++;
float x = r*cos(theta);
float y = r*sin(theta);
Ray stencilRay;
Vector3 dir = Vector3(ray.d);
dir.x += x;
dir.y += y;
stencilRay.o = ray.o;
stencilRay.d = dir;
HitInfo h;
if(scene.trace(h, stencilRay)){
if(h.objId != hit.objId){
m++;
} else{
normals.push_back(Vector3(h.N));
hits.push_back(h);
}
} else m++;
}
}
//Hit other geometry, outline edge
if(m > 0){
return Vector3(0.0f);
}
float gradient = 0.0;
//Check for creases or silhouettes
for(int i = 0; i <= normals.size(); i++){
gradient += (dot(normals[i], hit.N))/normals.size();
if(gradient < 0.01)
return Vector3(0.0f);
}
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Lights *lightlist = scene.lights();
Ray shadow;
shadow.o = hit.P - ray.o;
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Vector3 l = pLight->position() - hit.P;
// the inverse-squared falloff
float falloff = l.length2();
// normalize the light direction
l /= sqrt(falloff);
// get the diffuse component
shadow.d = l;
float nDotL = dot(hit.N, l);
//Map into color location
L += getTextureColor(nDotL, hit);
}
return L;
}
示例9: randvect
Vector3
Phong::shade(const Ray& ray, const HitInfo& rhit, const Scene& scene) const
{
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
Vector3 randvect(randone(g_rng), randone(g_rng), randone(g_rng));
const Lights *lightlist = scene.lights();
HitInfo bm_hit = bumpHit(rhit);
// loop over all of the lights
Lights::const_iterator lightIter;
Vector3 diffcolor = m_kd * m_texture_kd->shade(ray, bm_hit, scene);
Vector3 speccolor = m_ks * m_texture_ks->shade(ray, bm_hit, scene);
// float irrad[3];
// g_global_illum_map->irradiance_estimate(irrad, bm_hit.P.array(), bm_hit.N.array(), 1.f, 100);
// L += Vector3(irrad) * diffcolor;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
float shadow_mul = 0.f;
Vector3 tolight = pLight->position() - bm_hit.P;
tolight.normalize();
Vector3 xaxis = randvect.cross(tolight);
xaxis.normalize();
Vector3 yaxis = xaxis.cross(tolight);
yaxis.normalize();
float xdisk, ydisk;
do
{
xdisk = 1 - 2*randone(g_rng);
ydisk = 1 - 2*randone(g_rng);
} while (xdisk*xdisk + ydisk*ydisk > 1);
Vector3 posinlight = pLight->position() + xdisk*pLight->sphere()*xaxis + ydisk*pLight->sphere()*yaxis;
Ray lightray;
lightray.d = (posinlight - bm_hit.P);
float raylength = lightray.d.length();
float remaininglength = raylength;
lightray.d /= raylength;
lightray.o = bm_hit.P;
while (true)
{
HitInfo lighthit;
if (!scene.trace(lighthit, lightray, EPSILON, remaininglength))
{
shadow_mul = 1;
break;
}
if (lighthit.material->castShadow())
break;
remaininglength -= lighthit.t;
lightray.o = lighthit.P;
}
if (shadow_mul < EPSILON)
continue;
// Diffuse
Vector3 result = pLight->color()*shadow_mul;
// the inverse-squared falloff
float falloff = raylength*raylength;
// normalize the light direction
float nDotL = dot(bm_hit.N, lightray.d);
if (m_kd.max() > EPSILON)
{
L += std::max(0.0f, nDotL/falloff * pLight->wattage() / (4*PI)) * result * diffcolor;
}
if (m_ks.max() > EPSILON && nDotL > 0)
{
Vector3 refl = -lightray.d + 2*nDotL*bm_hit.N;
L += std::max(0.f, powf((-ray.d).dot(refl), m_phong)) * result * speccolor * (1 - m_tp);
//Vector3 half = -ray.d + hit.N;
//half.normalize();
//L += std::max(0.f, powf(half.dot(hit.N), 1000)) * result * speccolor * m_sp;
}
}
float caustic[3] = {0, 0, 0};
g_caustics_map->irradiance_estimate(caustic, bm_hit.P.array(), bm_hit.N.array(), 3.0f, 200); // TODO: customize these parameters
Vector3 caustic_color(caustic);
L += caustic_color;
// Indirect diffuse sampling (method 2)
if (m_indirect && m_kd.max() > EPSILON && ray.iter < MAX_RAY_ITER)
{
float theta = asinf((randone(g_rng)));
float phi = 2 * PI * randone(g_rng);
Vector3 const &yaxis = bm_hit.N;
Vector3 xaxis = yaxis.cross(randvect);
xaxis.normalize();
Vector3 zaxis = yaxis.cross(xaxis);
zaxis.normalize();
Ray diffuse_ray;
diffuse_ray.refractionIndex = ray.refractionIndex;
//.........这里部分代码省略.........
示例10: printf
Vector3
Specular::shade(const Ray& ray, const HitInfo& hit, const Scene& scene) const
{
printf("Shading specular\n");
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const Lights *lightlist = scene.lights();
Vector3 color = Vector3(m_kd);
if (hit.material->hasTexture()) {
Vector3 c = Vector3(hit.P);
color = m_texture->getColor(c);
}
// loop over all of the lights
HitInfo lightHitReflect = HitInfo(hit);
HitInfo lightHitRefract = HitInfo(hit);
lightHitReflect.hitNum = hit.hitNum;
lightHitRefract.hitNum = hit.hitNum;
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Ray lightRay;
Vector3 l = pLight->position() - hit.P;
float falloff = l.length2();
l /= sqrt(falloff);
/* Calculate the diffuse component - From Labertian Shading Model */
float nDotL = dot(hit.N, l);
Vector3 diffuseResult = pLight->color();
diffuseResult *= color;
L += std::max(0.0f, nDotL/falloff * pLight->wattage() / PI) * diffuseResult;
/* Calculate the specular highlight - From Phong Shading Model */
Vector3 h = (viewDir + l).normalize();
float nDotH = dot(hit.N, h);
Vector3 specResult = pLight->color();
specResult *= m_ks;
L += pow(std::max(0.0f, nDotH/falloff * pLight->wattage() / PI), m_p) * specResult;
/* Calculate the specular reflectance */
if(lightHitReflect.hitNum < 1){
Vector3 r = reflect(hit.N, ray.d);
lightRay.d = r.normalize();
lightRay.o = hit.P;
if(scene.trace(lightHitReflect, lightRay, 0.0001, r.length())){
lightHitReflect.hitNum = lightHitReflect.hitNum+1;
L += lightHitReflect.material->shade(lightRay, lightHitReflect, scene)*m_rl;
}
}
/* Calculate the specular refractance */
// Vector3 incident = viewDir - hit.P;
if(lightHitRefract.hitNum < 1 && m_rf > 0.0f ){
Vector3 t = refract(hit.N, ray.d, hit.material->n(), m_n);
if(t != Vector3(0.0f))
lightRay.d = t.normalize();
else lightRay.d = t;
lightRay.o = hit.P;
if(scene.trace(lightHitRefract, lightRay, 0.0001, t.length())){
lightHitRefract.hitNum = lightHitRefract.hitNum+1;
L+=lightHitRefract.material->shade(lightRay, lightHitRefract, scene)*m_rf;
} else {
L+=scene.getBGColor()*m_rf;
}
}
}
return L;
}
示例11: sqrt
Vector3
CoolWarmShader::shade(const Ray& ray, const HitInfo& hit, const Scene& scene) const
{
if(m_edges){
Vector3 hitPoint = hit.P - ray.o;
int m = 0;
int totalRays = 0;
float step = (float)RAD_H/SAMPLES;
std::vector<Vector3> normals;
for(float r = step; r <= RAD_H; r+=step){
float theta_step = (2.0*M_PI)/(pow(2, r+2));
for(float theta = 0; theta <= 2.0*M_PI; theta += theta_step){
totalRays++;
float x = r*cos(theta);
float y = r*sin(theta);
Ray stencilRay;
Vector3 dir = Vector3(ray.d);
dir.x += x;
dir.y += y;
stencilRay.o = ray.o;
stencilRay.d = dir;
HitInfo h;
if(scene.trace(h, stencilRay)){
if(h.objId != hit.objId){
m++;
} else{
normals.push_back(h.N);
}
} else m++;
}
}
}
Vector3 L = Vector3(0.0f, 0.0f, 0.0f);
const Vector3 viewDir = -ray.d; // d is a unit vector
const Lights *lightlist = scene.lights();
Vector3 color = Vector3(m_kd);
if (hit.material->hasTexture()) {
Vector3 c = Vector3(hit.P);
color = m_texture->getColor(c);
}
// loop over all of the lights
Lights::const_iterator lightIter;
for (lightIter = lightlist->begin(); lightIter != lightlist->end(); lightIter++)
{
PointLight* pLight = *lightIter;
Vector3 l = pLight->position() - hit.P;
// the inverse-squared falloff
float falloff = l.length2();
// normalize the light direction
l /= sqrt(falloff);
// get the diffuse component
float nDotL = dot(hit.N, l);
//Map into color location
L += getCellColor(nDotL);
}
return L;
}