Started on the render-pipeline/pass architecture.
This commit is contained in:
9
pass.odin
Normal file
9
pass.odin
Normal file
@@ -0,0 +1,9 @@
|
||||
package renderer
|
||||
|
||||
RGB_Color :: [3]u8
|
||||
RGBA_Color :: [4]u8
|
||||
|
||||
Pass :: struct {
|
||||
name: string,
|
||||
clear_color: RGB_Color,
|
||||
}
|
||||
47
pipeline.odin
Normal file
47
pipeline.odin
Normal file
@@ -0,0 +1,47 @@
|
||||
package renderer
|
||||
|
||||
import "core:mem"
|
||||
import "core:log"
|
||||
|
||||
MAX_PASSES_IN_PIPELINE :: 8
|
||||
|
||||
Pipeline :: struct {
|
||||
passes: [MAX_PASSES_IN_PIPELINE]^Pass,
|
||||
amount_of_passes: u8,
|
||||
}
|
||||
|
||||
clear_pipeline :: proc(renderer: ^Renderer) {
|
||||
assert(renderer != nil)
|
||||
pipeline := &renderer.pipeline
|
||||
|
||||
pipeline.amount_of_passes = 0;
|
||||
mem.set(&pipeline.passes[0], 0, MAX_PASSES_IN_PIPELINE * size_of(Pass))
|
||||
}
|
||||
|
||||
set_pipeline :: proc(renderer: ^Renderer, passes: []^Pass) {
|
||||
clear_pipeline(renderer)
|
||||
for p in passes {
|
||||
if !add_pass_to_pipeline(renderer, p) {
|
||||
return
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@(private="file") add_pass_to_pipeline :: proc(renderer: ^Renderer, pass: ^Pass) -> bool {
|
||||
assert(renderer != nil)
|
||||
assert(pass != nil)
|
||||
|
||||
pipeline := &renderer.pipeline
|
||||
|
||||
if pipeline.amount_of_passes == MAX_PASSES_IN_PIPELINE {
|
||||
log.warnf("Failed to add pass '%v' to renderer's pipeline; hit max capacity (%v).", pass.name, MAX_PASSES_IN_PIPELINE)
|
||||
return false
|
||||
}
|
||||
|
||||
pipeline.passes[pipeline.amount_of_passes] = pass
|
||||
pipeline.amount_of_passes += 1
|
||||
|
||||
log.infof("Successfully added pass '%v' to pipeline.", pass.name)
|
||||
|
||||
return true
|
||||
}
|
||||
@@ -1,6 +1,7 @@
|
||||
package renderer
|
||||
|
||||
import "core:fmt"
|
||||
import "core:log"
|
||||
|
||||
RENDER_BACKEND_OPENGL :: #config(RENDER_BACKEND_OPENGL, false)
|
||||
RENDER_BACKEND_VULKAN :: #config(RENDER_BACKEND_VULKAN, false)
|
||||
@@ -13,6 +14,8 @@ Renderer :: struct {
|
||||
viewport: Viewport,
|
||||
surface_ptr: rawptr,
|
||||
backend: rawptr,
|
||||
|
||||
pipeline: Pipeline,
|
||||
}
|
||||
|
||||
Viewport :: struct {
|
||||
@@ -26,7 +29,6 @@ Renderer_API :: enum {
|
||||
Metal,
|
||||
}
|
||||
|
||||
|
||||
create :: proc(surface_ptr: rawptr) -> (^Renderer, bool) {
|
||||
renderer := new(Renderer)
|
||||
renderer.surface_ptr = surface_ptr
|
||||
@@ -64,17 +66,29 @@ set_viewport :: proc(renderer: ^Renderer, x, y, width, height: u16) {
|
||||
}
|
||||
}
|
||||
|
||||
set_clear_color :: proc(renderer: ^Renderer, color: [3]u8) {
|
||||
@(private="file") set_clear_color :: proc(renderer: ^Renderer, color: RGB_Color) {
|
||||
when RENDER_BACKEND_OPENGL {
|
||||
opengl_set_clear_color(renderer, color)
|
||||
}
|
||||
}
|
||||
|
||||
render_frame :: proc(renderer: ^Renderer) {
|
||||
|
||||
pipeline := &renderer.pipeline
|
||||
for i in 0 ..< pipeline.amount_of_passes {
|
||||
pass := pipeline.passes[i]
|
||||
|
||||
// TODO: SS - "Activate" the pass.
|
||||
set_clear_color(renderer, pass.clear_color)
|
||||
|
||||
// TODO: SS - Loop over the pass' render-commands.
|
||||
|
||||
// TODO: SS - "Deactivate" the pass.
|
||||
}
|
||||
|
||||
swap_buffers(renderer)
|
||||
}
|
||||
|
||||
swap_buffers :: proc(renderer: ^Renderer) {
|
||||
@(private="file") swap_buffers :: proc(renderer: ^Renderer) {
|
||||
when RENDER_BACKEND_OPENGL {
|
||||
opengl_swap_buffers(renderer)
|
||||
}
|
||||
|
||||
@@ -69,7 +69,7 @@ when RENDER_BACKEND_OPENGL {
|
||||
)
|
||||
}
|
||||
|
||||
opengl_set_clear_color :: proc(renderer: ^Renderer, color: [3]u8) {
|
||||
opengl_set_clear_color :: proc(renderer: ^Renderer, color: RGB_Color) {
|
||||
gl.ClearColor(
|
||||
f32(color.r) / f32(max(u8)),
|
||||
f32(color.g) / f32(max(u8)),
|
||||
|
||||
Reference in New Issue
Block a user