Compare commits
8 Commits
5fe7a6966a
...
compress-s
Author | SHA1 | Date | |
---|---|---|---|
0b2eb9e61d | |||
2d4784f62e | |||
6953f343dc | |||
dfecef7225 | |||
e03c9beecc | |||
e6aac8b7a1 | |||
dbf020e320 | |||
f0cb051564 |
34
browser.lua
34
browser.lua
@ -204,7 +204,7 @@ local function drawGamemode(v)
|
|||||||
end
|
end
|
||||||
|
|
||||||
if m & F_SPBEXP then
|
if m & F_SPBEXP then
|
||||||
local invp = v.cachePatch("K_ITINV"..(leveltime / 6 % 7 + 1))
|
local invp = v.cachePatch("K_ITINV"..(leveltime / 3 % 7 + 1))
|
||||||
v.drawScaled(
|
v.drawScaled(
|
||||||
modeX * FRACUNIT - scaledHalf + xoff,
|
modeX * FRACUNIT - scaledHalf + xoff,
|
||||||
modeY * FRACUNIT - scaledHalf,
|
modeY * FRACUNIT - scaledHalf,
|
||||||
@ -259,22 +259,25 @@ local function drawFlags(v, x, y, flags)
|
|||||||
nx = $ + margin
|
nx = $ + margin
|
||||||
end
|
end
|
||||||
if flags & F_SPBEXP then
|
if flags & F_SPBEXP then
|
||||||
local invp = v.cachePatch("K_ISINV"..(leveltime / 6 % 6 + 1))
|
local invp = v.cachePatch("K_ISINV"..(leveltime / 3 % 6 + 1))
|
||||||
v.drawScaled(nx, ny, scale, invp)
|
v.drawScaled(nx, ny, scale, invp)
|
||||||
nx = $ + margin
|
nx = $ + margin
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local MSK_SPEED = 0xF0
|
||||||
|
local MSK_WEIGHT = 0xF
|
||||||
|
|
||||||
local function drawStats(v, x, y, skin, stats)
|
local function drawStats(v, x, y, skin, stats)
|
||||||
local s = skins[skin]
|
local s = skins[skin]
|
||||||
if not (s
|
if stats
|
||||||
and s.kartspeed == stats["speed"]
|
and not (s
|
||||||
and s.kartweight == stats["weight"]
|
and s.kartspeed == (stats & MSK_SPEED) >> 4
|
||||||
)
|
and s.kartweight == stats & MSK_WEIGHT
|
||||||
and stats then
|
) then
|
||||||
v.drawString(x-2, y-2, stats["speed"], V_ALLOWLOWERCASE, "thin")
|
v.drawString(x-2, y-2, (stats & MSK_SPEED) >> 4, V_ALLOWLOWERCASE, "thin")
|
||||||
v.drawString(x + 13, y + 9, stats["weight"], V_ALLOWLOWERCASE, "thin")
|
v.drawString(x + 13, y + 9, stats & MSK_WEIGHT, V_ALLOWLOWERCASE, "thin")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -304,7 +307,7 @@ local colorFlags = {
|
|||||||
[0] = V_SKYMAP,
|
[0] = V_SKYMAP,
|
||||||
[1] = 0
|
[1] = 0
|
||||||
}
|
}
|
||||||
local function drawScore(v, i, pos, score)
|
local function drawScore(v, i, pos, score, highlight)
|
||||||
local y = scoresY + i * 18
|
local y = scoresY + i * 18
|
||||||
local textFlag = colorFlags[pos%2]
|
local textFlag = colorFlags[pos%2]
|
||||||
|
|
||||||
@ -316,6 +319,13 @@ local function drawScore(v, i, pos, score)
|
|||||||
local facerank = skin and v.cachePatch(skin.facerank) or v.cachePatch("M_NORANK")
|
local facerank = skin and v.cachePatch(skin.facerank) or v.cachePatch("M_NORANK")
|
||||||
v.draw(column[1], y, facerank, 0, v.getColormap("sonic", score["color"]))
|
v.draw(column[1], y, facerank, 0, v.getColormap("sonic", score["color"]))
|
||||||
|
|
||||||
|
-- chili
|
||||||
|
if highlight then
|
||||||
|
local chilip = v.cachePatch("K_CHILI"..leveltime/4%8+1)
|
||||||
|
v.draw(column[1], y, chilip)
|
||||||
|
textFlag = V_YELLOWMAP
|
||||||
|
end
|
||||||
|
|
||||||
-- stats
|
-- stats
|
||||||
drawStats(v, column[1], y, score["skin"], score["stat"])
|
drawStats(v, column[1], y, score["skin"], score["stat"])
|
||||||
-- name
|
-- name
|
||||||
@ -326,7 +336,7 @@ local function drawScore(v, i, pos, score)
|
|||||||
drawFlags(v, column[4], y, score["flags"])
|
drawFlags(v, column[4], y, score["flags"])
|
||||||
end
|
end
|
||||||
|
|
||||||
local function drawBrowser(v)
|
local function drawBrowser(v, player)
|
||||||
if not leaderboard then return end
|
if not leaderboard then return end
|
||||||
|
|
||||||
v.fadeScreen(0xFF00, 16)
|
v.fadeScreen(0xFF00, 16)
|
||||||
@ -358,7 +368,7 @@ local function drawBrowser(v)
|
|||||||
scrollPos = max(min(scrollPos, scores - 3), 1)
|
scrollPos = max(min(scrollPos, scores - 3), 1)
|
||||||
local endi = min(scrollPos + 7, scores)
|
local endi = min(scrollPos + 7, scores)
|
||||||
for i = scrollPos, endi do
|
for i = scrollPos, endi do
|
||||||
drawScore(v, i - scrollPos + 1, i, scoreTable[i])
|
drawScore(v, i - scrollPos + 1, i, scoreTable[i], scoreTable[i].name == player.name)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
rawset(_G, "DrawBrowser", drawBrowser)
|
rawset(_G, "DrawBrowser", drawBrowser)
|
||||||
|
144
leaderboard.lua
144
leaderboard.lua
@ -253,24 +253,36 @@ local function score_t(map, name, skin, color, time, splits, flags, stat)
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local MSK_SPEED = 0xF0
|
||||||
|
local MSK_WEIGHT = 0xF
|
||||||
|
|
||||||
local function stat_t(speed, weight)
|
local function stat_t(speed, weight)
|
||||||
if speed and weight then
|
if speed and weight then
|
||||||
return {
|
return (speed << 4) | weight
|
||||||
["speed"] = speed,
|
|
||||||
["weight"] = weight
|
|
||||||
}
|
|
||||||
end
|
end
|
||||||
return nil
|
return 0
|
||||||
end
|
end
|
||||||
|
|
||||||
local function stat_str(stat)
|
local function stat_str(stat)
|
||||||
if stat then
|
if stat then
|
||||||
return string.format("%d%d", stat["speed"], stat["weight"])
|
return string.format("%d%d", (stat & MSK_SPEED) >> 4, stat & MSK_WEIGHT)
|
||||||
end
|
end
|
||||||
|
|
||||||
return "0"
|
return "0"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function splits_from_str(splitstr)
|
||||||
|
local spl = {}
|
||||||
|
for str in splitstr:gmatch("([^ ]+)") do
|
||||||
|
table.insert(spl, tonumber(str))
|
||||||
|
end
|
||||||
|
return spl
|
||||||
|
end
|
||||||
|
|
||||||
|
local function splits_to_str(splits)
|
||||||
|
return table.concat(splits, " ")
|
||||||
|
end
|
||||||
|
|
||||||
-- Read the leaderboard
|
-- Read the leaderboard
|
||||||
local f = io.open(FILENAME, "r")
|
local f = io.open(FILENAME, "r")
|
||||||
if f then
|
if f then
|
||||||
@ -289,12 +301,7 @@ if f then
|
|||||||
|
|
||||||
scoreTable = getScoreTable(tonumber(t[1]), flags) or {}
|
scoreTable = getScoreTable(tonumber(t[1]), flags) or {}
|
||||||
|
|
||||||
local spl = {}
|
local spl = t[6] or ""
|
||||||
if t[6] != nil then
|
|
||||||
for str in t[6]:gmatch("([^ ]+)") do
|
|
||||||
table.insert(spl, tonumber(str))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
local stats = nil
|
local stats = nil
|
||||||
if t[8] != nil then
|
if t[8] != nil then
|
||||||
@ -863,7 +870,7 @@ local modePatches = {
|
|||||||
|
|
||||||
local function modePatch(flag)
|
local function modePatch(flag)
|
||||||
if flag == F_SPBEXP then
|
if flag == F_SPBEXP then
|
||||||
return PATCH[modePatches[flag]][(leveltime / 4) % 6]
|
return PATCH[modePatches[flag]][(leveltime / 3) % 6]
|
||||||
end
|
end
|
||||||
return PATCH[modePatches[flag]]
|
return PATCH[modePatches[flag]]
|
||||||
end
|
end
|
||||||
@ -987,11 +994,11 @@ local function drawScore(v, player, pos, x, y, gui, faceRank, score, drawPos, te
|
|||||||
local pskin = score["skin"] and skins[score["skin"]]
|
local pskin = score["skin"] and skins[score["skin"]]
|
||||||
if stat and not (
|
if stat and not (
|
||||||
pskin
|
pskin
|
||||||
and pskin.kartweight == stat["weight"]
|
and pskin.kartweight == stat & MSK_WEIGHT
|
||||||
and pskin.kartspeed == stat["speed"]
|
and pskin.kartspeed == (stat & MSK_SPEED) >> 4
|
||||||
) then
|
) then
|
||||||
v.drawString(x + FACERANK_DIM - 2, y + 4, stat["speed"], V_HUDTRANS | VFLAGS, "small")
|
v.drawString(x + FACERANK_DIM - 2, y + 4, (stat & MSK_SPEED) >> 4, V_HUDTRANS | VFLAGS, "small")
|
||||||
v.drawString(x + FACERANK_DIM - 2, y + 8, stat["weight"], V_HUDTRANS | VFLAGS, "small")
|
v.drawString(x + FACERANK_DIM - 2, y + 8, stat & MSK_WEIGHT, V_HUDTRANS | VFLAGS, "small")
|
||||||
end
|
end
|
||||||
|
|
||||||
if gui == GUI_ON or (gui == GUI_SPLITS and showSplit) then
|
if gui == GUI_ON or (gui == GUI_SPLITS and showSplit) then
|
||||||
@ -1028,8 +1035,9 @@ local function drawScore(v, player, pos, x, y, gui, faceRank, score, drawPos, te
|
|||||||
)
|
)
|
||||||
|
|
||||||
-- Draw splits
|
-- Draw splits
|
||||||
if showSplit and score["splits"] and score["splits"][prevLap] != nil then
|
local splts = splits_from_str(score["splits"])
|
||||||
local split = splits[prevLap] - score["splits"][prevLap]
|
if showSplit and splts and splts[prevLap] != nil then
|
||||||
|
local split = splits[prevLap] - splts[prevLap]
|
||||||
v.drawString(
|
v.drawString(
|
||||||
x + px + FACERANK_DIM,
|
x + px + FACERANK_DIM,
|
||||||
y + 8,
|
y + 8,
|
||||||
@ -1122,7 +1130,7 @@ local function drawScrollTo(v, player, scoreTable, gui)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function drawBrowser(v, player)
|
local function drawBrowser(v, player)
|
||||||
DrawBrowser(v, lb)
|
DrawBrowser(v, player)
|
||||||
end
|
end
|
||||||
|
|
||||||
local stateFunctions = {
|
local stateFunctions = {
|
||||||
@ -1221,9 +1229,45 @@ local function writeStats()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local function saveTime(player)
|
local function checkFlags(p)
|
||||||
|
local flags = 0
|
||||||
|
|
||||||
scoreTable = $ or {}
|
-- Encore
|
||||||
|
if encoremode then
|
||||||
|
flags = $ | F_ENCORE
|
||||||
|
end
|
||||||
|
|
||||||
|
if not cv_spbatk then
|
||||||
|
cv_spbatk = CV_FindVar("spbatk")
|
||||||
|
end
|
||||||
|
|
||||||
|
-- SPBAttack
|
||||||
|
if server.SPBArunning and cv_spbatk.value then
|
||||||
|
flags = $ | F_SPBATK
|
||||||
|
|
||||||
|
if server.SPBAexpert then
|
||||||
|
flags = $ | F_SPBEXP
|
||||||
|
end
|
||||||
|
if p.SPBAKARTBIG then
|
||||||
|
flags = $ | F_SPBBIG
|
||||||
|
end
|
||||||
|
if p.SPBAjustice then
|
||||||
|
flags = $ | F_SPBJUS
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return flags
|
||||||
|
end
|
||||||
|
|
||||||
|
local function saveTime(player)
|
||||||
|
-- Disqualify if the flags changed mid trial.
|
||||||
|
if checkFlags(player) != Flags then
|
||||||
|
print("Game mode change detected! Time has been disqualified.")
|
||||||
|
S_StartSound(nil, 110)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
scoreTable = $ or {}
|
||||||
|
|
||||||
local pskin = skins[player.mo.skin]
|
local pskin = skins[player.mo.skin]
|
||||||
local newscore = score_t(
|
local newscore = score_t(
|
||||||
@ -1232,7 +1276,7 @@ local function saveTime(player)
|
|||||||
player.mo.skin,
|
player.mo.skin,
|
||||||
player.skincolor,
|
player.skincolor,
|
||||||
timeFinished,
|
timeFinished,
|
||||||
splits,
|
splits_to_str(splits),
|
||||||
Flags,
|
Flags,
|
||||||
stat_t(player.HMRs or pskin.kartspeed, player.HMRw or pskin.kartweight)
|
stat_t(player.HMRs or pskin.kartspeed, player.HMRw or pskin.kartweight)
|
||||||
)
|
)
|
||||||
@ -1294,7 +1338,7 @@ local function saveTime(player)
|
|||||||
score["skin"], "\t",
|
score["skin"], "\t",
|
||||||
score["color"], "\t",
|
score["color"], "\t",
|
||||||
score["time"], "\t",
|
score["time"], "\t",
|
||||||
table.concat(score["splits"], " "), "\t",
|
score["splits"], "\t",
|
||||||
score["flags"], "\t",
|
score["flags"], "\t",
|
||||||
stat_str(score["stat"]), "\n"
|
stat_str(score["stat"]), "\n"
|
||||||
)
|
)
|
||||||
@ -1387,13 +1431,7 @@ local function think()
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- Autospec
|
-- Autospec
|
||||||
-- Encore
|
|
||||||
if leveltime == 1 then
|
if leveltime == 1 then
|
||||||
Flags = $ & !F_ENCORE
|
|
||||||
if encoremode then
|
|
||||||
Flags = $ | F_ENCORE
|
|
||||||
end
|
|
||||||
|
|
||||||
if p then
|
if p then
|
||||||
for s in players.iterate do
|
for s in players.iterate do
|
||||||
if s.valid and s.spectator then
|
if s.valid and s.spectator then
|
||||||
@ -1402,49 +1440,29 @@ local function think()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if not cv_spbatk then
|
|
||||||
cv_spbatk = CV_FindVar("spbatk")
|
|
||||||
end
|
|
||||||
|
|
||||||
-- Gamemode flags
|
if leveltime > START_TIME - (3 * TICRATE) / 2 then
|
||||||
Flags = $ & !(F_SPBATK | F_SPBEXP | F_SPBBIG | F_SPBJUS)
|
|
||||||
if server.SPBArunning
|
|
||||||
and cv_spbatk.value
|
|
||||||
and leveltime > START_TIME - (3 * TICRATE) / 2 then
|
|
||||||
Flags = $ | F_SPBATK
|
|
||||||
if server.SPBAexpert then
|
|
||||||
Flags = $ | F_SPBEXP
|
|
||||||
end
|
|
||||||
if clearcheats then
|
if clearcheats then
|
||||||
clearcheats = false
|
clearcheats = false
|
||||||
for q in players.iterate do
|
if p then
|
||||||
q.SPBAKARTBIG = false
|
p.SPBAKARTBIG = false
|
||||||
q.SPBAjustice = false
|
p.SPBAjustice = false
|
||||||
q.SPBAshutup = false
|
p.SPBAshutup = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if p then
|
Flags = checkFlags(p)
|
||||||
if p.SPBAKARTBIG then
|
|
||||||
Flags = $ | F_SPBBIG
|
|
||||||
end
|
|
||||||
if p.SPBAjustice then
|
|
||||||
Flags = $ | F_SPBJUS
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
-- make sure the spb actually spawned
|
-- make sure the spb actually spawned
|
||||||
if leveltime == START_TIME - 1 then
|
if server.SPBArunning and leveltime == START_TIME - 1 then
|
||||||
if not (server.SPBAbomb and server.SPBAbomb.valid) then
|
if not (server.SPBAbomb and server.SPBAbomb.valid) then
|
||||||
-- it didn't spawn, clear spb flags
|
-- it didn't spawn, clear spb flags
|
||||||
Flags = $ & !(F_SPBATK | F_SPBEXP | F_SPBBIG | F_SPBJUS)
|
Flags = $ & !(F_SPBATK | F_SPBEXP | F_SPBBIG | F_SPBJUS)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
else
|
else
|
||||||
hud.enable("freeplay")
|
hud.enable("freeplay")
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
scoreTable = getScoreTable(gamemap, Flags)
|
scoreTable = getScoreTable(gamemap, Flags)
|
||||||
@ -1454,6 +1472,12 @@ local function think()
|
|||||||
end
|
end
|
||||||
|
|
||||||
if p then
|
if p then
|
||||||
|
-- must be done before browser control
|
||||||
|
if p.laps >= mapheaderinfo[gamemap].numlaps and timeFinished == 0 then
|
||||||
|
timeFinished = p.realtime
|
||||||
|
saveTime(p)
|
||||||
|
end
|
||||||
|
|
||||||
-- Scroll controller
|
-- Scroll controller
|
||||||
-- Spectators can't input buttons so let the gamer do it
|
-- Spectators can't input buttons so let the gamer do it
|
||||||
if drawState == DS_SCROLL then
|
if drawState == DS_SCROLL then
|
||||||
@ -1478,7 +1502,7 @@ local function think()
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- disable spba hud
|
-- disable spba hud
|
||||||
if server.SPBAdone then
|
if server.SPBArunning and server.SPBAdone then
|
||||||
server.SPBArunning = false
|
server.SPBArunning = false
|
||||||
p.pflags = $ & !(PF_TIMEOVER)
|
p.pflags = $ & !(PF_TIMEOVER)
|
||||||
p.exiting = 100
|
p.exiting = 100
|
||||||
@ -1509,10 +1533,6 @@ local function think()
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if p.laps >= mapheaderinfo[gamemap].numlaps and timeFinished == 0 then
|
|
||||||
timeFinished = p.realtime
|
|
||||||
saveTime(p)
|
|
||||||
end
|
|
||||||
regLap(p)
|
regLap(p)
|
||||||
elseif cv_teamchange.value == 0 then
|
elseif cv_teamchange.value == 0 then
|
||||||
allowJoin(true)
|
allowJoin(true)
|
||||||
|
Reference in New Issue
Block a user