@ -34,8 +34,8 @@
# include "Vector4.hpp"
# include "Vector4.hpp"
# include <Camera.h>
# include <Camera.h>
const int WINDOW_X = 1 00 0;
const int WINDOW_X = 1 92 0;
const int WINDOW_Y = 10 0 0;
const int WINDOW_Y = 10 8 0;
const int WORK_SIZE = WINDOW_X * WINDOW_Y ;
const int WORK_SIZE = WINDOW_X * WINDOW_Y ;
const int MAP_X = 512 ;
const int MAP_X = 512 ;
@ -65,297 +65,306 @@ sf::Texture window_texture;
int main ( ) {
int main ( ) {
//Map m(sf::Vector3i (50, 50, 50));
//return 1;
sf : : RenderWindow window ( sf : : VideoMode ( WINDOW_X , WINDOW_Y ) , " SFML " ) ;
// Setup CL, instantiate and pass in values to the kernel
Map m ( sf : : Vector3i ( 50 , 50 , 50 ) ) ;
CL_Wrapper c ;
m . generate_octree ( ) ;
query_platform_devices ( ) ;
return 1 ;
c . acquire_platform_and_device ( ) ;
c . create_shared_context ( ) ;
//sf::RenderWindow window(sf::VideoMode(WINDOW_X, WINDOW_Y), "SFML");
c . create_command_queue ( ) ;
//// Setup CL, instantiate and pass in values to the kernel
if ( c . compile_kernel ( " ../kernels/ray_caster_kernel.cl " , true , " min_kern " ) < 0 ) {
//CL_Wrapper c;
std : : cin . get ( ) ;
//query_platform_devices();
return - 1 ;
//c.acquire_platform_and_device();
}
//c.create_shared_context();
//c.create_command_queue();
std : : cout < < " map... " ;
sf : : Vector3i map_dim ( MAP_X , MAP_Y , MAP_Z ) ;
//if (c.compile_kernel("../kernels/ray_caster_kernel.cl", true, "min_kern") < 0) {
Map * map = new Map ( map_dim ) ;
// std::cin.get();
// return -1;
c . create_buffer ( " map_buffer " , sizeof ( char ) * map_dim . x * map_dim . y * map_dim . z , map - > list ) ;
//}
c . create_buffer ( " dim_buffer " , sizeof ( int ) * 3 , & map_dim ) ;
//
//std::cout << "map...";
sf : : Vector2i view_res ( WINDOW_X , WINDOW_Y ) ;
// sf::Vector3i map_dim(MAP_X, MAP_Y, MAP_Z);
c . create_buffer ( " res_buffer " , sizeof ( int ) * 2 , & view_res ) ;
// Map* map = new Map(map_dim);
//
//c.create_buffer("map_buffer", sizeof(char) * map_dim.x * map_dim.y * map_dim.z, map->list);
double y_increment_radians = DegreesToRadians ( 50.0 / view_res . y ) ;
//c.create_buffer("dim_buffer", sizeof(int) * 3, &map_dim);
double x_increment_radians = DegreesToRadians ( 80.0 / view_res . x ) ;
//sf::Vector2i view_res(WINDOW_X, WINDOW_Y);
std : : cout < < " view matrix... " ;
//c.create_buffer("res_buffer", sizeof(int) * 2, &view_res);
//
sf : : Vector4f * view_matrix = new sf : : Vector4f [ WINDOW_X * WINDOW_Y * 4 ] ;
// double y_increment_radians = DegreesToRadians(50.0 / view_res.y);
for ( int y = - view_res . y / 2 ; y < view_res . y / 2 ; y + + ) {
// double x_increment_radians = DegreesToRadians(80.0 / view_res.x);
for ( int x = - view_res . x / 2 ; x < view_res . x / 2 ; x + + ) {
//std::cout << "view matrix...";
// The base ray direction to slew from
//
sf : : Vector3f ray ( 1 , 0 , 0 ) ;
//sf::Vector4f* view_matrix = new sf::Vector4f[WINDOW_X * WINDOW_Y * 4];
// Y axis, pitch
// for (int y = -view_res.y / 2; y < view_res.y / 2; y++) {
ray = sf : : Vector3f (
// for (int x = -view_res.x / 2; x < view_res.x / 2; x++) {
ray . z * sin ( y_increment_radians * y ) + ray . x * cos ( y_increment_radians * y ) ,
ray . y ,
// // The base ray direction to slew from
ray . z * cos ( y_increment_radians * y ) - ray . x * sin ( y_increment_radians * y )
// sf::Vector3f ray(1, 0, 0);
) ;
// // Y axis, pitch
// Z axis, yaw
// ray = sf::Vector3f(
ray = sf : : Vector3f (
// ray.z * sin(y_increment_radians * y) + ray.x * cos(y_increment_radians * y),
ray . x * cos ( x_increment_radians * x ) - ray . y * sin ( x_increment_radians * x ) ,
// ray.y,
ray . x * sin ( x_increment_radians * x ) + ray . y * cos ( x_increment_radians * x ) ,
// ray.z * cos(y_increment_radians * y) - ray.x * sin(y_increment_radians * y)
ray . z
// );
) ;
int index = ( x + view_res . x / 2 ) + view_res . x * ( y + view_res . y / 2 ) ;
// // Z axis, yaw
ray = Normalize ( ray ) ;
// ray = sf::Vector3f(
// ray.x * cos(x_increment_radians * x) - ray.y * sin(x_increment_radians * x),
view_matrix [ index ] = sf : : Vector4f (
// ray.x * sin(x_increment_radians * x) + ray.y * cos(x_increment_radians * x),
ray . x ,
// ray.z
ray . y ,
// );
ray . z ,
//
0
// int index = (x + view_res.x / 2) + view_res.x * (y + view_res.y / 2);
) ;
// ray = Normalize(ray);
}
}
// view_matrix[index] = sf::Vector4f(
// ray.x,
c . create_buffer ( " view_matrix_buffer " , sizeof ( float ) * 4 * view_res . x * view_res . y , view_matrix ) ;
// ray.y,
// ray.z,
Camera camera (
// 0
sf : : Vector3f ( 256 , 256 , 256 ) ,
// );
sf : : Vector2f ( 0.0f , 1.00f )
// }
) ;
// }
c . create_buffer ( " cam_dir_buffer " , sizeof ( float ) * 4 , ( void * ) camera . get_direction_pointer ( ) , CL_MEM_READ_ONLY | CL_MEM_USE_HOST_PTR ) ;
//c.create_buffer("view_matrix_buffer", sizeof(float) * 4 * view_res.x * view_res.y, view_matrix);
c . create_buffer ( " cam_pos_buffer " , sizeof ( float ) * 4 , ( void * ) camera . get_position_pointer ( ) , CL_MEM_READ_ONLY | CL_MEM_USE_HOST_PTR ) ;
//Camera camera(
int light_count = 2 ;
// sf::Vector3f(70, 60, 50),
c . create_buffer ( " light_count_buffer " , sizeof ( int ) , & light_count ) ;
// sf::Vector2f(0.0f, 1.00f)
//);
// {r, g, b, i, x, y, z, x', y', z'}
//
sf : : Vector3f v = Normalize ( sf : : Vector3f ( 1.0 , 1.0 , 0.0 ) ) ;
//c.create_buffer("cam_dir_buffer", sizeof(float) * 4, (void*)camera.get_direction_pointer(), CL_MEM_READ_ONLY | CL_MEM_USE_HOST_PTR);
sf : : Vector3f v2 = Normalize ( sf : : Vector3f ( 1.1 , 0.4 , 0.7 ) ) ;
//c.create_buffer("cam_pos_buffer", sizeof(float) * 4, (void*)camera.get_position_pointer(), CL_MEM_READ_ONLY | CL_MEM_USE_HOST_PTR);
float light [ ] = { 0.4 , 0.8 , 0.1 , 1 , 50 , 50 , 50 , v . x , v . y , v . z ,
//
0.4 , 0.8 , 0.1 , 1 , 50 , 50 , 50 , v2 . x , v2 . y , v2 . z } ;
//int light_count = 2;
c . create_buffer ( " light_buffer " , sizeof ( float ) * 10 * light_count , light , CL_MEM_READ_ONLY | CL_MEM_USE_HOST_PTR ) ;
//c.create_buffer("light_count_buffer", sizeof(int), &light_count);
// The drawing canvas
//// {r, g, b, i, x, y, z, x', y', z'}
unsigned char * pixel_array = new sf : : Uint8 [ WINDOW_X * WINDOW_Y * 4 ] ;
//sf::Vector3f v = Normalize(sf::Vector3f(1.0, 0.0, 0.0));
//sf::Vector3f v2 = Normalize(sf::Vector3f(1.1, 0.4, 0.7));
for ( int i = 0 ; i < WINDOW_X * WINDOW_Y * 4 ; i + = 4 ) {
//float light[] = { 0.4, 0.8, 0.1, 1, 50, 50, 50, v.x, v.y, v.z,
// 0.4, 0.8, 0.1, 1, 50, 50, 50, v2.x, v2.y, v2.z};
pixel_array [ i ] = 255 ; // R?
//c.create_buffer("light_buffer", sizeof(float) * 10 * light_count, light, CL_MEM_READ_ONLY | CL_MEM_USE_HOST_PTR);
pixel_array [ i + 1 ] = 255 ; // G?
pixel_array [ i + 2 ] = 255 ; // B?
//// The drawing canvas
pixel_array [ i + 3 ] = 100 ; // A?
// unsigned char* pixel_array = new sf::Uint8[WINDOW_X * WINDOW_Y * 4];
}
// for (int i = 0; i < WINDOW_X * WINDOW_Y * 4; i += 4) {
sf : : Texture t ;
t . create ( WINDOW_X , WINDOW_Y ) ;
// pixel_array[i] = 255; // R?
t . update ( pixel_array ) ;
// pixel_array[i + 1] = 255; // G?
// pixel_array[i + 2] = 255; // B?
int error ;
// pixel_array[i + 3] = 100; // A?
cl_mem image_buff = clCreateFromGLTexture (
// }
c . getContext ( ) , CL_MEM_WRITE_ONLY , GL_TEXTURE_2D ,
0 , t . getNativeHandle ( ) , & error ) ;
//sf::Texture t;
// t.create(WINDOW_X, WINDOW_Y);
if ( c . assert ( error , " clCreateFromGLTexture " ) )
// t.update(pixel_array);
return - 1 ;
// int error;
c . store_buffer ( image_buff , " image_buffer " ) ;
// cl_mem image_buff = clCreateFromGLTexture(
// c.getContext(), CL_MEM_WRITE_ONLY, GL_TEXTURE_2D,
c . set_kernel_arg ( " min_kern " , 0 , " map_buffer " ) ;
// 0, t.getNativeHandle(), &error);
c . set_kernel_arg ( " min_kern " , 1 , " dim_buffer " ) ;
c . set_kernel_arg ( " min_kern " , 2 , " res_buffer " ) ;
// if (c.assert(error, "clCreateFromGLTexture"))
c . set_kernel_arg ( " min_kern " , 3 , " view_matrix_buffer " ) ;
// return -1;
c . set_kernel_arg ( " min_kern " , 4 , " cam_dir_buffer " ) ;
c . set_kernel_arg ( " min_kern " , 5 , " cam_pos_buffer " ) ;
// c.store_buffer(image_buff, "image_buffer");
c . set_kernel_arg ( " min_kern " , 6 , " light_buffer " ) ;
c . set_kernel_arg ( " min_kern " , 7 , " light_count_buffer " ) ;
// c.set_kernel_arg("min_kern", 0, "map_buffer");
c . set_kernel_arg ( " min_kern " , 8 , " image_buffer " ) ;
// c.set_kernel_arg("min_kern", 1, "dim_buffer");
// c.set_kernel_arg("min_kern", 2, "res_buffer");
sf : : Sprite s ;
// c.set_kernel_arg("min_kern", 3, "view_matrix_buffer");
s . setTexture ( t ) ;
// c.set_kernel_arg("min_kern", 4, "cam_dir_buffer");
s . setPosition ( 0 , 0 ) ;
// c.set_kernel_arg("min_kern", 5, "cam_pos_buffer");
//c.set_kernel_arg("min_kern", 6, "light_buffer");
// The step size in milliseconds between calls to Update()
//c.set_kernel_arg("min_kern", 7, "light_count_buffer");
// Lets set it to 16.6 milliseonds (60FPS)
//c.set_kernel_arg("min_kern", 8, "image_buffer");
float step_size = 0.0166f ;
//sf::Sprite s;
// Timekeeping values for the loop
//s.setTexture(t);
double frame_time = 0.0 ,
//s.setPosition(0, 0);
elapsed_time = 0.0 ,
delta_time = 0.0 ,
// // The step size in milliseconds between calls to Update()
accumulator_time = 0.0 ,
// // Lets set it to 16.6 milliseonds (60FPS)
current_time = 0.0 ;
// float step_size = 0.0166f;
fps_counter fps ;
// // Timekeeping values for the loop
// double frame_time = 0.0,
// ============================= RAYCASTER SETUP ==================================
// elapsed_time = 0.0,
// delta_time = 0.0,
// Setup the sprite and texture
// accumulator_time = 0.0,
window_texture . create ( WINDOW_X , WINDOW_Y ) ;
// current_time = 0.0;
window_sprite . setPosition ( 0 , 0 ) ;
// fps_counter fps;
// State values
//// ============================= RAYCASTER SETUP ==================================
sf : : Vector3f cam_vec ( 0 , 0 , 0 ) ;
//// Setup the sprite and texture
RayCaster ray_caster ( map , map_dim , view_res ) ;
//window_texture.create(WINDOW_X, WINDOW_Y);
//window_sprite.setPosition(0, 0);
sf : : Vector2f * dp = camera . get_direction_pointer ( ) ;
debug_text cam_text_x ( 1 , 30 , & dp - > x , " X: " ) ;
//// State values
debug_text cam_text_y ( 2 , 30 , & dp - > y , " Y: " ) ;
//sf::Vector3f cam_vec(0, 0, 0);
sf : : Vector3f * mp = camera . get_movement_pointer ( ) ;
debug_text cam_text_mov_x ( 4 , 30 , & mp - > x , " X: " ) ;
//RayCaster ray_caster(map, map_dim, view_res);
debug_text cam_text_mov_y ( 5 , 30 , & mp - > y , " Y: " ) ;
debug_text cam_text_mov_z ( 6 , 30 , & mp - > y , " Z: " ) ;
//sf::Vector2f *dp = camera.get_direction_pointer();
//debug_text cam_text_z(3, 30, &p->z);
//debug_text cam_text_x(1, 30, &dp->x, "X: ");
//debug_text cam_text_y(2, 30, &dp->y, "Y: ");
debug_text light_x ( 7 , 30 , & light [ 7 ] , " X: " ) ;
debug_text light_y ( 8 , 30 , & light [ 8 ] , " Y: " ) ;
//sf::Vector3f *mp = camera.get_movement_pointer();
debug_text light_z ( 9 , 30 , & light [ 9 ] , " Z: " ) ;
//debug_text cam_text_mov_x(4, 30, &mp->x, "X: ");
// ===============================================================================
//debug_text cam_text_mov_y(5, 30, &mp->y, "Y: ");
//debug_text cam_text_mov_z(6, 30, &mp->y, "Z: ");
// Mouse capture
////debug_text cam_text_z(3, 30, &p->z);
sf : : Vector2i deltas ;
sf : : Vector2i fixed ( window . getSize ( ) ) ;
//debug_text light_x(7, 30, &light[7], "X: ");
bool mouse_enabled = true ;
//debug_text light_y(8, 30, &light[8], "Y: ");
//debug_text light_z(9, 30, &light[9], "Z: ");
sf : : Vector3f cam_mov_vec ;
//// ===============================================================================
while ( window . isOpen ( ) ) {
//// Mouse capture
//sf::Vector2i deltas;
// Poll for events from the user
//sf::Vector2i fixed(window.getSize());
sf : : Event event ;
//bool mouse_enabled = true;
while ( window . pollEvent ( event ) ) {
//sf::Vector3f cam_mov_vec;
// If the user tries to exit the application via the GUI
if ( event . type = = sf : : Event : : Closed )
//while (window.isOpen()) {
window . close ( ) ;
if ( event . type = = sf : : Event : : KeyPressed ) {
// // Poll for events from the user
if ( event . key . code = = sf : : Keyboard : : Space ) {
// sf::Event event;
if ( mouse_enabled )
// while (window.pollEvent(event)) {
mouse_enabled = false ;
else
// // If the user tries to exit the application via the GUI
mouse_enabled = true ;
// if (event.type == sf::Event::Closed)
}
// window.close();
}
// if (event.type == sf::Event::KeyPressed) {
}
// if (event.key.code == sf::Keyboard::Space) {
// if (mouse_enabled)
cam_vec . x = 0 ;
// mouse_enabled = false;
cam_vec . y = 0 ;
// else
cam_vec . z = 0 ;
// mouse_enabled = true;
// }
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : Q ) ) {
// }
camera . add_relative_impulse ( Camera : : DIRECTION : : DOWN ) ;
// }
}
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : E ) ) {
// cam_vec.x = 0;
camera . add_relative_impulse ( Camera : : DIRECTION : : UP ) ;
// cam_vec.y = 0;
}
// cam_vec.z = 0;
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : W ) ) {
camera . add_relative_impulse ( Camera : : DIRECTION : : FORWARD ) ;
// float speed = 1.0f;
}
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : S ) ) {
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::LShift)) {
camera . add_relative_impulse ( Camera : : DIRECTION : : REARWARD ) ;
// speed = 0.2f;
}
// }
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : A ) ) {
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::Q)) {
camera . add_relative_impulse ( Camera : : DIRECTION : : LEFT ) ;
// camera.add_relative_impulse(Camera::DIRECTION::DOWN, speed);
}
// }
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : D ) ) {
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::E)) {
camera . add_relative_impulse ( Camera : : DIRECTION : : RIGHT ) ;
// camera.add_relative_impulse(Camera::DIRECTION::UP, speed);
}
// }
if ( sf : : Keyboard : : isKeyPressed ( sf : : Keyboard : : T ) ) {
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::W)) {
camera . set_position ( sf : : Vector3f ( 50 , 50 , 50 ) ) ;
// camera.add_relative_impulse(Camera::DIRECTION::FORWARD, speed);
}
// }
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::S)) {
camera . add_static_impulse ( cam_vec ) ;
// camera.add_relative_impulse(Camera::DIRECTION::REARWARD, speed);
// }
if ( mouse_enabled ) {
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::A)) {
deltas = fixed - sf : : Mouse : : getPosition ( ) ;
// camera.add_relative_impulse(Camera::DIRECTION::LEFT, speed);
if ( deltas ! = sf : : Vector2i ( 0 , 0 ) & & mouse_enabled = = true ) {
// }
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::D)) {
// Mouse movement
// camera.add_relative_impulse(Camera::DIRECTION::RIGHT, speed);
sf : : Mouse : : setPosition ( fixed ) ;
// }
camera . slew_camera ( sf : : Vector2f (
// if (sf::Keyboard::isKeyPressed(sf::Keyboard::T)) {
deltas . y / 300.0f ,
// camera.set_position(sf::Vector3f(50, 50, 50));
deltas . x / 300.0f
// }
) ) ;
}
// camera.add_static_impulse(cam_vec);
}
// if (mouse_enabled) {
// Time keeping
// deltas = fixed - sf::Mouse::getPosition();
elapsed_time = elap_time ( ) ;
// if (deltas != sf::Vector2i(0, 0) && mouse_enabled == true) {
delta_time = elapsed_time - current_time ;
current_time = elapsed_time ;
// // Mouse movement
if ( delta_time > 0.2f )
// sf::Mouse::setPosition(fixed);
delta_time = 0.2f ;
// camera.slew_camera(sf::Vector2f(
accumulator_time + = delta_time ;
// deltas.y / 300.0f,
while ( ( accumulator_time - step_size ) > = step_size ) {
// deltas.x / 300.0f
accumulator_time - = step_size ;
// ));
// }
// ==== DELTA TIME LOCKED ====
// }
}
// // Time keeping
float l [ ] = {
// elapsed_time = elap_time();
light [ 9 ] * sin ( delta_time ) + light [ 7 ] * cos ( delta_time ) ,
// delta_time = elapsed_time - current_time;
light [ 8 ] ,
// current_time = elapsed_time;
light [ 9 ] * cos ( delta_time ) - light [ 7 ] * sin ( delta_time )
// if (delta_time > 0.2f)
} ;
// delta_time = 0.2f;
// accumulator_time += delta_time;
float l2 [ ] = {
// while ((accumulator_time - step_size) >= step_size) {
l [ 0 ] * cos ( delta_time ) - l [ 2 ] * sin ( delta_time ) ,
// accumulator_time -= step_size;
l [ 0 ] * sin ( delta_time ) + l [ 2 ] * cos ( delta_time ) ,
l [ 2 ]
// // ==== DELTA TIME LOCKED ====
} ;
// }
light [ 7 ] = l [ 0 ] ;
// float l[] = {
light [ 8 ] = l [ 1 ] ;
// light[9] * sin(delta_time / 1) + light[7] * cos(delta_time / 1),
light [ 9 ] = l [ 2 ] ;
// light[8],
// light[9] * cos(delta_time / 1) - light[7] * sin(delta_time / 1)
// ==== FPS LOCKED ====
// };
camera . update ( delta_time ) ;
// float l2[] = {
// Run the raycast
// l[0] * cos(delta_time) - l[2] * sin(delta_time),
c . run_kernel ( " min_kern " , WORK_SIZE ) ;
// l[0] * sin(delta_time) + l[2] * cos(delta_time),
// l[2]
// ==== RENDER ====
// };
window . clear ( sf : : Color : : Black ) ;
// light[7] = l[0];
// light[8] = l[1];
window . draw ( s ) ;
// light[9] = l[2];
// Give the frame counter the frame time and draw the average frame time
// // ==== FPS LOCKED ====
fps . frame ( delta_time ) ;
// camera.update(delta_time);
fps . draw ( & window ) ;
// // Run the raycast
cam_text_x . draw ( & window ) ;
// c.run_kernel("min_kern", WORK_SIZE);
cam_text_y . draw ( & window ) ;
//
// // ==== RENDER ====
cam_text_mov_x . draw ( & window ) ;
cam_text_mov_y . draw ( & window ) ;
// window.clear(sf::Color::Black);
cam_text_mov_z . draw ( & window ) ;
// window.draw(s);
light_x . draw ( & window ) ;
light_y . draw ( & window ) ;
// // Give the frame counter the frame time and draw the average frame time
light_z . draw ( & window ) ;
// fps.frame(delta_time);
// fps.draw(&window);
window . display ( ) ;
// cam_text_x.draw(&window);
}
// cam_text_y.draw(&window);
// cam_text_mov_x.draw(&window);
// cam_text_mov_y.draw(&window);
// cam_text_mov_z.draw(&window);
// light_x.draw(&window);
// light_y.draw(&window);
// light_z.draw(&window);
//
// window.display();
//}
return 0 ;
return 0 ;
}
}