X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=water.h;h=c2a7122c2244c1774e9f49f428803ad6afb85ec1;hb=cb16ccb05a796178c879ea8d5091663d215a5217;hp=83a6cf82cded97e1fbd334ea525f791b24d705ac;hpb=e36cb7e44611855d39ba84710a7007ca659e9cd5;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/water.h b/water.h index 83a6cf8..c2a7122 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 = 4 }, + .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 ) @@ -60,7 +86,7 @@ static void water_compute_depth( boxf bounds ) { for( int x=0; x