X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=water.h;h=ac1db00dbafaf53001728bc6253f70b855a95a49;hb=3bb0287d544a4cb75de9afe2927ac8e946f3a18e;hp=83a6cf82cded97e1fbd334ea525f791b24d705ac;hpb=e36cb7e44611855d39ba84710a7007ca659e9cd5;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/water.h b/water.h index 83a6cf8..ac1db00 100644 --- a/water.h +++ b/water.h @@ -1,10 +1,17 @@ +#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_compute_depth( boxf bounds ); +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,7 +20,7 @@ vg_tex2d tex_water_surf = { .path = "textures/water_surf.qoi" }; static struct { - GLuint fb, rgb, rb; + struct framebuffer fbreflect, fbdepth; glmesh mdl; GLuint depthmap; @@ -23,7 +30,16 @@ static struct float height; int enabled; } -wrender; +wrender = +{ + .fbreflect = { .format = GL_RGB, .div = 3 }, + .fbdepth = { .format = GL_RGBA, .div = 4 } +}; + +static float water_height(void) +{ + return wrender.height; +} static void water_register(void) { @@ -33,11 +49,21 @@ static void water_register(void) static void water_init(void) { /* TODO: probably dont do this every time */ - create_renderbuffer_std( &wrender.fb, &wrender.rgb, &wrender.rb ); wrender.enabled = 1; + + fb_init( &wrender.fbreflect ); + fb_init( &wrender.fbdepth ); +} + +static void water_fb_resize(void) +{ + if( !wrender.enabled ) + return; + + fb_resize( &wrender.fbreflect ); + fb_resize( &wrender.fbdepth ); } -static int ray_world( v3f pos, v3f dir, ray_hit *hit ); static void water_compute_depth( boxf bounds ) { if( !wrender.enabled ) @@ -52,18 +78,24 @@ static void water_compute_depth( boxf bounds ) vg_info( "Computing depth map\n" ); u8 *img = malloc( kres*kres ); + 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