summaryrefslogtreecommitdiff
path: root/hw3/src/reflectanceShader_base.cpp
blob: 8ff81fc8da0952768790776671a9fbc4e30cb1cb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
/******************************************************************/
/* This file is part of the homework assignments for CSCI-427/527 */
/* at The College of William & Mary and authored by Pieter Peers. */
/* No part of this file, whether altered or in original form, can */
/* be distributed or used outside the context of CSCI-427/527     */
/* without consent of either the College of William & Mary or     */
/* Pieter Peers.                                                  */
/******************************************************************/
#include "reflectanceShader_base.h"
#include "coordinateTransform.h"

/////////////
// Methods //
/////////////
color reflectanceShader_base::shade(const intersectionPoint& ip, const vec3d& light_dir) const
{
  // create shading frame (note: in and out point away!)
  coordinateTransformation ct = ip.shadingFrame();
  vec3d local_out = ct.inverseTransformDirection(-ip.direction());
  vec3d local_in = ct.inverseTransformDirection(light_dir);

  // get brdf
  std::unique_ptr<const brdf_base> brdf = make_brdf(ip.textureCoordinate());

  // eval
  return brdf->shade(local_in, local_out);
}


shaderProperties reflectanceShader_base::properties(const intersectionPoint& ip) const
{
  // get brdf
  std::unique_ptr<const brdf_base> brdf = make_brdf(ip.textureCoordinate());

  // get properties
  return shaderProperties(brdf->isDiffuse(), brdf->isSpecular());
}