From db072ad4dc181eca5a1458656b130beb43f475bf Mon Sep 17 00:00:00 2001 From: 53hornet <53hornet@gmail.com> Date: Sat, 2 Feb 2019 23:33:15 -0500 Subject: Init. --- hw4/include/bvh_intersector.h | 62 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 hw4/include/bvh_intersector.h (limited to 'hw4/include/bvh_intersector.h') diff --git a/hw4/include/bvh_intersector.h b/hw4/include/bvh_intersector.h new file mode 100644 index 0000000..68afe3f --- /dev/null +++ b/hw4/include/bvh_intersector.h @@ -0,0 +1,62 @@ +/******************************************************************/ +/* 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. */ +/******************************************************************/ +#ifndef _BVH_INTERSECTOR_H_ +#define _BVH_INTERSECTOR_H_ + +#include + +#include "boundedPrimitive.h" +#include "intersector_base.h" +#include "intersector_factory_base.h" + +class bvh_intersector : public intersector_base { + public: + ////////////////// + // Constructors // + ////////////////// + bvh_intersector(void); + bvh_intersector(const std::vector>& compounds); + bvh_intersector(const bvh_intersector&) = delete; + + /////////////// + // Operators // + /////////////// + bvh_intersector& operator=(const bvh_intersector&) = delete; + + ///////////// + // Methods // + ///////////// + virtual intersectionPoint intersect(const ray& r) const final override; + + private: + ////////////////// + // Data Members // + ////////////////// + std::shared_ptr _root; +}; + + +class bvh_intersector_factory : public intersector_factory_base { + public: + ///////////////// + // Constructor // + ///////////////// + bvh_intersector_factory(void) {} + + /////////////// + // Operators // + /////////////// + std::unique_ptr operator()(const boundedCompound& boundedCompound) const final override + { + return std::unique_ptr(new bvh_intersector(boundedCompound.compounds())); + } +}; + +#endif /* _BVH_INTERSECTOR_H_ */ + -- cgit v1.2.3