X-Git-Url: http://git.mutantstargoat.com?a=blobdiff_plain;f=src%2Fgfxapi.cc;h=f50a3175ee1157ee6af17b6cbd24d18875b73c1b;hb=HEAD;hp=d4464f19abf764a90f77fcced5b40366cd364b40;hpb=3bf3536271e4afa8a8a93c75e2ab1256c0bf718a;p=demo diff --git a/src/gfxapi.cc b/src/gfxapi.cc index d4464f1..f50a317 100644 --- a/src/gfxapi.cc +++ b/src/gfxapi.cc @@ -6,15 +6,24 @@ #include "opengl/mesh-gl.h" #include "opengl/texture-gl.h" #include "opengl/shader-gl.h" +#include "opengl/uniforms-gl.h" +#include "vulkan/shader-vk.h" #include "vulkan/mesh-vk.h" #include "vulkan/texture-vk.h" +#include "vulkan/uniforms-vk.h" static Gfx_API api; void (*gfx_clear)(float r, float g, float b); void (*gfx_viewport)(int x, int y, int width, int height); - +void (*gfx_zbuffer)(bool enable); +void (*gfx_cull_face)(Gfx_cull_face cf); +void (*gfx_reshape)(int width, int height); +void (*gfx_wireframe)(bool enable); +void (*gfx_swapbuffers)(); +void (*gfx_begin_drawing)(); +void (*gfx_end_drawing)(); bool gfx_init(Gfx_API api) { @@ -55,6 +64,7 @@ Mesh *gfx_create_mesh() case GFX_VK: return new MeshVK; } + return 0; } Texture *gfx_create_texture() { @@ -64,6 +74,7 @@ Texture *gfx_create_texture() case GFX_VK: return new TextureVK; } + return 0; } ShaderProgram *gfx_create_shader_program() @@ -72,9 +83,9 @@ ShaderProgram *gfx_create_shader_program() case GFX_GL: return new ShaderProgramGL; case GFX_VK: - // return new ShaderProgramVK; - return 0; + return new ShaderProgramVK; } + return 0; } Shader *gfx_create_shader() @@ -83,17 +94,29 @@ Shader *gfx_create_shader() case GFX_GL: return new ShaderGL; case GFX_VK: - // return new ShaderVK; - return 0; + return new ShaderVK; } + return 0; +} + +UniformBuffer *gfx_create_uniform_buffer() +{ + switch(api) { + case GFX_GL: + return new UniformBufferGL; + case GFX_VK: + return new UniformBufferVK; + } + return 0; } char *gfx_get_shader_path() { switch(api) { case GFX_GL: - return (char *)"gl_shaders"; + return (char *)"shaders"; case GFX_VK: - return (char *)"vk_shaders"; + return (char *)"shaders/spirv"; } -} \ No newline at end of file + return (char *)""; +}