Add level selector / leaderboard browser #7

Merged
Not merged 23 commits from browser into master 2022-09-06 10:08:42 +02:00
3 changed files with 44 additions and 47 deletions
Showing only changes of commit e453290419 - Show all commits

View File

@ -6,9 +6,11 @@ local modes = nil
local mode = 1 local mode = 1
local prefMode = nil local prefMode = nil
-- imported funcs -- Imported functions -------
local ZoneAct -- lb_common.lua
local TicsToTime local ZoneAct = lb_ZoneAct
local TicsToTime = lb_TicsToTime
-----------------------------
local function mapIndexOffset(n) local function mapIndexOffset(n)
return (mapIndex + n + #maps - 1) % #maps + 1 return (mapIndex + n + #maps - 1) % #maps + 1
@ -293,9 +295,6 @@ end
local function drawBrowser(v) local function drawBrowser(v)
if not leaderboard then return end if not leaderboard then return end
TicsToTime = $ or rawget(_G, "TicsToTime")
ZoneAct = $ or rawget(_G, "ZoneAct")
v.fadeScreen(0xFF00, 16) v.fadeScreen(0xFF00, 16)
-- previous, next maps -- previous, next maps

26
lb_common.lua Normal file
View File

@ -0,0 +1,26 @@
rawset(_G, "lb_TicsToTime", function(tics, pure)
if tics == 0 and pure then
return "-:--:--"
end
return string.format(
"%d:%02d:%02d",
G_TicsToMinutes(tics, true),
G_TicsToSeconds(tics),
G_TicsToCentiseconds(tics)
)
end)
rawset(_G, "lb_ZoneAct", function(map)
local z = ""
if map.zonttl != "" then
z = " " + map.zonttl
elseif not(map.levelflags & LF_NOZONE) then
z = " Zone"
end
if map.actnum != "" then
z = $ + " " + map.actnum
end
return z
end)

View File

@ -87,9 +87,18 @@ local clamp
local scroll_to local scroll_to
local ticsToTime
local allowJoin local allowJoin
-- Imported functions --
-- lb_common.lua
local ticsToTime = lb_TicsToTime
local zoneAct = lb_ZoneAct
-- browser.lua
local InitBrowser = InitBrowser
local DrawBrowser = DrawBrowser
local BrowserController = BrowserController
--------------- ---------------
-- cvars -- cvars
@ -398,8 +407,6 @@ local function exitlevel(player, ...)
end end
COM_AddCommand("exit", exitlevel) COM_AddCommand("exit", exitlevel)
local DrawBrowser
local BrowserController
local function initBrowser(player) local function initBrowser(player)
if not doyoudare(player) then return end if not doyoudare(player) then return end
@ -409,33 +416,18 @@ local function initBrowser(player)
return return
end end
if not rawget(_G, "DrawBrowser") then if not InitBrowser then
print("Browser is not loaded") print("Browser is not loaded")
return return
end end
rawget(_G, "InitBrowser")(lb) InitBrowser(lb)
drawState = DS_BROWSER drawState = DS_BROWSER
player.afkTime = leveltime player.afkTime = leveltime
end end
COM_AddCommand("levelselect", initBrowser) COM_AddCommand("levelselect", initBrowser)
local function zoneAct(map)
local z = ""
if map.zonttl != "" then
z = " " + map.zonttl
elseif not(map.levelflags & LF_NOZONE) then
z = " Zone"
end
if map.actnum != "" then
z = $ + " " + map.actnum
end
return z
end
rawset(_G, "ZoneAct", zoneAct)
local function findMap(player, ...) local function findMap(player, ...)
local search = ... local search = ...
@ -849,20 +841,6 @@ addHook("MapLoad", function()
end end
) )
function ticsToTime(tics, pure)
if tics == 0 and pure then
return "-:--:--"
end
return string.format(
"%d:%02d:%02d",
G_TicsToMinutes(tics, true),
G_TicsToSeconds(tics),
G_TicsToCentiseconds(tics)
)
end
rawset(_G, "TicsToTime", ticsToTime)
-- Item patches have the amazing property of being displaced 12x 13y pixels -- Item patches have the amazing property of being displaced 12x 13y pixels
local iXoffset = 13 * FRACUNIT local iXoffset = 13 * FRACUNIT
local iYoffset = 12 * FRACUNIT local iYoffset = 12 * FRACUNIT
@ -1144,9 +1122,6 @@ local function drawScrollTo(v, player, scoreTable, gui)
end end
local function drawBrowser(v, player) local function drawBrowser(v, player)
if not DrawBrowser then
DrawBrowser = rawget(_G, "DrawBrowser")
end
DrawBrowser(v, lb) DrawBrowser(v, lb)
end end
@ -1493,9 +1468,6 @@ local function think()
end end
end end
elseif drawState == DS_BROWSER then elseif drawState == DS_BROWSER then
if not BrowserController then
BrowserController = rawget(_G, "BrowserController")
end
if BrowserController(p) then if BrowserController(p) then
drawState = DS_DEFAULT drawState = DS_DEFAULT
end end