Compare commits

...

3 Commits

Author SHA1 Message Date
087fc4a16c making sure the world is cleaned up after main loop 2026-02-16 18:23:45 -06:00
9301fe2696 Various cleanups and fixes 2026-02-16 15:29:10 -06:00
c7cfd5eac0 small player speed refactor 2026-02-16 13:17:51 -06:00
5 changed files with 53 additions and 19 deletions

View File

@@ -13,12 +13,16 @@ main :: proc() {
raylib.SetConfigFlags(config_flags)
raylib.InitWindow(1920, 1080, "Game")
defer raylib.CloseWindow()
raylib.SetTargetFPS(60)
raylib.SetExitKey(nil)
init_world()
defer deinit_world()
player = {
position = {0, 0},
position = {300, 300},
camera = {
zoom = 4,
offset = {f32(raylib.GetScreenWidth()) / 2, f32(raylib.GetScreenHeight()) / 2},
@@ -48,8 +52,6 @@ main :: proc() {
update(delta)
}
raylib.CloseWindow()
}
@(private = "file")

View File

@@ -3,12 +3,15 @@ package main
import "core:math"
import "vendor:raylib"
PLAYER_SPRINT_SPEED :: 80
PLAYER_SPEED :: 50
PLAYER_DEFAULT_SPRINT_SPEED :: 100
PLAYER_DEFAULT_SPEED :: 60
PLAYER_WIDTH :: 32
PLAYER_HEIGHT :: 32
PLAYER_SPRITE_PATH :: "assets/player/player.png"
player_speed := PLAYER_DEFAULT_SPEED
player_sprint_speed := PLAYER_DEFAULT_SPRINT_SPEED
spritesheet: raylib.Texture2D
framesX: i32
framesY: i32
@@ -48,6 +51,9 @@ handle_player_camera :: proc(p: ^Player, delta: f32) {
@(private = "file")
handle_player_input :: proc(p: ^Player, delta: f32) {
if raylib.IsKeyPressed(.ESCAPE) do return
dir: raylib.Vector2 = {0, 0}
if raylib.IsKeyDown(.W) do dir.y -= 1
if raylib.IsKeyDown(.S) do dir.y += 1
@@ -58,8 +64,8 @@ handle_player_input :: proc(p: ^Player, delta: f32) {
is_sprinting := raylib.IsKeyDown(.LEFT_SHIFT)
dir = raylib.Vector2Normalize(dir)
speed_val := f32(is_sprinting ? PLAYER_SPRINT_SPEED : PLAYER_SPEED)
p.animator.anim.fps = is_sprinting ? 11 : 6
speed_val := f32(is_sprinting ? player_sprint_speed : player_speed)
p.animator.anim.fps = is_sprinting ? i32(player_sprint_speed / 10) : i32(player_speed / 10)
velocity := dir * speed_val * delta
@@ -113,6 +119,9 @@ update_player :: proc(p: ^Player, delta: f32) {
handle_player_input(p, delta)
handle_player_camera(p, delta)
// Remove this in release
handle_debug_inputs()
if (p.state == .IDLE) {
set_sprite_animation(&p.animator, &idle_animation)
}
@@ -150,3 +159,17 @@ is_wall_at :: proc(world_pos: raylib.Vector2) -> bool {
return tile != nil && tile.type == .WALL
}
handle_debug_inputs :: proc() {
if (raylib.IsKeyPressed(.KP_ADD)) do player_sprint_speed += 10
if (raylib.IsKeyPressed(.KP_SUBTRACT)) do player_sprint_speed -= 10
if (raylib.IsKeyDown(.LEFT_CONTROL) && raylib.IsKeyPressed(.EQUAL)) {
player.camera.zoom += 0.5
}
if (raylib.IsKeyDown(.LEFT_CONTROL) && raylib.IsKeyPressed(.MINUS)) {
player.camera.zoom -= 0.5
}
}

View File

@@ -6,7 +6,6 @@ TILEMAP_TILE_SIZE :: 16
Tile :: struct {
frame_index: i32,
color: raylib.Color,
type: TileType,
interaction: InteractionType,
resource: ResourceType,
@@ -38,7 +37,6 @@ InteractionType :: enum {
nothing_tile := Tile {
type = .NOTHING,
frame_index = 0,
color = raylib.WHITE,
interaction = .NONE,
resource = .NONE,
animator = nil,
@@ -47,7 +45,6 @@ nothing_tile := Tile {
ground_tile := Tile {
type = .GROUND,
frame_index = 0,
color = raylib.WHITE,
interaction = .NONE,
resource = .NONE,
animator = nil,
@@ -55,8 +52,7 @@ ground_tile := Tile {
test_wall_tile := Tile {
type = .WALL,
frame_index = 1,
color = raylib.WHITE,
frame_index = 5,
interaction = .NONE,
resource = .NONE,
animator = nil,
@@ -65,7 +61,6 @@ test_wall_tile := Tile {
plant_tile := Tile {
type = .FLORA,
frame_index = 0,
color = raylib.WHITE,
interaction = .HARVEST,
resource = .FLORA,
animator = nil,
@@ -74,7 +69,6 @@ plant_tile := Tile {
plant_2_tile := Tile {
type = .FLORA,
frame_index = 1,
color = raylib.WHITE,
interaction = .HARVEST,
resource = .FLORA,
animator = nil,
@@ -83,7 +77,6 @@ plant_2_tile := Tile {
plant_3_tile := Tile {
type = .FLORA,
frame_index = 2,
color = raylib.WHITE,
interaction = .HARVEST,
resource = .FLORA,
animator = nil,

View File

@@ -55,7 +55,12 @@ update_tile_grid :: proc(grid: ^Grid, camera: ^raylib.Camera2D, tile_w, tile_h:
}
}
draw_tile_grid :: proc(sheet: ^TilemapSpritesheet, grid: ^Grid, camera: ^raylib.Camera2D) {
draw_tile_grid :: proc(
sheet: ^TilemapSpritesheet,
grid: ^Grid,
camera: ^raylib.Camera2D,
color: raylib.Color,
) {
tile_w := f32(sheet.tile_width)
tile_h := f32(sheet.tile_height)
@@ -68,7 +73,7 @@ draw_tile_grid :: proc(sheet: ^TilemapSpritesheet, grid: ^Grid, camera: ^raylib.
if tile.type == .NOTHING do continue
pos := raylib.Vector2{f32(x) * tile_w, f32(y) * tile_h}
draw_tile(sheet, tile, pos, raylib.WHITE)
draw_tile(sheet, tile, pos, color)
}
}
}

View File

@@ -1,8 +1,11 @@
package main
import "vendor:raylib"
WORLD_SIZE_X :: 1000
WORLD_SIZE_Y :: 1000
world_base_color := raylib.WHITE
ground_layer_grid: Grid
ground_tilemap_sheet: TilemapSpritesheet
@@ -10,6 +13,9 @@ interactables_layer_grid: Grid
interactables_tilemap_sheet: TilemapSpritesheet
init_world :: proc() {
// world_base_color = {74, 132, 74, 255}
ground_tilemap_sheet = load_tilemap_sheet(
"assets/tiles/master_tilemap.png",
TILEMAP_TILE_SIZE,
@@ -59,7 +65,12 @@ update_world :: proc(delta: f32) {
}
draw_world :: proc() {
draw_tile_grid(&ground_tilemap_sheet, &ground_layer_grid, &player.camera)
draw_tile_grid(&interactables_tilemap_sheet, &interactables_layer_grid, &player.camera)
draw_tile_grid(&ground_tilemap_sheet, &ground_layer_grid, &player.camera, world_base_color)
draw_tile_grid(
&interactables_tilemap_sheet,
&interactables_layer_grid,
&player.camera,
world_base_color,
)
}