X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=water.h;h=1de2554abf8e459175a30438cb6146e0f24b09a3;hb=b0a4fb814d794157c55212191df200915ab99515;hp=81d709e47956e56e992110f2eb8c945c51ee601a;hpb=4fccea589f00c06c570cc4ea3e7a69d191328ffb;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/water.h b/water.h index 81d709e..1de2554 100644 --- a/water.h +++ b/water.h @@ -1,10 +1,16 @@ +#include "common.h" +#include "model.h" + +static void water_register(void); +static void water_init(void); +static void water_fb_resize(void); +static void water_set_surface( glmesh *surf, float height ); +static float water_height(void); + #ifndef WATER_H #define WATER_H -#define VG_3D -#include "vg/vg.h" - -#include "model.h" +#include "world.h" #include "render.h" #include "shaders/water.h" #include "scene.h" @@ -13,16 +19,26 @@ vg_tex2d tex_water_surf = { .path = "textures/water_surf.qoi" }; static struct { - GLuint fb, rgb, rb; + struct framebuffer fbreflect, fbdepth; glmesh mdl; - GLuint depthmap; boxf depthbounds; int depth_computed; float height; + int enabled; + v4f plane; +} +wrender = +{ + .fbreflect = { .format = GL_RGB, .div = 3 }, + .fbdepth = { .format = GL_RGBA, .div = 4 } +}; + +static float water_height(void) +{ + return wrender.height; } -wrender; static void water_register(void) { @@ -31,47 +47,68 @@ static void water_register(void) static void water_init(void) { - create_renderbuffer_std( &wrender.fb, &wrender.rgb, &wrender.rb ); + /* TODO: probably dont do this every time */ + wrender.enabled = 1; + + fb_init( &wrender.fbreflect ); + fb_init( &wrender.fbdepth ); } -static int ray_world( v3f pos, v3f dir, ray_hit *hit ); +static void water_fb_resize(void) +{ + if( !wrender.enabled ) + return; + + fb_resize( &wrender.fbreflect ); + fb_resize( &wrender.fbdepth ); +} + +#if 0 static void water_compute_depth( boxf bounds ) { + if( !wrender.enabled ) + return; + #ifdef VG_RELEASE int const kres = 512; #else - int const kres = 64; + int const kres = 1024; #endif vg_info( "Computing depth map\n" ); - u8 *img = malloc( kres*kres ); + float *img = malloc( kres*kres*sizeof(float) ); + + boxf interior; + v3_add(bounds[0],(v3f){1.0f,1.0f,1.0f},interior[0]); + v3_sub(bounds[1],(v3f){1.0f,1.0f,1.0f},interior[1]); v3f volume; - v3_sub( bounds[1], bounds[0], volume ); - box_copy( bounds, wrender.depthbounds ); + v3_sub( interior[1], interior[0], volume ); + box_copy( interior, wrender.depthbounds ); for( int y=0; y