Rework engine

This commit is contained in:
David Gonzalez Martin 2024-11-30 21:08:25 -06:00 committed by David
parent 6151efb0b5
commit b20395fc1c
16 changed files with 1408 additions and 1196 deletions

View File

@ -226,6 +226,7 @@ if (NOT BB_IS_CI)
"bootstrap/std/font_provider.c" "bootstrap/std/font_provider.c"
"bootstrap/std/graphics.c" "bootstrap/std/graphics.c"
"bootstrap/std/render.c" "bootstrap/std/render.c"
"bootstrap/std/ui_core.c"
) )
target_include_directories(${COMPILER_NAME} PRIVATE dependencies/stb) target_include_directories(${COMPILER_NAME} PRIVATE dependencies/stb)

View File

@ -11,7 +11,7 @@
STRUCT(Vec4) STRUCT(Vec4)
{ {
f32 v[4]; f32 v[4];
}; }__attribute__((aligned(16)));
STRUCT(Vertex) STRUCT(Vertex)
{ {
@ -25,12 +25,23 @@ STRUCT(Vertex)
}; };
decl_vb(Vertex); decl_vb(Vertex);
STRUCT(GPUDrawPushConstants) fn TextureIndex white_texture_create(Arena* arena, Renderer* renderer)
{ {
u64 vertex_buffer; u32 white_texture_width = 1024;
f32 width; u32 white_texture_height = white_texture_width;
f32 height; auto* white_texture_buffer = arena_allocate(arena, u32, white_texture_width * white_texture_height);
}; memset(white_texture_buffer, 0xff, white_texture_width * white_texture_height * sizeof(u32));
auto white_texture = renderer_texture_create(renderer, (TextureMemory) {
.pointer = white_texture_buffer,
.width = white_texture_width,
.height = white_texture_height,
.depth = 1,
.format = TEXTURE_FORMAT_R8G8B8A8_SRGB,
});
return white_texture;
}
fn void draw_string(Renderer* renderer, VirtualBuffer(Vertex)* vertices, VirtualBuffer(u32)* indices, u32 width, u32 height, Vec4 color, String string, TextureAtlas texture_atlas, u32 texture_index) fn void draw_string(Renderer* renderer, VirtualBuffer(Vertex)* vertices, VirtualBuffer(u32)* indices, u32 width, u32 height, Vec4 color, String string, TextureAtlas texture_atlas, u32 texture_index)
{ {
@ -49,8 +60,6 @@ fn void draw_string(Renderer* renderer, VirtualBuffer(Vertex)* vertices, Virtual
auto uv_width = character->width; auto uv_width = character->width;
auto uv_height = character->height; auto uv_height = character->height;
print("UV x: {u32}. UV y: {u32}\n", uv_x, uv_y);
*vb_add(vertices, 1) = (Vertex) { *vb_add(vertices, 1) = (Vertex) {
.x = pos_x, .x = pos_x,
.y = pos_y, .y = pos_y,
@ -97,11 +106,27 @@ fn void draw_string(Renderer* renderer, VirtualBuffer(Vertex)* vertices, Virtual
} }
} }
void run_app(Arena* arena) STRUCT(BBWindow)
{ {
OSWindow os;
RenderWindow* render;
};
STRUCT(BBGUIState)
{
Arena* arena;
BBWindow* first;
BBWindow* last;
};
global_variable BBGUIState state;
void run_app()
{
state.arena = arena_init(MB(512), MB(2), MB(2));
u8 use_x11 = 1; u8 use_x11 = 1;
graphics_init(use_x11); os_graphics_init(use_x11);
GraphicsWindow* window = graphics_window_create((GraphicsWindowCreate) { OSWindow os_window = os_window_create((OSWindowCreate) {
.name = strlit("Bloat Buster"), .name = strlit("Bloat Buster"),
.size = { .size = {
.width = 1024, .width = 1024,
@ -109,67 +134,13 @@ void run_app(Arena* arena)
}, },
}); });
if (!window) if (!os_window)
{ {
failed_execution(); failed_execution();
} }
auto initial_window_size = graphics_window_size_get(window); Renderer* renderer = renderer_initialize(state.arena);
RenderWindow* render_window = renderer_window_initialize(renderer, os_window);
Renderer* renderer = renderer_initialize();
RenderWindow* render_window = renderer_window_initialize(renderer, window);
String shader_source_paths[] = {
strlit("bootstrap/shaders/font.vert"),
strlit("bootstrap/shaders/font.frag"),
};
PipelineLayoutCreate pipeline_layouts[] = {
(PipelineLayoutCreate) {
.push_constant_ranges = array_to_slice(((PushConstantRange[]){
(PushConstantRange) {
.offset = 0,
.size = sizeof(GPUDrawPushConstants),
.stage = SHADER_STAGE_VERTEX,
},
})),
.descriptor_set_layouts = array_to_slice(((DescriptorSetLayout[]){
(DescriptorSetLayout) {
.bindings = array_to_slice(((DescriptorSetLayoutBinding[]) {
{
.binding = 0,
.type = DESCRIPTOR_TYPE_IMAGE_PLUS_SAMPLER,
.stage = SHADER_STAGE_FRAGMENT,
.count = 2,
},
})),
},
})),
},
};
PipelineCreate pipeline_create[] = {
(PipelineCreate) {
.shader_source_indices = array_to_slice(((u16[]){0, 1})),
.layout_index = 0,
},
};
auto pipeline_index = renderer_graphics_pipelines_create(renderer, arena, (GraphicsPipelinesCreate){
.layouts = array_to_slice(pipeline_layouts),
.pipelines = array_to_slice(pipeline_create),
.shader_sources = array_to_slice(shader_source_paths),
});
u32 white_texture_width = 1024;
u32 white_texture_height = white_texture_width;
auto* white_texture_buffer = arena_allocate(arena, u32, white_texture_width * white_texture_height / sizeof(u32));
memset(white_texture_buffer, 0xff, white_texture_width * white_texture_height);
auto white_texture = renderer_texture_create(renderer, (TextureMemory) {
.pointer = white_texture_buffer,
.width = white_texture_width,
.height = white_texture_height,
.depth = 1,
.format = R8G8B8A8_SRGB,
});
auto font_path = auto font_path =
#ifdef _WIN32 #ifdef _WIN32
@ -179,122 +150,154 @@ strlit("/usr/share/fonts/TTF/FiraSans-Regular.ttf")
#else #else
#endif #endif
; ;
auto texture_atlas = font_create_texture_atlas(arena, (TextureAtlasCreate) {
.font_path = font_path,
.text_height = 72,
});
auto texture_atlas_image = renderer_texture_create(renderer, (TextureMemory) {
.pointer = texture_atlas.pointer,
.width = texture_atlas.width,
.height = texture_atlas.height,
.depth = 1,
.format = R8G8B8A8_SRGB,
});
DescriptorSetUpdate descriptor_set_updates[] = {
{
.set = { .value = 0 },
.type = DESCRIPTOR_TYPE_IMAGE_PLUS_SAMPLER,
.binding = 0,
.descriptor_count = 2,
.textures = {
[0] = white_texture,
[1] = texture_atlas_image,
},
},
};
renderer_update_pipeline_resources(renderer, pipeline_index, (Slice(DescriptorSetUpdate)) array_to_slice(descriptor_set_updates)); window_rect_texture_update_begin(render_window);
VirtualBuffer(Vertex) vertices = {};
VirtualBuffer(u32) indices = {};
Vec4 color = {1, 1, 1, 1};
static_assert(sizeof(color) == 4 * sizeof(float));
u32 texture_index = 1;
draw_string(renderer, &vertices, &indices, initial_window_size.width, initial_window_size.height, color, strlit("He"), texture_atlas, texture_index);
auto vertex_buffer_size = sizeof(*vertices.pointer) * vertices.length;
auto index_buffer_size = sizeof(*indices.pointer) * indices.length;
auto vertex_buffer = renderer_buffer_create(renderer, vertex_buffer_size, BUFFER_TYPE_VERTEX);
auto vertex_buffer_device_address = buffer_address(vertex_buffer);
auto index_buffer = renderer_buffer_create(renderer, index_buffer_size, BUFFER_TYPE_INDEX);
auto staging_buffer = renderer_buffer_create(renderer, vertex_buffer_size + index_buffer_size, BUFFER_TYPE_STAGING);
renderer_copy_to_host(staging_buffer, (Slice(HostBufferCopy)) array_to_slice(((HostBufferCopy[]) {
{
.destination_offset = 0,
.source = {
.pointer = (u8*)vertices.pointer,
.length = vertex_buffer_size,
},
},
{
.destination_offset = vertex_buffer_size,
.source = {
.pointer = (u8*)indices.pointer,
.length = index_buffer_size,
},
},
})));
renderer_copy_to_local(renderer, (Slice(LocalBufferCopy)) array_to_slice(((LocalBufferCopy[]) {
{
.destination = vertex_buffer,
.source = staging_buffer,
.regions = array_to_slice(((LocalBufferCopyRegion[]) {
{
.source_offset = 0,
.destination_offset = 0,
.size = vertex_buffer_size,
},
})),
},
{
.destination = index_buffer,
.source = staging_buffer,
.regions = array_to_slice(((LocalBufferCopyRegion[]) {
{
.source_offset = vertex_buffer_size,
.destination_offset = 0,
.size = index_buffer_size,
},
})),
},
})));
while (!graphics_window_should_close(window))
{ {
graphics_poll_events(); auto white_texture = white_texture_create(state.arena, renderer);
auto monospace_font = font_texture_atlas_create(state.arena, renderer, (TextureAtlasCreate) {
.font_path = font_path,
.text_height = 180,
});
auto proportional_font = font_texture_atlas_create(state.arena, renderer, (TextureAtlasCreate) {
.font_path = font_path,
.text_height = 180,
});
window_queue_rect_texture_update(render_window, RECT_TEXTURE_SLOT_WHITE, white_texture);
renderer_queue_font_update(renderer, render_window, RENDER_FONT_TYPE_MONOSPACE, monospace_font);
renderer_queue_font_update(renderer, render_window, RENDER_FONT_TYPE_PROPORTIONAL, proportional_font);
}
window_rect_texture_update_end(renderer, render_window);
auto mouse_position = graphics_window_cursor_position_get(window); // Vec4 color = {1, 1, 1, 1};
// static_assert(sizeof(color) == 4 * sizeof(float));
//
// u32 texture_index = 1;
// // draw_string(renderer, &vertices, &indices, window_size.width, window_size.height, color, strlit("He"), texture_atlas, texture_index);
//
//
// vb_copy_array(&vertices, box_vertices);
// vb_copy_array(&indices, box_indices);
//
// auto vertex_buffer_size = sizeof(*vertices.pointer) * vertices.length;
// auto index_buffer_size = sizeof(*indices.pointer) * indices.length;
//
// auto vertex_buffer = renderer_buffer_create(renderer, vertex_buffer_size, BUFFER_TYPE_VERTEX);
// auto vertex_buffer_device_address = buffer_address(vertex_buffer);
// auto index_buffer = renderer_buffer_create(renderer, index_buffer_size, BUFFER_TYPE_INDEX);
// auto staging_buffer = renderer_buffer_create(renderer, vertex_buffer_size + index_buffer_size, BUFFER_TYPE_STAGING);
//
// renderer_copy_to_host(staging_buffer, (Slice(HostBufferCopy)) array_to_slice(((HostBufferCopy[]) {
// {
// .destination_offset = 0,
// .source = {
// .pointer = (u8*)vertices.pointer,
// .length = vertex_buffer_size,
// },
// },
// {
// .destination_offset = vertex_buffer_size,
// .source = {
// .pointer = (u8*)indices.pointer,
// .length = index_buffer_size,
// },
// },
// })));
//
// renderer_copy_to_local(renderer, (Slice(LocalBufferCopy)) array_to_slice(((LocalBufferCopy[]) {
// {
// .destination = vertex_buffer,
// .source = staging_buffer,
// .regions = array_to_slice(((LocalBufferCopyRegion[]) {
// {
// .source_offset = 0,
// .destination_offset = 0,
// .size = vertex_buffer_size,
// },
// })),
// },
// {
// .destination = index_buffer,
// .source = staging_buffer,
// .regions = array_to_slice(((LocalBufferCopyRegion[]) {
// {
// .source_offset = vertex_buffer_size,
// .destination_offset = 0,
// .size = index_buffer_size,
// },
// })),
// },
// })));
while (!os_window_should_close(os_window))
{
os_poll_events();
auto mouse_position = os_window_cursor_position_get(os_window);
// print("Mouse position: ({f64}, {f64})\n", mouse_position.x, mouse_position.y); // print("Mouse position: ({f64}, {f64})\n", mouse_position.x, mouse_position.y);
auto frame_window_size = renderer_window_frame_begin(renderer, render_window); renderer_window_frame_begin(renderer, render_window);
u32 box_x = 200;
u32 box_y = 200;
u32 box_width = 100;
u32 box_height = 100;
Vec4 box_color = { 1, 0, 0, 1 };
window_command_begin(render_window); Vertex box_vertices[] = {
{
window_bind_pipeline(render_window, pipeline_index); .x = box_x,
window_bind_pipeline_descriptor_sets(render_window, pipeline_index); .y = box_y,
window_bind_index_buffer(render_window, index_buffer, 0, INDEX_TYPE_U32); .color = box_color,
GPUDrawPushConstants push_constants = { },
.vertex_buffer = vertex_buffer_device_address, {
.width = (f32)frame_window_size.width, .x = box_x + box_width,
.height = (f32)frame_window_size.height, .y = box_y,
.color = box_color,
},
{
.x = box_x,
.y = box_y + box_height,
.color = box_color,
},
{
.x = box_x + box_width,
.y = box_y + box_height,
.color = box_color,
},
}; };
window_push_constants(render_window, pipeline_index, (SliceP(void)) array_to_slice(((void*[]) {&push_constants})));
window_render_begin(render_window); u32 box_indices[] = {
{ 0, 1, 2,
window_draw_indexed(render_window, indices.length, 1, 0, 0, 0); 1, 3, 2,
} };
window_render_end(render_window);
window_command_end(render_window); window_pipeline_add_vertices(render_window, BB_PIPELINE_RECT, (String)array_to_bytes(box_vertices));
window_pipeline_add_indices(render_window, BB_PIPELINE_RECT, (Slice(u32))array_to_slice(box_indices));
renderer_window_frame_end(renderer, render_window); renderer_window_frame_end(renderer, render_window);
// window_size = os_window_size_get(os_window);
//
// window_command_begin(render_window);
//
// // window_bind_pipeline(render_window, pipeline_index);
// // window_bind_pipeline_descriptor_sets(render_window, pipeline_index);
// // window_bind_index_buffer(render_window, index_buffer, 0, INDEX_TYPE_U32);
// // GPUDrawPushConstants push_constants = {
// // .vertex_buffer = vertex_buffer_device_address,
// // .width = (f32)window_size.width,
// // .height = (f32)window_size.height,
// // };
// // window_push_constants(render_window, pipeline_index, (SliceP(void)) array_to_slice(((void*[]) {&push_constants})));
//
// window_render_begin(render_window);
// {
// // window_draw_indexed(render_window, indices.length, 1, 0, 0, 0);
// }
// window_render_end(render_window);
//
// window_command_end(render_window);
//
// renderer_window_frame_end(renderer, render_window);
} }
// TODO: deinitialization // TODO: deinitialization

View File

@ -24781,8 +24781,8 @@ void entry_point(int argc, char* argv[], char* envp[])
unit_tests(); unit_tests();
#endif #endif
Arena* global_arena = arena_init(MB(16), KB(64), KB(64));
#if BB_CI #if BB_CI
Arena* global_arena = arena_init(MB(512), KB(64), KB(64));
{ {
arguments.length = cast_to(u64, s32, argc); arguments.length = cast_to(u64, s32, argc);
@ -24850,6 +24850,6 @@ void entry_point(int argc, char* argv[], char* envp[])
thread_clear(thread); thread_clear(thread);
#else #else
run_app(global_arena); run_app();
#endif #endif
} }

View File

@ -2,6 +2,6 @@
#include <std/base.h> #include <std/base.h>
#include <std/os.h> #include <std/os.h>
EXPORT void run_app(Arena* arena); EXPORT void run_app();
#endif #endif

View File

@ -252,3 +252,8 @@ Hash64 hash_bytes(String bytes);
Hash32 hash64_to_hash32(Hash64 hash64); Hash32 hash64_to_hash32(Hash64 hash64);
u64 round_up_to_next_power_of_2(u64 n); u64 round_up_to_next_power_of_2(u64 n);
STRUCT(TextureIndex)
{
u32 value;
};

View File

@ -1,3 +1,5 @@
#pragma once
#include <std/base.h> #include <std/base.h>
#include <std/os.h> #include <std/os.h>
@ -23,6 +25,7 @@ STRUCT(TextureAtlas)
s32 ascent; s32 ascent;
s32 descent; s32 descent;
s32 line_gap; s32 line_gap;
TextureIndex texture;
}; };
STRUCT(TextureAtlasCreate) STRUCT(TextureAtlasCreate)
@ -31,4 +34,6 @@ STRUCT(TextureAtlasCreate)
u32 text_height; u32 text_height;
}; };
EXPORT TextureAtlas font_create_texture_atlas(Arena* arena, TextureAtlasCreate create); #include <std/render.h>
EXPORT TextureAtlas font_texture_atlas_create(Arena* arena, Renderer* renderer, TextureAtlasCreate create);

