3d_fractals_cuda/camera.cuh

82 lines
2.0 KiB
Plaintext

#ifndef CAMERA_H
#define CAMERA_H
#include "entity.cuh"
#include "common.cuh"
#include <limits>
//template <class T> class scene;
//I am soooo high lol
template<class T>
class camera : public entity<T> {
using T3 = typename vect_t3<T>::vect_t;
using T2 = typename vect_t2<T>::vect_t;
public:
__device__ void render();
__device__ camera(scene<T> *pscene, const T fov = 1, const T3 pos = vect_create<T3>(0), const T3 rot = vect_create<T3>(0))
: pscene(pscene), fov(fov), entity<T>(pos, rot, vect_create<T3>(0)) {};
//__device__ ~camera();
private:
T fov;
T2 size;
int steps = 100;
T clip_min = .1;
T clip_max = 100;
scene<T> *pscene;
};
/**
//later we'll make scenes objects, rn im lazy (TODO)
template <class T> __device__ void camera<T>::render() {
//TODO *really* need to clean this up once you get further
//extra dimentions is extra math
//either generisize float3 or stop using this fucking template nonsense
const uint3 unnormalized_uv = ((blockDim * blockIdx) + threadIdx);
const unsigned int img_index = (unnormalized_uv.x + (unnormalized_uv.y * blockDim.x * gridDim.x)) * 4;
const T3 uv = ((2 * vect_create<T3>(unnormalized_uv)) / vect_create<T3>(gridDim * blockDim)) - 1;
const T3 ray_direction = normalize(vect_create<T3>(uv.x, uv.y, 1));
T dist;
T total_dist = 0;
T3 ray;
int i;
//if(img_index == 640) { printf("%f, %f, %f\n", uv.x, uv.y, uv.z); }
T min_dist = clip_max;
render_object<T> **objs = pscene->get_objs();
for(i = 0; i < steps; i++) {
ray = this->pos_ + (total_dist * ray_direction);
//gyagh memory lookups
for(unsigned int oi = 0; objs[oi] != NULL; oi++) {
dist = object.distance_estimator(ray);
}
if((dist < clip_min)) {
//image[img_index] = 0xff;
break;
}
if((dist > clip_max)) {
//image[img_index+2] = 0xff;
break;
}
total_dist += dist;
}
//image[img_index] = 0x00;
//image[img_index+1] = 0x00;
//image[img_index+2] = p;
//image[img_index+3] = 0xff;
}
**/
#endif