Compare commits
4 commits
bdba4cc62f
...
89f9bd1913
| Author | SHA1 | Date | |
|---|---|---|---|
| 89f9bd1913 | |||
| 0195d7f9e9 | |||
| d4a5fc78d0 | |||
| c5b8b324db |
8 changed files with 91 additions and 31 deletions
6
.gitmodules
vendored
6
.gitmodules
vendored
|
|
@ -10,3 +10,9 @@
|
|||
[submodule "lib/cameramod"]
|
||||
path = lib/cameramod
|
||||
url = https://github.com/a327ex/ModifiedCamera
|
||||
[submodule "lib/breezefield"]
|
||||
path = lib/breezefield
|
||||
url = https://github.com/HDictus/breezefield
|
||||
[submodule "lib/hc"]
|
||||
path = lib/hc
|
||||
url = https://github.com/vrld/HC
|
||||
|
|
|
|||
6
.vscode/settings.json
vendored
Normal file
6
.vscode/settings.json
vendored
Normal file
|
|
@ -0,0 +1,6 @@
|
|||
{
|
||||
"Lua.diagnostics.globals": [
|
||||
"love",
|
||||
"Circle"
|
||||
]
|
||||
}
|
||||
1
lib/breezefield
Submodule
1
lib/breezefield
Submodule
|
|
@ -0,0 +1 @@
|
|||
Subproject commit 01faa2dd8def34aecc7018492f93f5a8e224237a
|
||||
1
lib/hc
Submodule
1
lib/hc
Submodule
|
|
@ -0,0 +1 @@
|
|||
Subproject commit eb1f285cb1cc4d951d90c92b64a4fc85e7ed06bd
|
||||
14
main.lua
14
main.lua
|
|
@ -12,6 +12,8 @@ Baton = require 'lib/baton/baton'
|
|||
---@type Timer
|
||||
Timer = require 'lib/hump/timer'
|
||||
|
||||
HC = require 'lib/hc'
|
||||
|
||||
Camera = require 'lib/cameramod/camera'
|
||||
require 'lib/cameramod/Shake'
|
||||
|
||||
|
|
@ -20,9 +22,6 @@ Room = require 'obj/Room'
|
|||
Area = require 'obj/Area'
|
||||
GameObject = require 'obj/GameObject'
|
||||
|
||||
-- game objects --
|
||||
Circle = require 'obj/game/Circle'
|
||||
|
||||
function love.load()
|
||||
-- screen setup
|
||||
love.graphics.setDefaultFilter("nearest")
|
||||
|
|
@ -32,6 +31,13 @@ function love.load()
|
|||
---@type Room|nil
|
||||
current_room = nil
|
||||
|
||||
-- load game objects
|
||||
local game_objects = {}
|
||||
print('loading game objects:')
|
||||
recursiveEnumerate('obj/game', game_objects)
|
||||
for _,v in ipairs(game_objects) do print('',v) end
|
||||
requireFiles(game_objects, true)
|
||||
|
||||
-- load rooms
|
||||
local room_files = {}
|
||||
print('loading rooms:')
|
||||
|
|
@ -59,7 +65,7 @@ end
|
|||
function love.update(dt)
|
||||
if current_room then current_room:update(dt) end
|
||||
input:update(dt)
|
||||
if input:pressed('f1') then gotoRoom('Stage') end
|
||||
if input:pressed('f1') then gotoRoom('CircleRoom') end
|
||||
if input:pressed('f3') then camera:shake(4, 60, 1) end
|
||||
|
||||
camera:update(dt)
|
||||
|
|
|
|||
20
obj/game/Player.lua
Normal file
20
obj/game/Player.lua
Normal file
|
|
@ -0,0 +1,20 @@
|
|||
---@class Player:GameObject
|
||||
---@field area Area
|
||||
---@field x number
|
||||
---@field y number
|
||||
---@field opts table|nil
|
||||
local Player = GameObject:extend()
|
||||
|
||||
function Player:new(area, x, y, opts)
|
||||
Player.super.new(self, area, x, y, opts)
|
||||
end
|
||||
|
||||
function Player:update(dt)
|
||||
Player.super.update(self, dt)
|
||||
end
|
||||
|
||||
function Player:draw()
|
||||
Player.super.draw(self)
|
||||
end
|
||||
|
||||
return Player
|
||||
45
rooms/CircleRoom.lua
Normal file
45
rooms/CircleRoom.lua
Normal file
|
|
@ -0,0 +1,45 @@
|
|||
---@class CircleRoom:Room
|
||||
---@field timer Timer
|
||||
local CircleRoom = Room:extend()
|
||||
|
||||
function CircleRoom:new()
|
||||
CircleRoom.super.new(self)
|
||||
self.timer = Timer()
|
||||
|
||||
-- game objects
|
||||
self.timer:every(2, function()
|
||||
local latest_object = self.area:addGameObject('Circle', love.math.random(1, gw), love.math.random(1, gh))
|
||||
latest_object.timer:after(love.math.random(2, 4), function() latest_object:kill() end)
|
||||
end)
|
||||
end
|
||||
|
||||
function CircleRoom:update(dt)
|
||||
CircleRoom.super.update(self, dt)
|
||||
|
||||
if input:pressed('action') then
|
||||
local latest_object = self.area:addGameObject('Circle', love.math.random(1, gw), love.math.random(1, gh), {radius = 15})
|
||||
end
|
||||
|
||||
if input:pressed('right') then
|
||||
for _, game_object in ipairs(self.area.game_objects) do
|
||||
game_object:kill()
|
||||
end
|
||||
end
|
||||
|
||||
if input:pressed('left') then
|
||||
for _, game_object in ipairs(self.area.game_objects) do
|
||||
if game_object:is(Circle) then
|
||||
---@cast game_object Circle
|
||||
if game_object.mode == "fill" then game_object.mode = "line" else game_object.mode = "fill" end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
self.timer:update(dt)
|
||||
end
|
||||
|
||||
function CircleRoom:canvasDraw()
|
||||
CircleRoom.super.canvasDraw(self)
|
||||
end
|
||||
|
||||
return CircleRoom
|
||||
|
|
@ -1,39 +1,14 @@
|
|||
---@class Stage:Room
|
||||
---@field timer Timer
|
||||
local Stage = Room:extend()
|
||||
|
||||
function Stage:new()
|
||||
Stage.super.new(self)
|
||||
self.timer = Timer()
|
||||
self.timer:every(2, function()
|
||||
local latest_object = self.area:addGameObject('Circle', love.math.random(1, gw), love.math.random(1, gh))
|
||||
latest_object.timer:after(love.math.random(2, 4), function() latest_object:kill() end)
|
||||
end)
|
||||
|
||||
self.area:addGameObject('Player', gw/2, gh/2)
|
||||
end
|
||||
|
||||
function Stage:update(dt)
|
||||
Stage.super.update(self, dt)
|
||||
|
||||
if input:pressed('action') then
|
||||
local latest_object = self.area:addGameObject('Circle', love.math.random(1, gw), love.math.random(1, gh), {radius = 15})
|
||||
end
|
||||
|
||||
if input:pressed('right') then
|
||||
for _, game_object in ipairs(self.area.game_objects) do
|
||||
game_object:kill()
|
||||
end
|
||||
end
|
||||
|
||||
if input:pressed('left') then
|
||||
for _, game_object in ipairs(self.area.game_objects) do
|
||||
if game_object:is(Circle) then
|
||||
---@cast game_object Circle
|
||||
if game_object.mode == "fill" then game_object.mode = "line" else game_object.mode = "fill" end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
self.timer:update(dt)
|
||||
end
|
||||
|
||||
function Stage:canvasDraw()
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue