Skip to content
Snippets Groups Projects
DiffuseMaterial.h 1.33 KiB
Newer Older
Postea's avatar
Postea committed
#pragma once
Yoel's avatar
Yoel committed
#include "../tools/EmissionProfile.h"
Postea's avatar
Postea committed
#include "Material.h"
Postea's avatar
Postea committed
namespace material {
class DiffuseMaterial : public Material {
Yoel's avatar
Yoel committed
   public:
	DiffuseMaterial(const std::shared_ptr<util::Sampler>& albedo_texture,
	                const std::shared_ptr<util::Sampler>& emission_texture);
Yoel's avatar
Yoel committed
	DiffuseMaterial(const std::shared_ptr<util::Sampler>& albedo_texture,
	                const std::shared_ptr<util::Sampler>& emission_texture,
	                const util::Image& distribution);
Yoel's avatar
Yoel committed
	DiffuseMaterial(const std::shared_ptr<util::Sampler>& albedo);
	DiffuseMaterial(const util::Vec3& color);
	util::Vec3 albedo(const std::pair<float, float>& uv) const override;
	util::Vec3 emission(const std::pair<float, float>& uv) const override;
Yoel's avatar
Yoel committed
	std::pair<float, float> sampleEmissionProfile() const override;
	util::Vec3 scattered_d(const util::Vec3& d,
	                       const util::Vec3& n) const override;
	bool scatter(const util::Vec3& d, const util::Vec3& n) const override;

	float calculateLightMultiplier(const util::Vec3& d_in,
	                               const util::Vec3& d_out,
	                               const util::Vec3& n) const override;
Yoel's avatar
Yoel committed
	std::optional<float> emission_pdf(float u, float v) const override;
Postea's avatar
Postea committed

Yoel's avatar
Yoel committed
   private:
	std::shared_ptr<util::Sampler> albedo_texture;
Yoel's avatar
Yoel committed
	util::EmissionProfile emission_profile;
Yoel's avatar
Yoel committed
}  // namespace material