Use 4-channel pixel for font texture atlas
This commit is contained in:
parent
2d349436da
commit
fc9506f520
@ -166,7 +166,7 @@ strlit("/usr/share/fonts/TTF/FiraSans-Regular.ttf")
|
||||
.width = texture_atlas.width,
|
||||
.height = texture_atlas.height,
|
||||
.depth = 1,
|
||||
.format = R8_UNORM,
|
||||
.format = R8G8B8A8_SRGB,
|
||||
});
|
||||
DescriptorSetUpdate descriptor_set_updates[] = {
|
||||
{
|
||||
|
@ -24781,7 +24781,7 @@ void entry_point(int argc, char* argv[], char* envp[])
|
||||
unit_tests();
|
||||
#endif
|
||||
|
||||
Arena* global_arena = arena_init(MB(2), KB(64), KB(64));
|
||||
Arena* global_arena = arena_init(MB(16), KB(64), KB(64));
|
||||
#if BB_CI
|
||||
|
||||
{
|
||||
|
@ -15,7 +15,7 @@ STRUCT(FontCharacter)
|
||||
|
||||
STRUCT(TextureAtlas)
|
||||
{
|
||||
u8* pointer;
|
||||
u32* pointer;
|
||||
FontCharacter* characters;
|
||||
s32* kerning_tables;
|
||||
u32 width;
|
||||
|
@ -24,7 +24,7 @@ typedef enum TextureFormat : u8
|
||||
|
||||
STRUCT(TextureMemory)
|
||||
{
|
||||
u8* pointer;
|
||||
void* pointer;
|
||||
u32 width;
|
||||
u32 height;
|
||||
u32 depth;
|
||||
|
@ -11,7 +11,6 @@ layout(set = 0, binding = 0) uniform sampler2D atlas_texture;
|
||||
|
||||
void main()
|
||||
{
|
||||
vec4 alpha_v = texture(atlas_texture, in_uv);
|
||||
vec4 sampled = vec4(1.0, 1.0, 1.0, alpha_v.r);
|
||||
vec4 sampled = texture(atlas_texture, in_uv);
|
||||
out_frag_color = in_color * sampled;
|
||||
}
|
||||
|
@ -22,8 +22,7 @@ TextureAtlas font_create_texture_atlas(Arena* arena, TextureAtlasCreate create)
|
||||
result.kerning_tables = arena_allocate(arena, s32, character_count * character_count);
|
||||
result.height = (u32)sqrtf((f32)(create.text_height * create.text_height * character_count));
|
||||
result.width = result.height;
|
||||
auto atlas_size = result.width * result.height;
|
||||
result.pointer = arena_allocate(arena, u8, atlas_size);
|
||||
result.pointer = arena_allocate(arena, u32, result.width * result.height);
|
||||
auto scale_factor = stbtt_ScaleForPixelHeight(&font_info, create.text_height);
|
||||
|
||||
int ascent;
|
||||
@ -88,7 +87,7 @@ TextureAtlas font_create_texture_atlas(Arena* arena, TextureAtlasCreate create)
|
||||
{
|
||||
auto source_index = bitmap_y * width + bitmap_x;
|
||||
auto destination_index = ((height - bitmap_y - 1) + y) * result.width + bitmap_x + x;
|
||||
destination[destination_index] = source[source_index];
|
||||
destination[destination_index] = ((u32)(source[source_index]) << 24) | 0xffffff;
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user