2020-06-06 21:21:21 +00:00
|
|
|
#ifndef MATERIAL_H
|
|
|
|
#define MATERIAL_H
|
|
|
|
|
|
|
|
#include "hittable.h"
|
|
|
|
#include "vec3.h"
|
|
|
|
|
|
|
|
struct hit_record;
|
|
|
|
|
|
|
|
class Material {
|
|
|
|
public:
|
|
|
|
virtual bool scatter(const Ray& r_in, const hit_record& rec, Color& attenuation, Ray& scattered) const = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
class Lambertian : public Material {
|
|
|
|
public:
|
|
|
|
Lambertian(const Color& a) : albedo(a) {}
|
|
|
|
|
|
|
|
virtual bool scatter(const Ray& r_in, const hit_record& rec, Color& attenuation, Ray& scattered) const;
|
|
|
|
|
|
|
|
private:
|
|
|
|
Color albedo;
|
|
|
|
};
|
|
|
|
|
|
|
|
class Metal : public Material {
|
|
|
|
public:
|
2020-06-06 21:28:33 +00:00
|
|
|
Metal(const Color& a, double f) : albedo(a), fuzz(f < 1 ? f : 1) {}
|
2020-06-06 21:21:21 +00:00
|
|
|
|
|
|
|
virtual bool scatter(const Ray& r_in, const hit_record& rec, Color& attenuation, Ray& scattered) const;
|
|
|
|
private:
|
|
|
|
Color albedo;
|
2020-06-06 21:28:33 +00:00
|
|
|
double fuzz;
|
2020-06-06 21:21:21 +00:00
|
|
|
};
|
|
|
|
|
2020-06-06 22:03:25 +00:00
|
|
|
double schlick(double cosine, double ref_idx);
|
|
|
|
|
|
|
|
class Dielectric : public Material {
|
|
|
|
public:
|
|
|
|
Dielectric(double ri) : ref_idx(ri) {}
|
|
|
|
virtual bool scatter(const Ray& r_in, const hit_record& rec, Color& attenuation, Ray& scattered) const;
|
|
|
|
private:
|
|
|
|
double ref_idx;
|
|
|
|
};
|
|
|
|
|
2020-06-06 21:21:21 +00:00
|
|
|
#endif // MATERIAL_H
|