View File

@ -3,43 +3,48 @@
#include <std/base.h> #include <std/base.h>
#include <std/os.h> #include <std/os.h>
STRUCT(GraphicsWindowSize) typedef void* OSWindow;
typedef void OSWindowResize(OSWindow window, void* context, u32 width, u32 height);
typedef void OSWindowRefresh(OSWindow window, void* context);
STRUCT(OSWindowSize)
{ {
u32 width; u32 width;
u32 height; u32 height;
}; };
STRUCT(GraphicsWindowCreate) STRUCT(OSWindowCreate)
{ {
String name; String name;
GraphicsWindowSize size; OSWindowSize size;
void* context;
OSWindowResize* resize_callback;
OSWindowRefresh* refresh_callback;
}; };
STRUCT(GraphicsCursorPosition) STRUCT(OSCursorPosition)
{ {
f64 x; f64 x;
f64 y; f64 y;
}; };
typedef struct GraphicsWindow GraphicsWindow; EXPORT void os_graphics_init(u8 should_use_x11);
EXPORT OSWindow os_window_create(OSWindowCreate create);
EXPORT void graphics_init(u8 should_use_x11); EXPORT u8 os_window_should_close(OSWindow window);
EXPORT GraphicsWindow* graphics_window_create(GraphicsWindowCreate create); EXPORT void os_poll_events();
EXPORT u8 graphics_window_should_close(GraphicsWindow* window); EXPORT OSWindowSize os_window_size_get(OSWindow window);
EXPORT void graphics_poll_events(); EXPORT OSCursorPosition os_window_cursor_position_get(OSWindow window);
EXPORT GraphicsWindowSize graphics_window_size_get(GraphicsWindow* window);
EXPORT void graphics_window_consume_resize(GraphicsWindow* window);
EXPORT GraphicsCursorPosition graphics_window_cursor_position_get(GraphicsWindow* window);
#ifdef __linux__ #ifdef __linux__
typedef unsigned long XID; typedef unsigned long XID;
typedef struct _XDisplay Display; typedef struct _XDisplay Display;
typedef XID Window; typedef XID Window;
EXPORT Display* graphics_x11_display_get(); EXPORT Display* x11_display_get();
EXPORT Window graphics_x11_window_get(GraphicsWindow* window); EXPORT Window x11_window_get(OSWindow window);
#endif #endif
#ifdef _WIN32 #ifdef _WIN32
EXPORT HANDLE graphics_win32_window_get(GraphicsWindow* window); EXPORT HANDLE win32_window_get(GraphicsWindow* window);
#endif #endif

