Compare commits

..

No commits in common. "cd4af324df4cf2c4e94990919305a7e55f9a9b68" and "7f9551583c2a11ed55575d8aa36fd253fba184f5" have entirely different histories.

11 changed files with 28 additions and 97 deletions

View file

@ -20,7 +20,11 @@ Fully open sourced and maintained by the community (me 😞).
> You can find all modules **[here](https://github.com/JonnyBro/beatrun/tree/main/lua/bin)**.\ > You can find all modules **[here](https://github.com/JonnyBro/beatrun/tree/main/lua/bin)**.\
> Check **[Credits](#credits)** section for their source code. > Check **[Credits](#credits)** section for their source code.
## Automatic Installation (Recommended | Windows 10/11) ## Steam Workshop (lmao)
[Subscribe](https://steamcommunity.com/sharedfiles/filedetails/?id=3290421288)
### Automatic Installation (Recommended | Windows 10/11)
> [!WARNING] > [!WARNING]
> Windows 7 is not supported.\ > Windows 7 is not supported.\
@ -36,7 +40,7 @@ irm https://beatrun.jonnybro.ru/install | iex
* Select the `Beatrun` gamemode in right lower corner. * Select the `Beatrun` gamemode in right lower corner.
## Manual Installation ### Manual Installation
1. **[Download this repository](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip)**. 1. **[Download this repository](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip)**.
2. **Delete the `beatrun` folder in *your_game_folder/garrysmod/addons* if you have one.** 2. **Delete the `beatrun` folder in *your_game_folder/garrysmod/addons* if you have one.**

View file

@ -20,7 +20,11 @@
> Все модули можно найти **[здесь](https://github.com/JonnyBro/beatrun/tree/main/lua/bin)**.\ > Все модули можно найти **[здесь](https://github.com/JonnyBro/beatrun/tree/main/lua/bin)**.\
> Проверьте **[Благодарности](#благодарности)** чтобы найти исходный код модулей. > Проверьте **[Благодарности](#благодарности)** чтобы найти исходный код модулей.
## Автоматическая установка (Рекомендуемое | Windows 10/11) ## Steam Workshop (ржака)
[Подписаться](https://steamcommunity.com/sharedfiles/filedetails/?id=3290421288)
### Автоматическая установка (Рекомендуемое | Windows 10/11)
> [!WARNING] > [!WARNING]
> Windows 7 не поддерживается.\ > Windows 7 не поддерживается.\
@ -36,7 +40,7 @@ irm https://beatrun.jonnybro.ru/install | iex
* Выберите режим `Beatrun` в правом нижнем углу. * Выберите режим `Beatrun` в правом нижнем углу.
## Ручная установка ### Ручная установка
1. **[Скачайте проект](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip)**. 1. **[Скачайте проект](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip)**.
2. **Удалите папку `beatrun` по пути *путь_к_игре/garrysmod/addons* если присутствует.** 2. **Удалите папку `beatrun` по пути *путь_к_игре/garrysmod/addons* если присутствует.**

View file

@ -63,7 +63,6 @@ beatrun.coursesdatabase.update1=You are trying to update a course with this code
# Tools Menu # Tools Menu
beatrun.toolsmenu.client=Client beatrun.toolsmenu.client=Client
beatrun.toolsmenu.server=Server beatrun.toolsmenu.server=Server
beatrun.toolsmenu.extra=Extra
# Tools Menu Courses Section # Tools Menu Courses Section
beatrun.toolsmenu.courses.name=Courses beatrun.toolsmenu.courses.name=Courses
@ -230,16 +229,6 @@ beatrun.toolsmenu.gamemodes.infectiontime=Time in seconds
beatrun.toolsmenu.gamemodes.datatheft=Toggle Data Theft Gamemode beatrun.toolsmenu.gamemodes.datatheft=Toggle Data Theft Gamemode
beatrun.toolsmenu.gamemodes.deathmatch=Toggle Deathmatch Gamemode beatrun.toolsmenu.gamemodes.deathmatch=Toggle Deathmatch Gamemode
# Tools Menu Extra Section
beatrun.toolsmenu.extra.name=Extra
beatrun.toolsmenu.extra.desc=Extra settings for speedrunners/sweaty boys
beatrun.toolsmenu.extra.stats=Extra Stats
beatrun.toolsmenu.extra.statsdesc=Shows extra stats besides speedometer to provide more info to help on harder tricks
beatrun.toolsmenu.extra.speedrunsverif=Speedrun Verification Stats
beatrun.toolsmenu.extra.speedrunsverifdesc=Shows info about your current settings (Purist Mode, Purist wallrun and Kick Glitch version)
# Checkpoints # Checkpoints
beatrun.checkpoints.countdown1=Ready beatrun.checkpoints.countdown1=Ready
beatrun.checkpoints.countdown2=Set beatrun.checkpoints.countdown2=Set

View file

@ -63,7 +63,6 @@ beatrun.coursesdatabase.update1=Вы пытаетесь обновить кур
# Tools Menu # Tools Menu
beatrun.toolsmenu.client=Клиент beatrun.toolsmenu.client=Клиент
beatrun.toolsmenu.server=Сервер beatrun.toolsmenu.server=Сервер
beatrun.toolsmenu.extra=Дополнительно
# Tools Menu Courses Section # Tools Menu Courses Section
beatrun.toolsmenu.courses.name=Курсы beatrun.toolsmenu.courses.name=Курсы
@ -227,16 +226,6 @@ beatrun.toolsmenu.gamemodes.infectiontime=Время в секундах
beatrun.toolsmenu.gamemodes.datatheft=Переключить Data Theft beatrun.toolsmenu.gamemodes.datatheft=Переключить Data Theft
beatrun.toolsmenu.gamemodes.deathmatch=Переключить Deathmatch beatrun.toolsmenu.gamemodes.deathmatch=Переключить Deathmatch
# Tools Menu Extra Section
beatrun.toolsmenu.extra.name=Дополнительно
beatrun.toolsmenu.extra.desc=Доп. настройки для спидранеров/потеющих ребяток
beatrun.toolsmenu.extra.stats=Доп. статы
beatrun.toolsmenu.extra.statsdesc=Показывает дополнительные статы рядом со спидометром
beatrun.toolsmenu.extra.speedrunsverif=Статы для верификации спидранов
beatrun.toolsmenu.extra.speedrunsverifdesc=Показывает ваши настройки в углу экрана (Purist Mode, Purist wallrun и версия Kick Glitch)
# Checkpoints # Checkpoints
beatrun.checkpoints.countdown1=Раз beatrun.checkpoints.countdown1=Раз
beatrun.checkpoints.countdown2=Два beatrun.checkpoints.countdown2=Два

View file

@ -99,8 +99,6 @@ function SWEP:Deploy()
self:SetWasOnGround(false) self:SetWasOnGround(false)
self:SetBlockAnims(false) self:SetBlockAnims(false)
self:SetPunch(1) self:SetPunch(1)
return true
end end
function SWEP:Initialize() function SWEP:Initialize()

View file

@ -1,4 +1,5 @@
if not util.IsBinaryModuleInstalled("gdiscord") then return end if not util.IsBinaryModuleInstalled("gdiscord") then return end
require("gdiscord") require("gdiscord")
local image = "default" local image = "default"
@ -8,6 +9,7 @@ local discord_start = discord_start or -1
function DiscordUpdate() function DiscordUpdate()
local ply = LocalPlayer() local ply = LocalPlayer()
if not ply.GetLevel then return end if not ply.GetLevel then return end
local rpc_data = {} local rpc_data = {}
@ -24,6 +26,7 @@ function DiscordUpdate()
rpc_data["state"] = "Local Server" rpc_data["state"] = "Local Server"
end end
else else
-- rpc_data["state"] = string.Replace(ip, ":27015", "")
rpc_data["state"] = "Dedicated Server" rpc_data["state"] = "Dedicated Server"
end end
end end
@ -38,10 +41,13 @@ function DiscordUpdate()
local level = ply:GetLevel() local level = ply:GetLevel()
local customname = hook.Run("BeatrunHUDCourse") local customname = hook.Run("BeatrunHUDCourse")
local course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay" local course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay"
rpc_data["details"] = "Level: " .. level .. " | Map: " .. game.GetMap() rpc_data["details"] = "Level: " .. level .. " | Map: " .. game.GetMap()
rpc_data["startTimestamp"] = discord_start rpc_data["startTimestamp"] = discord_start
rpc_data["largeImageKey"] = image rpc_data["largeImageKey"] = image
rpc_data["largeImageText"] = course rpc_data["largeImageText"] = course
DiscordUpdateRPC(rpc_data) DiscordUpdateRPC(rpc_data)
end end

View file

@ -1,8 +1,7 @@
local show_total_xp = CreateClientConVar("Beatrun_HUDXP", "1", true, false, language.GetPhrase("beatrun.convars.hudxp"), 0, 1) local showtotalXP = CreateClientConVar("Beatrun_HUDXP", "1", true, false, language.GetPhrase("beatrun.convars.hudxp"), 0, 1)
local sway = CreateClientConVar("Beatrun_HUDSway", "1", true, false, language.GetPhrase("beatrun.convars.hudsway"), 0, 1) local sway = CreateClientConVar("Beatrun_HUDSway", "1", true, false, language.GetPhrase("beatrun.convars.hudsway"), 0, 1)
local dynamic = CreateClientConVar("Beatrun_HUDDynamic", "0", true, false, language.GetPhrase("beatrun.convars.huddynamic"), 0, 1) local dynamic = CreateClientConVar("Beatrun_HUDDynamic", "0", true, false, language.GetPhrase("beatrun.convars.huddynamic"), 0, 1)
local hidden = CreateClientConVar("Beatrun_HUDHidden", "0", true, false, language.GetPhrase("beatrun.convars.hudhidden"), 0, 2) local hidden = CreateClientConVar("Beatrun_HUDHidden", "0", true, false, language.GetPhrase("beatrun.convars.hudhidden"), 0, 2)
local verificationstats = CreateClientConVar("Beatrun_HUDVerification", "0", true, false, "", 0, 1)
-- local reticle = CreateClientConVar("Beatrun_HUDReticle", "1", true, false, language.GetPhrase("beatrun.convars.hudreticle"), 0, 1) -- local reticle = CreateClientConVar("Beatrun_HUDReticle", "1", true, false, language.GetPhrase("beatrun.convars.hudreticle"), 0, 1)
CreateClientConVar("Beatrun_HUDTextColor", "255 255 255 255", true, true, language.GetPhrase("beatrun.convars.hudtextcolor")) CreateClientConVar("Beatrun_HUDTextColor", "255 255 255 255", true, true, language.GetPhrase("beatrun.convars.hudtextcolor"))
@ -176,7 +175,7 @@ local function BeatrunHUD()
-- local lastxp = ply.LastXP or 0 -- local lastxp = ply.LastXP or 0
local nicktext = nil local nicktext = nil
if show_total_xp:GetBool() then if showtotalXP:GetBool() then
nicktext = ply:Nick() .. " | " .. ply:GetXP() .. "XP" nicktext = ply:Nick() .. " | " .. ply:GetXP() .. "XP"
else else
nicktext = ply:Nick() nicktext = ply:Nick()
@ -227,18 +226,6 @@ local function BeatrunHUD()
surface.SetTextPos(scrw * 0.015 + vp.z, scrh * 0.9 + vp.x) surface.SetTextPos(scrw * 0.015 + vp.z, scrh * 0.9 + vp.x)
surface.DrawText(language.GetPhrase("beatrun.hud.lvl"):format(ply:GetLevel())) surface.DrawText(language.GetPhrase("beatrun.hud.lvl"):format(ply:GetLevel()))
if verificationstats:GetBool() then
surface.SetTextPos(scrw * 0.015 + vp.z, scrh * 0.02 + vp.x)
surface.DrawText("Purist: ")
surface.DrawText(LocalPlayer():GetInfo("Beatrun_PuristMode") == "1" and "true" or "false")
surface.SetTextPos(scrw * 0.015 + vp.z, scrh * 0.04 + vp.x)
surface.DrawText("Purist Wallrun: ")
surface.DrawText(LocalPlayer():GetInfo("Beatrun_PuristWallrun") == "1" and "true" or "false")
surface.SetTextPos(scrw * 0.015 + vp.z, scrh * 0.06 + vp.x)
surface.DrawText("Kick Glitch: ")
surface.DrawText(LocalPlayer():GetInfo("Beatrun_OldKickGlitch") == "1" and "Old" or "New")
end
if tobool(LocalPlayer():GetInfo("Beatrun_PuristMode")) then if tobool(LocalPlayer():GetInfo("Beatrun_PuristMode")) then
surface.SetDrawColor(230, 230, 230) surface.SetDrawColor(230, 230, 230)
surface.SetMaterial(MELogo) surface.SetMaterial(MELogo)

View file

@ -1,4 +1,5 @@
if not util.IsBinaryModuleInstalled("steamrichpresencer") then return end if not util.IsBinaryModuleInstalled("steamrichpresencer") then return end
require("steamrichpresencer") require("steamrichpresencer")
local richtext = "" local richtext = ""
@ -6,21 +7,25 @@ local refresh_time = 60
local function UpdateRichPresence() local function UpdateRichPresence()
local ply = LocalPlayer() local ply = LocalPlayer()
if not ply.GetLevel then return end if not ply.GetLevel then return end
local map = game.GetMap() local map = game.GetMap()
local level = ply:GetLevel() local level = ply:GetLevel()
local customname = hook.Run("BeatrunHUDCourse") local customname = hook.Run("BeatrunHUDCourse")
local course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay" local course = customname and customname or Course_Name ~= "" and Course_Name or "Freeplay"
local updatedtext = "Beatrun Lv. " .. level .. " (" .. map .. ") | " .. course local updatedtext = "Beatrun Lv. " .. level .. " (" .. map .. ") | " .. course
if richtext ~= updatedtext then if richtext ~= updatedtext then
richtext = updatedtext richtext = updatedtext
steamworks.SetRichPresence("generic", richtext) steamworks.SetRichPresence("generic", richtext)
end end
end end
hook.Add("OnGamemodeLoaded", "LoadDLL", function() hook.Add("OnGamemodeLoaded", "LoadDLL", function()
UpdateRichPresence() UpdateRichPresence()
timer.Create("UpdateSteamRichPresence", refresh_time, 0, UpdateRichPresence) timer.Create("UpdateSteamRichPresence", refresh_time, 0, UpdateRichPresence)
end) end)

View file

@ -7,7 +7,6 @@ end
hook.Add("AddToolMenuCategories", "Beatrun_Category", function() hook.Add("AddToolMenuCategories", "Beatrun_Category", function()
spawnmenu.AddToolCategory("Beatrun", "Client", language.GetPhrase("beatrun.toolsmenu.client")) spawnmenu.AddToolCategory("Beatrun", "Client", language.GetPhrase("beatrun.toolsmenu.client"))
spawnmenu.AddToolCategory("Beatrun", "Server", language.GetPhrase("beatrun.toolsmenu.server")) spawnmenu.AddToolCategory("Beatrun", "Server", language.GetPhrase("beatrun.toolsmenu.server"))
spawnmenu.AddToolCategory("Beatrun", "Extra", language.GetPhrase("beatrun.toolsmenu.extra"))
end) end)
hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function() hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
@ -414,15 +413,4 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
-- end -- end
-- panel:AddItem(LoadoutMenuButton) -- panel:AddItem(LoadoutMenuButton)
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Extra", "beatrun_extra", "#beatrun.toolsmenu.extra.name", "", "", function(panel)
panel:ClearControls()
panel:SetName("#beatrun.toolsmenu.extra.desc")
panel:CheckBox("#beatrun.toolsmenu.extra.stats", "Beatrun_HUDStats")
panel:ControlHelp("#beatrun.toolsmenu.extra.statsdesc")
panel:CheckBox("#beatrun.toolsmenu.extra.speedrunsverif", "Beatrun_HUDVerification")
panel:ControlHelp("#beatrun.toolsmenu.extra.speedrunsverifdesc")
end)
end) end)

View file

@ -19,7 +19,6 @@ local timecolor = color_neutral
if CLIENT then if CLIENT then
CreateClientConVar("Beatrun_ShowSpeedometer", 1, true, true, language.GetPhrase("#beatrun.convars.showspeedometer"), 0, 1) CreateClientConVar("Beatrun_ShowSpeedometer", 1, true, true, language.GetPhrase("#beatrun.convars.showspeedometer"), 0, 1)
CreateClientConVar("Beatrun_HUDStats", "0", true, false, "", 0, 1)
end end
if SERVER then if SERVER then
@ -265,44 +264,6 @@ function CourseHUD()
surface.SetTextColor(r, g, b, a) surface.SetTextColor(r, g, b, a)
surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.85 + vpz) surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.85 + vpz)
surface.DrawText(text) surface.DrawText(text)
if GetConVar("Beatrun_HUDStats"):GetBool() then
local ang1 = ply:GetAimVector()
ang1 = math.Round(ang1:Angle()[2] % 90, 0)
surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.88 + vpz)
surface.DrawText(ang1)
surface.SetTextPos(ScrW() * 0.87 - w * 0.5 + vpx, ScrH() * 0.88 + vpz)
surface.DrawText("Angle")
surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.90 + vpz)
surface.DrawText(ply:GetWallrun())
surface.SetTextPos(ScrW() * 0.87 - w * 0.5 + vpx, ScrH() * 0.90 + vpz)
surface.DrawText("Wall stat")
if ply:UsingRH() then
surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.92 + vpz)
surface.DrawText(tostring(ply:GetActiveWeapon():GetQuakeJumping()))
surface.SetTextPos(ScrW() * 0.89 - w * 0.5 + vpx, ScrH() * 0.92 + vpz)
surface.DrawText("Quake")
end
surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.94 + vpz)
if (ply:GetWallrunTime() - CurTime()) < 0 then
surface.DrawText("0.00")
else
surface.DrawText(tostring(math.Round(ply:GetWallrunTime() - CurTime(), 2)))
end
surface.SetTextPos(ScrW() * 0.89 - w * 0.5 + vpx, ScrH() * 0.94 + vpz)
surface.DrawText("Wallrun Time Remains")
surface.SetTextPos(ScrW() * 0.85 - w * 0.5 + vpx, ScrH() * 0.96 + vpz)
surface.DrawText(tostring(CurTime() < ply:GetWallrunTime()))
surface.SetTextPos(ScrW() * 0.89 - w * 0.5 + vpx, ScrH() * 0.96 + vpz)
surface.DrawText("Wallrunning")
end
end end
if incourse and pbtimes then if incourse and pbtimes then

View file

@ -1,4 +1,4 @@
VERSIONGLOBAL = "v1.0.4" VERSIONGLOBAL = "v1.0.1"
DeriveGamemode("sandbox") DeriveGamemode("sandbox")