Finish online lobbies; 800x800 scale

This commit is contained in:
Jaidyn Ann 2021-02-07 13:27:36 -06:00
parent 487cde4801
commit ae75f23025
2 changed files with 267 additions and 69 deletions

View File

@ -2,4 +2,6 @@ function love.conf(t)
t.window.resizable = true t.window.resizable = true
t.window.title = "HorseHorse" t.window.title = "HorseHorse"
t.window.vsync = 0 t.window.vsync = 0
t.window.width = 800
t.window.height = 800
end end

326
main.lua
View File

@ -10,6 +10,9 @@ SWORDWIDTH = 3
SHIELDWIDTH = 16 SHIELDWIDTH = 16
SHIELDHEIGHT = 5 SHIELDHEIGHT = 5
MP_PORT = 13371
CHATLOG = {}
-- GAME STATES -- GAME STATES
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
@ -18,11 +21,12 @@ SHIELDHEIGHT = 5
function love.load() function love.load()
math.randomseed(os.time()) math.randomseed(os.time())
logMsg(nil, "Starting up...")
love.graphics.setDefaultFilter("nearest", "nearest") love.graphics.setDefaultFilter("nearest", "nearest")
a_ttf = love.graphics.newFont("art/font/alagard.ttf", nil, "none") a_ttf = love.graphics.newFont("art/font/alagard.ttf", nil, "none")
r_ttf = love.graphics.newFont("art/font/romulus.ttf", nil, "none") r_ttf = love.graphics.newFont("art/font/romulus.ttf", nil, "none")
camera = stalker() love.resize()
menu_load(makeMainMenu()) menu_load(makeMainMenu())
end end
@ -37,13 +41,16 @@ end
function love.draw() function love.draw()
camera:attach() camera:attach()
drawFunction() drawFunction()
drawLogMsgs()
camera:detach() camera:detach()
camera:draw() camera:draw()
end end
function love.resize() function love.resize()
camera = stalker() local width,height = love.window.getMode()
logMsg("[Window]", width .. "x" .. height)
newCamera()
end end
@ -80,7 +87,7 @@ function makeNetMenu()
{love.graphics.newText(a_ttf, "Join"), {love.graphics.newText(a_ttf, "Join"),
function () function ()
local addressBox = local addressBox =
TextBox:new(100, 100, 3, 99, "127.0.0.1", "Address/Host: ", TextBox:new(100, 100, 3, 99, "192.168.254.51", "Address/Host: ",
function (text) lobby_load(ClientLobby, text) end) function (text) lobby_load(ClientLobby, text) end)
addressBox:install() addressBox:install()
end}, end},
@ -91,9 +98,6 @@ function makeNetMenu()
end end
-- NET
----------------------------------------
-- GAME LOBBY -- GAME LOBBY
---------------------------------------- ----------------------------------------
function lobby_load(lobbyClass, arg) function lobby_load(lobbyClass, arg)
@ -339,9 +343,6 @@ function Game:initialize(lobbiests)
self.fighters = self.localFighters self.fighters = self.localFighters
camera:fade(.2, {0,0,0,0})
camera:setFollowLerp(0.1)
camera:setFollowStyle('TOPDOWN')
end end
@ -436,7 +437,7 @@ function Lobby:draw()
love.graphics.draw(love.graphics.newText(self.ttf, lobbiest.name), love.graphics.draw(love.graphics.newText(self.ttf, lobbiest.name),
rowX + SWORDLENGTH + 30, rowY, 0, self.scale) rowX + SWORDLENGTH + 30, rowY, 0, self.scale)
love.graphics.draw(love.graphics.newText(self.ttf, lobbiest.class.name), love.graphics.draw(love.graphics.newText(self.ttf, lobbiest.class.name),
rowX + 500, rowY, 0, self.scale) rowX + 550, rowY, 0, self.scale)
if (lobbiest.class.name == "LocalLobbiest") then if (lobbiest.class.name == "LocalLobbiest") then
local keymap = lobbiest.keymap local keymap = lobbiest.keymap
@ -444,18 +445,24 @@ function Lobby:draw()
.. keymap["flip"] .. " " .. keymap["right"] .. keymap["flip"] .. " " .. keymap["right"]
love.graphics.draw(love.graphics.newText(self.ttf, text), love.graphics.draw(love.graphics.newText(self.ttf, text),
rowX + 300, rowY + 5, 0, self.scale * (2/3)) rowX + 350, rowY + 5, 0, self.scale * (2/3))
end end
end end
local rowX = 470
local rowY = 500
love.graphics.draw(love.graphics.newText(self.ttf, "SPACE: Add player"), love.graphics.draw(love.graphics.newText(self.ttf, "SPACE: Add player"),
10, 460, 0, self.scale) rowX, rowY + (40 * 1), 0, self.scale)
love.graphics.draw(love.graphics.newText(self.ttf, "DELETE: Del player"),
rowX, rowY + (40 * 2), 0, self.scale)
rowY = 560
love.graphics.draw(love.graphics.newText(self.ttf, "LEFT: Edit name"), love.graphics.draw(love.graphics.newText(self.ttf, "LEFT: Edit name"),
10, 500, 0, self.scale) rowX, rowY + (40 * 2), 0, self.scale)
love.graphics.draw(love.graphics.newText(self.ttf, "RIGHT: Change sprite"), love.graphics.draw(love.graphics.newText(self.ttf, "RIGHT: Change sprite"),
10, 520, 0, self.scale) rowX, rowY + (40 * 3), 0, self.scale)
love.graphics.draw(love.graphics.newText(self.ttf, "ACCEL: Change sword"), love.graphics.draw(love.graphics.newText(self.ttf, "ACCEL: Change sword"),
10, 540, 0, self.scale) rowX, rowY + (40 * 4), 0, self.scale)
end end
@ -475,6 +482,17 @@ end
function Lobby:keypressed(key) function Lobby:keypressed(key)
if (key == "space" and self.localLobbiestsN < table.maxn(KEYMAPS)) then if (key == "space" and self.localLobbiestsN < table.maxn(KEYMAPS)) then
self:newLocalLobbiest() self:newLocalLobbiest()
elseif (key == "t") then
local chatbox = TextBox:new(10,770, 2, 99, nil, nil,
function (text)
self:sendChat(text)
self:install()
end)
chatbox:install(false, drawFunction, nil, false)
elseif (key == "escape") then
self:toMainMenu()
else else
for i,lobbiest in pairs(self.localLobbiests) do for i,lobbiest in pairs(self.localLobbiests) do
lobbiest:keypressed(key, self) lobbiest:keypressed(key, self)
@ -487,6 +505,21 @@ function Lobby:keyreleased(key)
end end
function Lobby:toMainMenu()
menu_load(makeMainMenu())
end
function Lobby:sendChat(message)
local author = "AGhost"
if (self.localLobbiestsN > 0) then
author = self.localLobbiests[1].name
end
logMsg(author, message)
return author,message
end
function Lobby:newLocalLobbiest() function Lobby:newLocalLobbiest()
local i = self.localLobbiestsN + 1 local i = self.localLobbiestsN + 1
self.localLobbiestsN = i self.localLobbiestsN = i
@ -520,6 +553,8 @@ function Lobby:localLobbiestTables()
end end
-- LOCAL LOBBY -- LOCAL LOBBY
---------------------------------------- ----------------------------------------
LocalLobby = class("LocalLobby", Lobby) LocalLobby = class("LocalLobby", Lobby)
@ -538,38 +573,111 @@ function LocalLobby:keypressed(key)
end end
-- NET - NET LOBBY
----------------------------------------
NetLobby = class("NetLobby", Lobby)
function NetLobby:initialize()
Lobby.initialize(self)
end
function NetLobby:install()
Lobby.install(self)
self:sendLobbiests()
end
function NetLobby:update(dt)
self.sock:update()
end
function NetLobby:keypressed(key)
Lobby.keypressed(self, key)
self:sendLobbiests()
end
function NetLobby:sockCallbacks()
self.sock:on("chat",
function (chatData, client)
self:chatReceived(chatData, client)
end)
self.sock:on("lobbiests",
function (localLobbiests, client)
self:receiveLobbiests(localLobbiests, client)
end)
end
function NetLobby:chatReceived(chatData, client)
logMsg(chatData["author"], chatData["text"])
end
-- NET - HOST LOBBY -- NET - HOST LOBBY
---------------------------------------- ----------------------------------------
HostLobby = class("HostLobby", Lobby) HostLobby = class("HostLobby", NetLobby)
function HostLobby:initialize() function HostLobby:initialize()
Lobby.initialize(self) NetLobby.initialize(self)
self.server = sock.newServer("*", 13371) self.sock = sock.newServer("*", MP_PORT)
self.server:setSerialization(bitser.dumps, bitser.loads) self.sock:setSerialization(bitser.dumps, bitser.loads)
self:sockCallbacks()
end
self.server:on("connect",
function HostLobby:sockCallbacks()
NetLobby.sockCallbacks(self)
self.sock:on("connect",
function (data, client) function (data, client)
print("GOD IS DEAD BUT THERE'S A CONNECTION") -- self:sendLobbiests()
end) end)
self.server:on("lobbiestsUpdate", self.sock:on("disconnect",
function (localLobbiests, client) function (data, client)
for i,v in pairs(localLobbiests) do self:removeLobbiestsOfClient(client)
print(v["name"])
end
self:updateLobbiests(localLobbiests, client)
end) end)
end end
function HostLobby:update(dt) function HostLobby:toMainMenu()
self.server:update() -- self.sock:destroy()
-- Lobby.toMainMenu(self)
end
function HostLobby:sendChat(message)
local author,text = Lobby.sendChat(self, message)
self.sock:sendToAll("chat", {["author"] = author, ["text"] = text})
end
function HostLobby:chatReceived(chatData, client)
NetLobby.chatReceived(self, chatData)
self.sock:sendToAllBut(client, "chat", chatData)
end end
function HostLobby:sendLobbiests() function HostLobby:sendLobbiests()
-- for i,v in pairs(localLobbiests) do for k,client in pairs(self.sock:getClients()) do
self.serverToAll:send("lobbiestsUpdate", self:localLobbiestTables()) client:send("lobbiests", self:lobbiestTables(client))
end
end
function HostLobby:receiveLobbiests(localLobbiestTables, client)
self:removeLobbiestsOfClient(client)
for k,lobbiestTable in pairs(localLobbiestTables) do
table.insert(self.remoteLobbiests,
ClientLobbiest:new(self, client, lobbiestTable))
self.remoteLobbiestsN = self.remoteLobbiestsN + 1
end
self:sendLobbiests()
end end
@ -579,57 +687,77 @@ function HostLobby:newLocalLobbiest()
end end
function HostLobby:updateLobbiests(localLobbiests, client) function HostLobby:removeLobbiestsOfClient(client)
local newRemotes = {} local lobbiests = {}
local n = 0
for k,lobbiest in pairs(self.remoteLobbiests) do for k,lobbiest in pairs(self.remoteLobbiests) do
if (lobbiest.client == client) then if not (lobbiest.client == client) then
self.remoteLobbiestsN = self.remoteLobbiestsN - 1 table.insert(lobbiests, lobbiest)
else n = n + 1
table.insert(newRemotes, lobbiest)
end end
end end
self.remoteLobbiests = lobbiests
self.remoteLobbiestsN = n
end
for k,lobbiest in pairs(localLobbiests) do
table.insert(newRemotes, ClientLobbiest:new(self, client, lobbiest)) function HostLobby:remoteLobbiestTables(client)
self.remoteLobbiestsN = self.remoteLobbiestsN + 1 local lobbiests = {}
table.foreach(self.remoteLobbiests,
function (k, lobbiest)
if not (lobbiest.client == client) then
table.insert(lobbiests, lobbiest:toTable())
end
end)
return lobbiests
end end
self.remoteLobbiests = newRemotes
function HostLobby:lobbiestTables(client)
local lobbiests = {}
table.foreach(self:localLobbiestTables(),
function(k, v) table.insert(lobbiests, v) end)
table.foreach(self:remoteLobbiestTables(client),
function(k, v) table.insert(lobbiests, v) end)
return lobbiests
end end
-- NET - CLIENT LOBBY -- NET - CLIENT LOBBY
---------------------------------------- ----------------------------------------
ClientLobby = class("ClientLobby", Lobby) ClientLobby = class("ClientLobby", NetLobby)
function ClientLobby:initialize(address) function ClientLobby:initialize(address)
Lobby.initialize(self) NetLobby.initialize(self)
self.status = "Connecting..." self.status = "Connecting..."
self.client = sock.newClient(address, 13371) self.sock = sock.newClient(address, MP_PORT)
self.client:setSerialization(bitser.dumps, bitser.loads) self.sock:setSerialization(bitser.dumps, bitser.loads)
self:sockCallbacks()
self.client:on("connect", self.sock:connect()
function (data) end
function ClientLobby:sockCallbacks()
NetLobby.sockCallbacks(self)
self.sock:on("connect",
function (ignoredData)
self.status = "Connected!" self.status = "Connected!"
self.client:send("lobbiestsUpdate", self:localLobbiestTables()) self.sock:send("lobbiests", self:localLobbiestTables())
end) end)
self.client:on("disconnect", self.sock:on("disconnect",
function (data) function (ignoredData)
self.status = "Disconnected" self.status = "Disconnected"
end) end)
self.client:on("lobbiestsUpdate",
function (lobbiests)
self.remoteLobbiests = lobbiests
end)
self.client:connect()
end end
function ClientLobby:update(dt) function ClientLobby:update(dt)
self.client:update() self.sock:update()
end end
@ -641,12 +769,37 @@ function ClientLobby:draw()
end end
function ClientLobby:updateLobbiests(localLobbiests) function ClientLobby:toMainMenu()
self.sock:disconnect()
Lobby.toMainMenu(self)
end
function ClientLobby:sendChat(message)
local author,text = Lobby.sendChat(self, message)
self.sock:send("chat", {["author"] = author, ["text"] = text})
end
function ClientLobby:sendLobbiests()
self.sock:send("lobbiests", self:localLobbiestTables())
end
function ClientLobby:receiveLobbiests(remoteLobbiestTables)
self.remoteLobbiests = {}
self.remoteLobbiestsN = 0
for i,lobbiestTable in pairs(remoteLobbiestTables) do
table.insert(self.remoteLobbiests, HostLobbiest:new(nil, lobbiestTable))
self.remoteLobbiestsN = self.remoteLobbiestsN + 1
end
end
function ClientLobby:newLocalLobbiest() function ClientLobby:newLocalLobbiest()
Lobby.newLocalLobbiest(self) Lobby.newLocalLobbiest(self)
self.client:send("lobbiestsUpdate", self:localLobbiestTables()) self:sendLobbiests()
end end
@ -727,8 +880,10 @@ end
---------------------------------------- ----------------------------------------
HostLobbiest = class("HostLobbiest", Lobbiest) HostLobbiest = class("HostLobbiest", Lobbiest)
function HostLobbiest:initialize(lobby) function HostLobbiest:initialize(lobby, lobbiestTable)
Lobbiest.initialize(self, lobby) self.name = lobbiestTable["name"]
self.swordType = lobbiestTable["swordType"]
self.character = lobbiestTable["character"]
end end
@ -825,8 +980,8 @@ function TextBox:initialize(x, y, scale, max, initialText, label, onEnter)
self.x,self.y = x,y self.x,self.y = x,y
self.scale = scale self.scale = scale
self.onEnter = onEnter self.onEnter = onEnter
self.text = initialText self.text = initialText or ""
self.label = label self.label = label or ""
self.max = max or 999 self.max = max or 999
self.ttf = r_ttf self.ttf = r_ttf
@ -854,7 +1009,6 @@ end
function TextBox:keypressed(key) function TextBox:keypressed(key)
print(key)
if (key == "return") then if (key == "return") then
self.onEnter(self.text) self.onEnter(self.text)
@ -874,6 +1028,35 @@ function TextBox:keyreleased(key)
end end
-- CHAT/LOGGING
--------------------------------------------------------------------------------
function logMsg(source, text)
local string = text
if not (source == nil) then
string = source .. ": " .. text
end
print(string)
table.remove(CHATLOG, 5)
table.insert(CHATLOG, 1, string)
end
function drawLogMsgs()
local x,y = 10,600
local offset_y = 30
local scale = 1.7
local chatCount = table.maxn(CHATLOG)
for i=1,chatCount do
local this_y = y + (offset_y * (chatCount - i))
love.graphics.draw(love.graphics.newText(a_ttf, CHATLOG[i]),
x, this_y, 0, scale, scale)
end
end
-- UTIL -- UTIL
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
-- Install the important 'hook' functions (draw, update, keypressed/released) -- Install the important 'hook' functions (draw, update, keypressed/released)
@ -915,6 +1098,18 @@ function hookInstall(newUpdate, newDraw, newPress, newRelease,
end end
function newCamera()
local width,height = love.window.getMode()
local scale = height / 800
logMsg("[Camera]", "Scale: " .. scale)
camera = stalker()
camera.scale = scale
camera:setFollowStyle('NO_DEADZONE')
camera:follow(400, 400)
end
-- MISC DATA -- MISC DATA
-------------------------------------------------------------------------------- --------------------------------------------------------------------------------
-- CHARACTERS -- CHARACTERS
@ -929,7 +1124,8 @@ CHARACTERS[3] = love.graphics.newImage("art/sprites/shark-unicorn.png")
-- DEFAULT NAMES -- DEFAULT NAMES
------------------------------------------ ------------------------------------------
NAMES = {"Ignucius", "Penguin", "Tux", "Puffy", "Doktoro", "Espero", "<3", "</3"} NAMES = {"Ignucius", "Splashers", "Penguin", "Tux", "Puffy", "Doktoro",
"Espero", "<3", "</3", "Blublub", "Hase-ian"}
-- LOCAL KEYMAPS -- LOCAL KEYMAPS
------------------------------------------ ------------------------------------------