View File

@ -1,25 +1,46 @@
#pragma once #pragma once
#include <std/base.h> #include <std/base.h>
#include <std/graphics.h>
#define frame_overlap (2)
typedef struct Renderer Renderer; typedef struct Renderer Renderer;
#include <std/graphics.h>
#include <std/font_provider.h>
typedef struct RenderWindow RenderWindow; typedef struct RenderWindow RenderWindow;
typedef struct Pipeline Pipeline; typedef struct Pipeline Pipeline;
typedef enum BBPipeline
{
BB_PIPELINE_RECT,
BB_PIPELINE_COUNT,
} BBPipeline;
typedef enum RenderFontType
{
RENDER_FONT_TYPE_MONOSPACE,
RENDER_FONT_TYPE_PROPORTIONAL,
RENDER_FONT_TYPE_COUNT,
} RenderFontType;
typedef enum RectTextureSlot
{
RECT_TEXTURE_SLOT_WHITE,
RECT_TEXTURE_SLOT_MONOSPACE_FONT,
RECT_TEXTURE_SLOT_PROPORTIONAL_FONT,
RECT_TEXTURE_SLOT_COUNT
} RectTextureSlot;
typedef enum IndexType : u8 typedef enum IndexType : u8
{ {
INDEX_TYPE_U16,
INDEX_TYPE_U32, INDEX_TYPE_U32,
} IndexType; } IndexType;
typedef enum TextureFormat : u8 typedef enum TextureFormat : u8
{ {
R8_UNORM, TEXTURE_FORMAT_R8_UNORM,
R8G8B8A8_SRGB, TEXTURE_FORMAT_R8G8B8A8_SRGB,
} TextureFormat; } TextureFormat;
STRUCT(TextureMemory) STRUCT(TextureMemory)
@ -67,16 +88,16 @@ STRUCT(DescriptorSetLayoutBinding)
}; };
declare_slice(DescriptorSetLayoutBinding); declare_slice(DescriptorSetLayoutBinding);
STRUCT(DescriptorSetLayout) STRUCT(DescriptorSetLayoutCreate)
{ {
Slice(DescriptorSetLayoutBinding) bindings; Slice(DescriptorSetLayoutBinding) bindings;
}; };
declare_slice(DescriptorSetLayout); declare_slice(DescriptorSetLayoutCreate);
STRUCT(PipelineLayoutCreate) STRUCT(PipelineLayoutCreate)
{ {
Slice(PushConstantRange) push_constant_ranges; Slice(PushConstantRange) push_constant_ranges;
Slice(DescriptorSetLayout) descriptor_set_layouts; Slice(DescriptorSetLayoutCreate) descriptor_set_layouts;
}; };
declare_slice(PipelineLayoutCreate); declare_slice(PipelineLayoutCreate);
@ -87,11 +108,6 @@ STRUCT(GraphicsPipelinesCreate)
Slice(PipelineCreate) pipelines; Slice(PipelineCreate) pipelines;
}; };
STRUCT(TextureIndex)
{
u32 value;
};
STRUCT(PipelineIndex) STRUCT(PipelineIndex)
{ {
u32 value; u32 value;
@ -107,21 +123,6 @@ STRUCT(DescriptorSetIndex)
u32 value; u32 value;
}; };
#define MAX_TEXTURE_UPDATE_COUNT (32)
#define MAX_DESCRIPTOR_SET_UPDATE_COUNT (16)
STRUCT(DescriptorSetUpdate)
{
DescriptorSetIndex set;
DescriptorType type;
u32 binding;
u32 descriptor_count;
union
{
TextureIndex textures[MAX_TEXTURE_UPDATE_COUNT];
};
};
declare_slice(DescriptorSetUpdate);
typedef enum BufferType : u8 typedef enum BufferType : u8
{ {
BUFFER_TYPE_VERTEX, BUFFER_TYPE_VERTEX,
@ -129,11 +130,6 @@ typedef enum BufferType : u8
BUFFER_TYPE_STAGING, BUFFER_TYPE_STAGING,
} BufferType; } BufferType;
STRUCT(BufferIndex)
{
u32 value;
};
STRUCT(HostBufferCopy) STRUCT(HostBufferCopy)
{ {
String source; String source;
@ -149,35 +145,24 @@ STRUCT(LocalBufferCopyRegion)
}; };
declare_slice(LocalBufferCopyRegion); declare_slice(LocalBufferCopyRegion);
STRUCT(LocalBufferCopy) EXPORT Renderer* renderer_initialize(Arena* arena);
{ EXPORT RenderWindow* renderer_window_initialize(Renderer* renderer, OSWindow window);
BufferIndex destination;
BufferIndex source;
Slice(LocalBufferCopyRegion) regions;
};
declare_slice(LocalBufferCopy);
#define MAX_LOCAL_BUFFER_COPY_COUNT (16)
EXPORT Renderer* renderer_initialize();
EXPORT RenderWindow* renderer_window_initialize(Renderer* renderer, GraphicsWindow* window);
EXPORT PipelineIndex renderer_graphics_pipelines_create(Renderer* renderer, Arena* arena, GraphicsPipelinesCreate create_data); EXPORT PipelineIndex renderer_graphics_pipelines_create(Renderer* renderer, Arena* arena, GraphicsPipelinesCreate create_data);
EXPORT PipelineLayoutIndex renderer_pipeline_get_layout(PipelineIndex pipeline); EXPORT PipelineLayoutIndex renderer_pipeline_get_layout(PipelineIndex pipeline);
EXPORT GraphicsWindowSize renderer_window_frame_begin(Renderer* renderer, RenderWindow* window); EXPORT void renderer_window_frame_begin(Renderer* renderer, RenderWindow* window);
EXPORT void renderer_window_frame_end(Renderer* renderer, RenderWindow* window); EXPORT void renderer_window_frame_end(Renderer* renderer, RenderWindow* window);
EXPORT TextureIndex renderer_texture_create(Renderer* renderer, TextureMemory texture_memory); EXPORT TextureIndex renderer_texture_create(Renderer* renderer, TextureMemory texture_memory);
EXPORT BufferIndex renderer_buffer_create(Renderer* renderer, u64 size, BufferType type);
EXPORT void renderer_update_pipeline_resources(Renderer* renderer, PipelineIndex pipeline_index, Slice(DescriptorSetUpdate) descriptor_updates);
EXPORT void renderer_copy_to_host(BufferIndex buffer_index, Slice(HostBufferCopy) regions);
EXPORT void renderer_copy_to_local(Renderer* renderer, Slice(LocalBufferCopy) copies);
EXPORT void window_command_begin(RenderWindow* window); EXPORT void window_command_begin(RenderWindow* window);
EXPORT void window_command_end(RenderWindow* window); EXPORT void window_command_end(RenderWindow* window);
EXPORT void window_render_begin(RenderWindow* window); EXPORT void window_render_begin(RenderWindow* window);
EXPORT void window_render_end(RenderWindow* window); EXPORT void window_render_end(RenderWindow* window);
EXPORT void window_bind_pipeline(RenderWindow* window, PipelineIndex pipeline_index);
EXPORT void window_bind_pipeline_descriptor_sets(RenderWindow* window, PipelineIndex pipeline_index);
EXPORT void window_bind_index_buffer(RenderWindow* window, BufferIndex index_buffer, u64 offset, IndexType index_type);
EXPORT void window_push_constants(RenderWindow* window, PipelineIndex pipeline_index, SliceP(void) memories);
EXPORT u64 buffer_address(BufferIndex buffer_index);
EXPORT void window_draw_indexed(RenderWindow* window, u32 index_count, u32 instance_count, u32 first_index, s32 vertex_offset, u32 first_instance); EXPORT void window_draw_indexed(RenderWindow* window, u32 index_count, u32 instance_count, u32 first_index, s32 vertex_offset, u32 first_instance);
EXPORT void window_rect_texture_update_begin(RenderWindow* window);
EXPORT void renderer_queue_font_update(Renderer* renderer, RenderWindow* window, RenderFontType type, TextureAtlas atlas);
EXPORT void window_queue_rect_texture_update(RenderWindow* window, RectTextureSlot slot, TextureIndex texture_index);
EXPORT void window_rect_texture_update_end(Renderer* renderer, RenderWindow* window);
EXPORT void window_pipeline_add_vertices(RenderWindow* window, BBPipeline pipeline_index, String vertex_memory);
EXPORT void window_pipeline_add_indices(RenderWindow* window, BBPipeline pipeline_index, Slice(u32) indices);

View File

@ -0,0 +1,5 @@
#include <std/base.h>
STRUCT(UI_State)
{
};

View File

@ -15,8 +15,8 @@ layout(set = 0, binding = 0) uniform sampler2D textures[];
void main() void main()
{ {
vec2 texture_size = textureSize(textures[texture_index], 0); vec2 texture_size = textureSize(textures[texture_index], 0);
//debugPrintfEXT("texture uv: (%f, %f)\n", in_screen_uv.x, in_screen_uv.y);
vec2 uv = vec2(in_screen_uv.x / texture_size.x, in_screen_uv.y / texture_size.y); vec2 uv = vec2(in_screen_uv.x / texture_size.x, in_screen_uv.y / texture_size.y);
vec4 sampled = texture(textures[texture_index], uv); vec4 sampled = texture(textures[texture_index], uv);
// debugPrintfEXT("In color: (%f, %f, %f, %f). Sampled: (%f, %f, %f, %f)\n", in_color.x, in_color.y, in_color.z, in_color.w, sampled.x, sampled.y, sampled.z, sampled.w);
out_frag_color = in_color * sampled; out_frag_color = in_color * sampled;
} }

View File

@ -7,7 +7,7 @@
#include <stb_truetype.h> #include <stb_truetype.h>
#pragma clang diagnostic pop #pragma clang diagnostic pop
TextureAtlas font_create_texture_atlas(Arena* arena, TextureAtlasCreate create) TextureAtlas font_texture_atlas_create(Arena* arena, Renderer* renderer, TextureAtlasCreate create)
{ {
auto font_file = file_read(arena, create.font_path); auto font_file = file_read(arena, create.font_path);
stbtt_fontinfo font_info; stbtt_fontinfo font_info;
@ -114,5 +114,13 @@ TextureAtlas font_create_texture_atlas(Arena* arena, TextureAtlasCreate create)
stbtt_FreeBitmap(bitmap, 0); stbtt_FreeBitmap(bitmap, 0);
} }
result.texture = renderer_texture_create(renderer, (TextureMemory) {
.pointer = result.pointer,
.width = result.width,
.height = result.height,
.depth = 1,
.format = TEXTURE_FORMAT_R8G8B8A8_SRGB,
});
return result; return result;
} }

