working basic game state, state stack
This commit is contained in:
parent
de36d1501f
commit
85af303aa0
|
@ -0,0 +1,2 @@
|
||||||
|
arkanoid
|
||||||
|
core.*
|
45
game.odin
45
game.odin
|
@ -1,11 +1,12 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import rl "vendor:raylib"
|
import rl "vendor:raylib"
|
||||||
|
import "core:fmt"
|
||||||
|
|
||||||
|
|
||||||
Pad :: struct {
|
Pad :: struct {
|
||||||
position: Vec2,
|
position: Vec2,
|
||||||
width: Vec2,
|
size: Vec2,
|
||||||
}
|
}
|
||||||
|
|
||||||
Ball :: struct {
|
Ball :: struct {
|
||||||
|
@ -31,20 +32,40 @@ Game :: struct {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
game_init :: proc() -> Game {
|
game_init :: proc() -> ^GameState {
|
||||||
return Game{
|
state := new(Game)
|
||||||
update = game_update,
|
state.variant = state
|
||||||
draw = game_draw,
|
state.draw = game_draw
|
||||||
lives = 3,
|
state.update = game_update
|
||||||
pad = Pad{
|
state.lives = 3
|
||||||
position = {f32(WINDOW_WIDTH / 2), f32(WINDOW_HEIGHT - 40)}
|
state.pad = Pad{
|
||||||
}
|
position = {f32(WINDOW_WIDTH / 2), f32(WINDOW_HEIGHT - 40)},
|
||||||
|
size = {80, 10},
|
||||||
}
|
}
|
||||||
|
return state
|
||||||
}
|
}
|
||||||
|
|
||||||
game_update :: proc(delta: f32) {
|
game_update :: proc(state: ^GameState, delta: f32) {
|
||||||
|
game := transmute(^Game)state
|
||||||
|
|
||||||
|
using game
|
||||||
|
|
||||||
|
if rl.IsKeyDown(rl.KeyboardKey.LEFT) {
|
||||||
|
pad.position.x -= 100 * delta
|
||||||
|
fmt.println(pad.position)
|
||||||
|
}
|
||||||
|
if rl.IsKeyDown(rl.KeyboardKey.RIGHT) {
|
||||||
|
pad.position.x += 100 * delta
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
game_draw :: proc() {
|
game_draw :: proc(state: ^GameState) {
|
||||||
|
game := transmute(^Game)state
|
||||||
|
|
||||||
|
using game
|
||||||
|
|
||||||
|
rl.ClearBackground(rl.RAYWHITE)
|
||||||
|
|
||||||
|
rl.DrawRectangleV(pad.position, pad.size, rl.GREEN)
|
||||||
}
|
}
|
||||||
|
|
43
main.odin
43
main.odin
|
@ -1,13 +1,52 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import rl "vendor:raylib"
|
import rl "vendor:raylib"
|
||||||
|
import "core:slice"
|
||||||
|
|
||||||
Vec2 :: [2]f32
|
Vec2 :: [2]f32
|
||||||
Vec2i :: [2]i32
|
Vec2i :: [2]i32
|
||||||
|
|
||||||
WINDOW_WIDTH : i32
|
WINDOW_WIDTH : i32 = 800
|
||||||
WINDOW_HEIGHT : i32
|
WINDOW_HEIGHT : i32 = 480
|
||||||
|
|
||||||
|
|
||||||
main :: proc() {
|
main :: proc() {
|
||||||
|
rl.SetConfigFlags(rl.ConfigFlags{.BORDERLESS_WINDOWED_MODE, .VSYNC_HINT, .WINDOW_RESIZABLE})
|
||||||
|
monitor := rl.GetCurrentMonitor()
|
||||||
|
WINDOW_WIDTH = rl.GetMonitorWidth(monitor)
|
||||||
|
WINDOW_HEIGHT = rl.GetMonitorHeight(monitor)
|
||||||
|
rl.InitWindow(WINDOW_WIDTH, WINDOW_HEIGHT, "SinePong")
|
||||||
|
rl.SetTargetFPS(9999)
|
||||||
|
|
||||||
|
stack_init()
|
||||||
|
|
||||||
|
defer {
|
||||||
|
for s, i in state_stack {
|
||||||
|
free(s)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
game := game_init()
|
||||||
|
append(&state_stack, game)
|
||||||
|
|
||||||
|
for (!rl.WindowShouldClose()) {
|
||||||
|
if rl.IsWindowResized() {
|
||||||
|
WINDOW_WIDTH = rl.GetScreenWidth()
|
||||||
|
WINDOW_HEIGHT = rl.GetScreenHeight()
|
||||||
|
}
|
||||||
|
|
||||||
|
current_state := state_stack[len(state_stack)-1]
|
||||||
|
|
||||||
|
delta := rl.GetFrameTime()
|
||||||
|
|
||||||
|
current_state->update(delta)
|
||||||
|
|
||||||
|
{
|
||||||
|
rl.BeginDrawing()
|
||||||
|
defer rl.EndDrawing()
|
||||||
|
current_state->draw()
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
36
state.odin
36
state.odin
|
@ -1,11 +1,14 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
|
import "core:slice"
|
||||||
|
|
||||||
|
StateVariant :: union{^Game, ^Menu}
|
||||||
|
|
||||||
GameState :: struct {
|
GameState :: struct {
|
||||||
update: proc(f32),
|
update: proc(state: ^GameState, delta: f32),
|
||||||
draw: proc(),
|
draw: proc(state: ^GameState),
|
||||||
|
|
||||||
variant: union{^Game, ^Menu}
|
variant: StateVariant
|
||||||
}
|
}
|
||||||
|
|
||||||
new_state :: proc($T: typeid) -> ^T {
|
new_state :: proc($T: typeid) -> ^T {
|
||||||
|
@ -13,3 +16,30 @@ new_state :: proc($T: typeid) -> ^T {
|
||||||
state.variant = state
|
state.variant = state
|
||||||
return state
|
return state
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
STACK_SIZE :: 16
|
||||||
|
state_buf : [STACK_SIZE]^GameState
|
||||||
|
state_stack : [dynamic]^GameState
|
||||||
|
|
||||||
|
stack_init :: proc() {
|
||||||
|
state_stack = slice.into_dynamic(state_buf[:])
|
||||||
|
}
|
||||||
|
|
||||||
|
stack_push :: proc(state: ^GameState) -> (bool) {
|
||||||
|
if len(state_stack) == STACK_SIZE {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
append(&state_stack, state)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
stack_pop :: proc() -> (bool) {
|
||||||
|
if len(state_stack) == 0 {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
state := pop(&state_stack)
|
||||||
|
free(state)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue