X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=world_sfd.h;h=176425dfea664ba49112f004dc90c993602e64b0;hb=859178c6d4b2a9b9a95f8b01b113f589ce0f197f;hp=3f94c4ed86fae271a5948d20c521179ccf395c65;hpb=0ae443b3f6b4b753f9a2eba58da597ae8cb14b4f;p=carveJwlIkooP6JGAAIwe30JlM.git diff --git a/world_sfd.h b/world_sfd.h index 3f94c4e..176425d 100644 --- a/world_sfd.h +++ b/world_sfd.h @@ -1,216 +1,42 @@ /* - * Copyright (C) 2021-2022 Mt.ZERO Software, Harry Godden - All Rights Reserved + * Copyright (C) 2021-2023 Mt.ZERO Software, Harry Godden - All Rights Reserved */ #ifndef SFD_H #define SFD_H #include "world.h" +#include "world_routes.h" +#include "scene.h" -#include "shaders/scoretext.h" -#include "shaders/vblend.h" +struct world_sfd{ + GLuint tex_scoretex; -vg_tex2d tex_scoretext = { .path = "textures/scoretext.qoi", - .flags = VG_TEXTURE_CLAMP|VG_TEXTURE_NEAREST }; + glmesh mesh_base, mesh_display; + mdl_submesh sm_base; -/* - * TODO: utf-8 -> ascii - */ - -float sfd_encode_glyph( char c ) -{ - int value = 0; - if( c >= 'a' && c <= 'z' ) - value = c-'a'+11; - else if( c >= '0' && c <= '9' ) - value = c-'0'+1; - else if( c >= 'A' && c <= 'Z' ) - value = c-'A'+11; - else if( c >= '\x01' && c <= '\x01'+10 ) - value = 63-c; - else - { - int base = 11+26; - - switch( c ) - { - case '!': value=base+0; break; - case '?': value=base+1; break; - case ',': value=base+2; break; - case '.': value=base+3; break; - case '#': value=base+4; break; - case '$': value=base+5; break; - case '%': value=base+6; break; - case '*': value=base+7; break; - case '+': value=base+8; break; - case '-': value=base+9; break; - case '/': value=base+10; break; - case ':': value=base+11; break; - default: value=0; break; - } - } - - return (float)value; -} - -VG_STATIC void sfd_encode( u32 row, const char *str ) -{ - int end=0; - u32 row_h = world.sfd.h -1 -row; - - for( int i=0; i rate ) - { - *cur += rate; - if( *cur > 60.0f ) - *cur -= 60.0f; - } - else - *cur = *target; - } -} - -VG_STATIC void bind_terrain_noise(void); -VG_STATIC void sfd_render( m4x4f projection, v3f camera, m4x3f transform ) -{ - mesh_bind( &world.sfd.mesh_display ); - - shader_scoretext_use(); - shader_scoretext_uTexGarbage(0); - shader_scoretext_uTexGradients(1); - shader_link_standard_ub( _shader_scoretext.id, 2 ); - bind_terrain_noise(); - vg_tex2d_bind( &tex_scoretext, 1 ); - - shader_scoretext_uPv( projection ); - shader_scoretext_uMdl( transform ); - shader_scoretext_uCamera( camera ); - - for( int y=0;ysubmesh_buffer[ pn_backer->submesh_start ]; - mdl_node *pn_card = mdl_node_from_name( mboard, "score_card" ); - mdl_submesh *card = &mboard->submesh_buffer[ pn_card->submesh_start ]; - - m4x3f identity; - m4x3_identity( identity ); - - for( int i=4;i<6;i++ ) - { - u32 vert_start = sc->vertex_count; - scene_add_submesh( sc, mboard, card, identity ); - - for( int j=0; jvertex_count; j++ ) - { - mdl_vert *vert = &sc->arrvertices[ vert_start+j ]; - - float const k_glyph_uvw = 1.0f/64.0f; - vert->uv[0] -= k_glyph_uvw * (float)(i-4); - vert->colour[0] = 0.0f; - vert->colour[1] = i*36; - } - } - - vg_acquire_thread_sync(); - { - scene_upload( sc, &world.sfd.mesh_display ); - mdl_unpack_submesh( mboard, &world.sfd.mesh_base, backer ); - - vg_tex2d_init( (vg_tex2d *[]){ &tex_scoretext }, 1 ); - } - vg_release_thread_sync(); - - int w = 27, - h = 13; + u32 active_route_board; + scene_context scene; - world.sfd.w = w; - world.sfd.h = h; - world.sfd.buffer = vg_linear_alloc( vg_mem.rtmemory, 2*w*h*sizeof(float) ); + u32 view_weekly; - for( int i=0; i