View File

@ -6,18 +6,7 @@
global_variable u8 use_x11 = 0; global_variable u8 use_x11 = 0;
STRUCT(GraphicsWindow) void os_graphics_init(u8 should_use_x11)
{
GLFWwindow* handle;
u8 resized:1;
u32 width;
u32 height;
};
#define MAX_WINDOW_COUNT (32)
global_variable GraphicsWindow windows[MAX_WINDOW_COUNT];
global_variable u32 window_count = 0;
void graphics_init(u8 should_use_x11)
{ {
#ifdef __linux__ #ifdef __linux__
use_x11 = should_use_x11; use_x11 = should_use_x11;
@ -31,78 +20,80 @@ void graphics_init(u8 should_use_x11)
} }
} }
fn void framebuffer_size_callback(GLFWwindow* w, int width, int height) global_variable OSWindowResize* resize_callback;
global_variable OSWindowRefresh* refresh_callback;
fn void os_framebuffer_size_callback(GLFWwindow* w, int width, int height)
{ {
GraphicsWindow* window = glfwGetWindowUserPointer(w); void* context = glfwGetWindowUserPointer(w);
assert(window->handle == w); if (resize_callback)
window->width = width; {
window->height = height; resize_callback(w, context, width, height);
window->resized = 1; }
} }
typedef void (* GLFWframebuffersizefun)(GLFWwindow* window, int width, int height); fn void os_window_refresh_callback(GLFWwindow* w)
{
void* context = glfwGetWindowUserPointer(w);
if (refresh_callback)
{
refresh_callback(w, context);
}
}
GraphicsWindow* graphics_window_create(GraphicsWindowCreate create) OSWindow os_window_create(OSWindowCreate create)
{ {
glfwWindowHint(GLFW_CLIENT_API, GLFW_NO_API); glfwWindowHint(GLFW_CLIENT_API, GLFW_NO_API);
GraphicsWindow* window = &windows[window_count]; GLFWwindow* window = glfwCreateWindow(create.size.width, create.size.height, string_to_c(create.name), 0, 0);
*window = (GraphicsWindow) { glfwSetWindowUserPointer(window, create.context);
.handle = glfwCreateWindow(create.size.width, create.size.height, string_to_c(create.name), 0, 0), glfwSetFramebufferSizeCallback(window, &os_framebuffer_size_callback);
}; glfwSetWindowRefreshCallback(window, &os_window_refresh_callback);
glfwSetWindowUserPointer(window->handle, window); resize_callback = create.resize_callback;
glfwSetFramebufferSizeCallback(window->handle, &framebuffer_size_callback); refresh_callback = create.refresh_callback;
window->width = create.size.width;
window->height = create.size.height;
return window; return window;
} }
void graphics_window_consume_resize(GraphicsWindow* window) u8 os_window_should_close(OSWindow window)
{ {
assert(window->resized); return glfwWindowShouldClose(window);
window->resized = 0;
} }
u8 graphics_window_should_close(GraphicsWindow* window) void os_poll_events()
{
return glfwWindowShouldClose(window->handle);
}
void graphics_poll_events()
{ {
glfwPollEvents(); glfwPollEvents();
} }
GraphicsWindowSize graphics_window_size_get(GraphicsWindow* window) OSWindowSize os_window_size_get(OSWindow window)
{ {
GraphicsWindowSize result; OSWindowSize result;
glfwGetWindowSize(window->handle, (int*)&result.width, (int*)&result.height); glfwGetWindowSize(window, (int*)&result.width, (int*)&result.height);
return result; return result;
} }
GraphicsCursorPosition graphics_window_cursor_position_get(GraphicsWindow* window) OSCursorPosition os_window_cursor_position_get(OSWindow window)
{ {
GraphicsCursorPosition result; OSCursorPosition result;
glfwGetCursorPos(window->handle, &result.x, &result.y); glfwGetCursorPos(window, &result.x, &result.y);
return result; return result;
} }
#ifdef _WIN32 #ifdef _WIN32
HANDLE graphics_win32_window_get(GraphicsWindow* window) HANDLE win32_window_get(OSWindow window)
{ {
return glfwGetWin32Window(window->handle); return glfwGetWin32Window(window);
} }
#endif #endif
#ifdef __linux__ #ifdef __linux__
Display* graphics_x11_display_get() Display* x11_display_get()
{ {
return glfwGetX11Display(); return glfwGetX11Display();
} }
Window graphics_x11_window_get(GraphicsWindow* window) Window x11_window_get(OSWindow window)
{ {
return glfwGetX11Window(window->handle); return glfwGetX11Window(window);
} }
#endif #endif

View File

@ -21,7 +21,7 @@ EXPORT TextureMemory texture_load_from_file(Arena* arena, String path)
.pointer = buffer, .pointer = buffer,
.width = width, .width = width,
.height = height, .height = height,
.format = R8G8B8A8_SRGB, .format = TEXTURE_FORMAT_R8G8B8A8_SRGB,
.depth = 1, .depth = 1,
}; };
} }

File diff suppressed because it is too large Load Diff

View File

@ -116,7 +116,11 @@ String compile_shader(Arena* arena, String path, ShaderStage shader_stage)
strlit(".spv"), strlit(".spv"),
}))); })));
char* arguments[] = { char* arguments[] = {
#if _WIN32
"C:/VulkanSDK/1.3.296.0/Bin/glslangValidator.exe",
#else
"/usr/bin/glslangValidator", "/usr/bin/glslangValidator",
#endif
"-V", "-V",
string_to_c(path), string_to_c(path),
"-o", "-o",

3
bootstrap/std/ui_core.c Normal file
View File

@ -0,0 +1,3 @@
#include <std/ui_core.h>