some audio things
[carveJwlIkooP6JGAAIwe30JlM.git] / world.h
diff --git a/world.h b/world.h
index 3f806cb8714e00dbabf0d8564dede4a7b9acd43b..69def4c85875df63fa9bd9a9c0d207738b94daeb 100644 (file)
--- a/world.h
+++ b/world.h
@@ -53,6 +53,8 @@ enum geo_type
    k_geo_type_water = 2
 };
 
+static const float k_light_cube_size = 8.0f;
+
 struct world_instance 
 {
    /* This is a small flag we use to changelevel.
@@ -79,31 +81,44 @@ struct world_instance
    /* STD140 */
    struct ub_world_lighting
    {
-      /* v3f (padded) */
-      v4f g_light_colours[3],
-          g_light_directions[3],
-          g_ambient_colour;
+      v4f g_cube_min,
+          g_cube_inv_range;
 
       v4f g_water_plane,
           g_depth_bounds;
 
+      v4f g_daysky_colour;
+      v4f g_nightsky_colour;
+      v4f g_sunset_colour;
+      v4f g_ambient_colour;
+      v4f g_sunset_ambient;
+      v4f g_sun_colour;
+      v4f g_sun_dir;
+
       float g_water_fog;
       float g_time;
-      int g_light_count;
+      float g_shadow_length;
+      float g_shadow_spread;
+
+      float g_time_of_day;
+      float g_day_phase;
+      float g_sunset_phase;
+
       int g_light_preview;
       int g_shadow_samples;
 
-#if 0
-      v4f g_point_light_positions[32];
-      v4f g_point_light_colours[32];
-#endif
+      int g_debug_indices;
+      int g_debug_complexity;
    }
    ub_lighting;
    GLuint ubo_lighting;
    int    ubo_bind_point;
 
    GLuint tbo_light_entities,
-          tex_light_entities;
+          tex_light_entities,
+          tex_light_cubes;
+
+   v3i light_cubes;
 
    struct framebuffer heightmap;
 
@@ -213,6 +228,8 @@ struct world_instance
    {
       mdl_node *node;
       struct classtype_world_light *inf;
+      m4x3f inverse_world;
+      v2f angle_sin_cos;
 
       /* enabled.. etc? 
        * TODO: we should order entities in the binary by their type */
@@ -324,8 +341,7 @@ VG_STATIC struct world_global
     * Allocated as system memory
     * --------------------------------------------------------------------------
     */
-   void *generic_heap,
-        *audio_heap;  /* sub buffer of the audio buffer */
+   void *generic_heap;
 
    /* rendering */
    glmesh skydome;
@@ -545,12 +561,14 @@ VG_STATIC void world_init(void)
 
 VG_STATIC void world_audio_init(void)
 {
+#if 0
    u32 size = vg_linear_remaining( vg_audio.audio_pool ) 
                - sizeof(vg_linear_allocator);
 
    world_global.audio_heap = vg_create_linear_allocator( vg_audio.audio_pool, 
                                                          size, 
                                                          VG_MEMORY_SYSTEM );
+#endif
 }
 
 VG_STATIC void world_trigger_achievement( world_instance *world, u32 uid )
@@ -624,7 +642,28 @@ VG_STATIC void world_update( world_instance *world, v3f pos )
    static double g_time = 0.0;
    g_time += vg.time_delta * (1.0/(k_day_length*60.0));
 
-   world->ub_lighting.g_time = g_time;
+
+   struct ub_world_lighting *state = &world->ub_lighting;
+
+   state->g_time = g_time;
+   state->g_debug_indices = k_debug_light_indices;
+   state->g_light_preview = k_light_preview;
+   state->g_debug_complexity = k_debug_light_complexity;
+
+   state->g_time_of_day = vg_fractf( g_time );
+   state->g_day_phase   = cosf( state->g_time_of_day * VG_PIf * 2.0f );
+   state->g_sunset_phase= cosf( state->g_time_of_day * VG_PIf * 4.0f + VG_PIf );
+
+   state->g_day_phase    =       state->g_day_phase    * 0.5f + 0.5f;
+   state->g_sunset_phase = powf( state->g_sunset_phase * 0.5f + 0.5f, 6.0f );
+
+   float a = state->g_time_of_day * VG_PIf * 2.0f;
+   state->g_sun_dir[0] = sinf( a );
+   state->g_sun_dir[1] = cosf( a );
+   state->g_sun_dir[2] = 0.2f;
+   v3_normalize( state->g_sun_dir );
+
+
 
    glBindBuffer( GL_UNIFORM_BUFFER, world->ubo_lighting );
    glBufferSubData( GL_UNIFORM_BUFFER, 0, 
@@ -734,7 +773,7 @@ VG_STATIC void world_update( world_instance *world, v3f pos )
                                                         0xff00ff00 );
    }
 
-   if( k_debug_light_index )
+   if( k_debug_light_indices )
    {
       for( int i=0; i<world->light_count; i++ )
       {