Merge branch 'JonnyBro:main' into master

This commit is contained in:
Салават Таиров 2023-11-08 14:10:26 +05:00 committed by GitHub
commit 132d57c349
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
120 changed files with 1512 additions and 681 deletions

View file

@ -0,0 +1,29 @@
# ENGLISH
# Animations Installer Source Code
Here you can find source code of the animations installer.\
I don't know why you will ever need that but we put it here so you can be sure we don't supply malware with our fork.
## How To Use
Please refer to this [README](../beatrun/README.md).
## Credits
* [YuRaNnNzZZ](https://github.com/YuRaNnNzZZ) - Creator of this installer.
# RUSSIAN
# Исходный код установщика анимаций
Здесь находятся исходники нашего установщика анимаций.\
Я не знаю зачем это вам, но мы оставили их здесь чтобы вы могли убедиться что мы не распространяем вирусы в нашем форке.
## Как использовать
Прочитайте этот файл [README](../beatrun/README.md).
## Благодарность
* [YuRaNnNzZZ](https://github.com/YuRaNnNzZZ) - Создатель установщика.

122
README.md
View file

@ -1,75 +1,95 @@
# Beatrun | Community version # Beatrun | Community edition
Infamous parkour addon for Garry's Mod, fully open sourced and maintained by the community. * [Русский](./README_ru.md)
This version does not include malicious modules, code or networking. What it does contain is: Infamous parkour addon for Garry's Mod, fully open sourced and maintained by the community (me 😞).
* Lua modules for Discord Rich Presence
* Lua modules for Steam Presence
* Network connectivity for courses (activates only when you load or upload courses, and by default `courses.beatrun.ru` is used)
**All of this is optional and you may remove all of it. (modules are located [here](https://github.com/JonnyBro/beatrun/blob/master/lua/bin/) and online courses functionality is [here](https://github.com/JonnyBro/beatrun/blob/master/beatrun/gamemodes/beatrun/gamemode/cl/OnlineCourse.lua))** > [!IMPORTANT]
> You will not find here any malicious modules, code or networking! We have modules and networking for:
>
> * Discord Rich Presence.
> * Steam Presence.
> * Custom Courses Database.
>
> **All of this is optional and you can remove all of it.**\
> Modules are located [here](https://github.com/JonnyBro/beatrun/tree/main/lua/bin) and courses database functionality is [here](https://github.com/JonnyBro/beatrun/blob/main/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua).\
> You can find source code for modules in [Credits](#credits) section.
# Installation (Manual) **PLEASE READ EVERYTHING BEFORE ASKING QUESTIONS ON OUR SERVER!**
1. Download this repository [here](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip).
2. Delete the `beatrun` folder in *addons* if you have one! ## Automatic Installation (Recommended | Windows only)
3. Extract the `beatrun` folder to *your_game_folder/garrysmod/addons*.
4. Extract the `lua` folder to *your_game_folder/garrysmod*. Run the command below in Powershell.
* `lua` folder contains modules for Discord Rich Presense and Steam Presence. They are optional. You can find their source code in the [credits](https://github.com/JonnyBro/beatrun?tab=readme-ov-file#credits-3) section<br><br> > [!NOTE]
> Win + R > `powershell`
# Installation (Automatic | Windows only)
Run the command below in the Powershell. (Win + R --> powershell --> the command below)
```powershell ```powershell
iex (iwr "beatrun.ru/install.ps1" -UseBasicParsing) iex (iwr "rlxx.ru/beatrun" -UseBasicParsing)
``` ```
## Manual Installation
1. Download this repository [here](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.**
3. Extract the `beatrun-main/beatrun` folder to *your_game_folder/garrysmod/addons*.
4. Extract the `beatrun-main/lua` folder to *your_game_folder/garrysmod*.
## Animations ## Animations
You can use "**Beatrun Animations Installer**" for custom animations. Currently there's:
* Beatrun Reanimated
* Fixed Original<br><br>
Start the executable and press a key on your keyboard with the number of the animation you want to install (if nothing's changed, run the program as admin).<br> Please refer to this [README](beatrun/README.md).
Installer's source can be found [here](/BeatrunAnimInstaller).
## Changes and fixes done by me ## Changes
* Created a [custom online courses database](https://courses.beatrun.ru), which is also free and [open source](https://github.com/relaxtakenotes/beatrun-courses-server/) 🤯!
* Added a new gamemode - *Deathmatch*, it's like Data Theft, but you collect kills not cubes! > [!IMPORTANT]
* Added an in-game config menu - You can find it in the tool menu, in the *Beatrun* Category!\ > There are many undocumented changes and fixes in this version, you better look at the commits for more specific changes.
All of the settings below can be changed in the configuration menu.
* Added the ability Getting off of ladders. * Jonny_Bro is hosting [custom online courses database](https://courses.beatrun.ru), which is also free and [open source](https://github.com/relaxtakenotes/beatrun-courses-server/) 🤯!
* Allowed jumping while slowwalking. * Implemented a new gamemode - **Deathmatch** (it's way more fun than Data Theft I promise).
* Done various tweaks to the Time Trials Menu (F4). * Implemented "Proper" Kick Glitch just like in [original ME](https://www.youtube.com/watch?v=zK5y3NBUStc).
* Added an in-game config menu - you can find it in the tool menu, in the *Beatrun* Category.\
**All** of the Beatrun settings can be changed in the configuration menu.
* Localization support.\
For now Russian and English are supported.
* Added the ability to get off of ladders.
* Added an arrow that shows the next checkpoint. * Added an arrow that shows the next checkpoint.
* Added a convar to allow Overdrive usage on the server - `Beatrun_AllowOverdriveInMultiplayer`. * Added a ConVar to allow Overdrive usage on the server - `Beatrun_AllowOverdriveInMultiplayer`.
* Added a convar to toggle between old and new (like in ME) Kick-Glitch - `Beatrun_OldKickGlitch`. * Added a ConVar to toggle between old and new Kick Glitch - `Beatrun_OldKickGlitch`.
* Added convars to change HUD's colors - `Beatrun_HUDTextColor`, `Beatrun_HUDCornerColor`, `Beatrun_HUDFloatingXPColor`. * Added some ConVars to change HUD colors - `Beatrun_HUDTextColor`, `Beatrun_HUDCornerColor`, `Beatrun_HUDFloatingXPColor`.
* Added a convar to allow players to spawn props without admin rights - `Beatrun_AllowPropSpawn`. * Added a ConVar to allow players to spawn props and weapons without admin rights - `Beatrun_AllowPropSpawn`.
* Added a convar to disable grapple ability - `Beatrun_DisableGrapple`. * Added a ConVar to disable grapple ability - `Beatrun_DisableGrapple`.
* Implemented Discord Rich Presence using open source tools (See step 3). * Added a ConVar to allow QuickTurn with any weapon or only with *Runner Hands* - `Beatrun_QuickturnHandsOnly`.
* Added small camera punch when diving. * Added small camera punch when diving.
* Added the ability to remove ziplines that created with *Zipline Gun* - RMB. * Added the ability to remove ziplines that created with *Zipline Gun* - `RMB`.
* SteamID in the right corner is no longer present. * Implemented Discord Rich Presence using [open source](#credits) module.
## Notable changes and fixes done by the community ## Fixes
* Made QuickTurn work only with `Runner Hands`.
* Your SteamID in the right corner is no longer present.
* Fixed some playermodels show up as ERROR.
* Done various tweaks to the Courses Menu (F4).
* Allowed jumping while walking (🤷).
* Fixed leaderboard sorting in gamemodes. * Fixed leaderboard sorting in gamemodes.
* Fixed grapple usage in courses and gamemodes. * Fixed grapple usage in courses and gamemodes.
* Fixed a crash in DataTheft when touching data bank. * Fixed a crash in Data Theft when touching Data Bank.
* Fixed an error on course load. * Fixed an error on course loading.
* Fixed collisions issues. (you getting stuck in walls for no reason or player to player damage not going through in gamemodes other than datatheft) * Fixed collisions issues. (PvP damage not going through in gamemodes other than Data Theft)
* Added Proper Kick Glitch ([Like in original ME](https://www.youtube.com/watch?v=zK5y3NBUStc)). (cry about prediction errors l0l)
* Tweaked safety roll, now you can roll under things. * Tweaked safety roll, now you can roll under things.
* Tweaked some grapple related stuff. Now it moves with the entity it was attached to and other players can see the rope.
* Made it possible to dive to your death =). * Made it possible to dive to your death =).
* Added some grapple related stuff. Now it moves with the entity it was attached to and other players can see the rope.
## TODO ## TODO
- [ ] Gamemodes menu.
# Related * [ ] Loadouts creation menu for Data Theft and Deathmatch. (idk how to properly implement this for know).
* [beatrun-anims](https://github.com/JonnyBro/beatrun-anims) - Decompiled beatrun animations.
# Credits <3 ## Related
* All contributors.
* [MTB](https://www.youtube.com/@MTB396) - Beatrun Reanimated project. * [Beatrun Reanimated Project](https://github.com/JonnyBro/beatrun-anims).
## Credits
* [All contributors](https://github.com/JonnyBro/beatrun/graphs/contributors) - <3.
* [EarthyKiller127](https://www.youtube.com/channel/UCiFqPwGo4x0J65xafIaECDQ) - He made that piece of shit.
* [relaxtakenotes](https://github.com/relaxtakenotes) - Made all of this possible.
* [MTB](https://www.youtube.com/@MTB396) - Beatrun Reanimated Project.
* [Discord Rich Presence](https://github.com/fluffy-servers/gmod-discord-rpc) by Fluffy Servers. * [Discord Rich Presence](https://github.com/fluffy-servers/gmod-discord-rpc) by Fluffy Servers.
* [Steam Presence](https://github.com/YuRaNnNzZZ/gmcl_steamrichpresencer) by YuRaNnNzZZ. * [Steam Presence](https://github.com/YuRaNnNzZZ/gmcl_steamrichpresencer) by YuRaNnNzZZ.
* [earthykiller](https://www.youtube.com/channel/UCiFqPwGo4x0J65xafIaECDQ) - He made that piece of shit code.

95
README_ru.md Normal file
View file

@ -0,0 +1,95 @@
# Beatrun | Версия от сообщества
* [English](./README.md)
Печально известный паркур-аддон для Garry's Mod, с полностью открытым исходным кодом и поддерживаемый сообществом (мной 😞).
> [!IMPORTANT]
> У нас вы не найдёте вредоносного кода, модулей или сетевого кода! У нас есть модули и сетевой код, который используется для:
>
> * Discord Rich Presence.
> * Steam Presence.
> * Пользовательская онлайн база курсов.
>
> **Всё это необязательно и может быть удалено.**\
> Модули находятся [тут](https://github.com/JonnyBro/beatrun/tree/main/lua/bin) и функционал онлайн базы курсов доступен [здесь](https://github.com/JonnyBro/beatrun/blob/main/beatrun/gamemodes/beatrun/gamemode/cl/CoursesDatabase.lua).\
> Исходный код модулей можно найти в [благодарностях](#благодарности).
**ПОЖАЛУЙСТА, ПРОЧТИТЕ ВЕСЬ ДОКУМЕНТ ПЕРЕД ТЕМ КАК ЗАДАВАТЬ ВОПРОСЫ НА НАШЕМ СЕРВЕРЕ!**
## Автоматическая установка (Рекомендуемое | только для Windows)
Запустите команду ниже в Powershell.
> [!NOTE]
> Win + R > `powershell`
```powershell
iex (iwr "rlxx.ru/beatrun" -UseBasicParsing)
```
## Ручная установка
1. Скачайте данный репозиторий по данной [ссылке](https://github.com/JonnyBro/beatrun/archive/refs/heads/master.zip).
2. **Удалите старую папку `beatrun` по пути *путь_к_игре/garrysmod/addons* если она у вас имеется.**
3. Извлеките папку `beatrun-main/beatrun` по пути *путь_к_игре/garrysmod/addons*.
4. Извлеките папку `beatrun-main/lua` по пути *путь_к_игре/garrysmod*.
## Анимации
Пожалуйста, обратитесь к данному [README](beatrun/README.md).
## Изменения
> [!IMPORTANT]
> Множество изменений и исправлений не задокументированы, обратитесь к списку коммитов для более подробного списка изменений.
* Jonny_Bro держит [пользовательскую онлайн базу курсов](https://courses.beatrun.ru), которая так же бесплатна и имеет [открытый исходный код](https://github.com/relaxtakenotes/beatrun-courses-server/) 🤯!
* Реализован новый режим - **Deathmatch** (намного веселее чем Data Theft, честно).
* Реализован "правильный" Kick Glitch прямо как в [оригинальной ME](https://www.youtube.com/watch?v=zK5y3NBUStc).
* Добавлено меню настроек в игре - его можно найти в списке инструментов, в категории *Beatrun*.\
Вам доступны **все** настройки Beatrun из данного меню.
* Поддержка локализации.\
На данный момент доступны Русский и Английский языки.
* Добавлена возможность слезания с лестниц.
* Добавлена стрелка указывающая на следующую контрольную точку.
* Добавлена переменная которая разрешает использование Overdrive на сервере - `Beatrun_AllowOverdriveInMultiplayer`.
* Добавлена переменная которая позволяет переключится между старым и новым Kick Glitch - `Beatrun_OldKickGlitch`.
* Добавлено несколько переменных позволяющих настроить цвета HUD - `Beatrun_HUDTextColor`, `Beatrun_HUDCornerColor`, `Beatrun_HUDFloatingXPColor`.
* Добавлена переменная которая разрешает игрокам без админ прав создавать пропы и оружие - `Beatrun_AllowPropSpawn`.
* Добавлена переменная которая позволяет переключить работу крюка-кошки - `Beatrun_DisableGrapple`.
* Добавлена переменная которая позволяет переключить использование Quickturn только с *Runner Hands* или с любым оружием - `Beatrun_QuickturnHandsOnly`.
* Добавлен небольшой толчёк камеры при нырянии.
* Добавлена возможность удаления зиплайнов созданных *Zipline Gun* - `ПКМ`.
* Реализована поддержка Discord Rich Presence используя модуль с [открытым исходным кодом](#благодарности).
## Исправления
* Ваш SteamID больше не показывается в углу экрана.
* Исправлено отображение некоторых моделей игрока как ERROR.
* Сделано несколько изменений в меню выбора курсов (F4).
* Разрешены прыжки во время ходьбы (🤷).
* Исправлена сортировка в таблице лидеров.
* Исправлено использование крюка-кошки в режимах и курсах.
* Исправлен краш при соприкосновении с Data Bank в Data Theft.
* Исправлена ошибка загрузки курсов.
* Исправлены ошибки коллизий. (PvP урон не проходил нигде, кроме Data Theft)
* Изменён кувырок, теперь можно кувыркаться под объектами.
* Изменена крюк-кошка. Теперь вы движетесь вместе с объектом к которому она прицеплена и её видят другие игроки.
* Теперь можно нырнуть до смерти =).
## TODO
* [ ] Меню выбора снаряжения для Data Theft и Deathmatch (не знаю пока как это реализовать).
## Может быть полезно
* [Beatrun Reanimated Project](https://github.com/JonnyBro/beatrun-anims).
## Благодарности
* [Все участники](https://github.com/JonnyBro/beatrun/graphs/contributors) - <3.
* [EarthyKiller127](https://www.youtube.com/channel/UCiFqPwGo4x0J65xafIaECDQ) - Создатель этого куска дерьма.
* [relaxtakenotes](https://github.com/relaxtakenotes) - Если бы не он, этого проекта бы не существовало.
* [MTB](https://www.youtube.com/@MTB396) - Создатель Beatrun Reanimated Project.
* [Discord Rich Presence](https://github.com/fluffy-servers/gmod-discord-rpc) от Fluffy Servers.
* [Steam Presence](https://github.com/YuRaNnNzZZ/gmcl_steamrichpresencer) от YuRaNnNzZZ.

39
beatrun/README.md Normal file
View file

@ -0,0 +1,39 @@
# ENGLISH
# Animations Installer
You can use **BeatrunAnimInstaller** (located literally here) to change animations. Currently we have:
1. `Beatrun Reanimated Project` animations.
2. Original but fixed animations.
## How To Use
1. Start the executable.
2. Press a key on your keyboard with the number of the animation you want to install.
> [!NOTE]
> If nothing is changed, close the game and/or try run the program with admin priveleges.
## Source Code
Please refer to this [README](../BeatrunAnimInstaller_Source/README.md).
# RUSSIAN
# Установщик анимаций
Используйте **BeatrunAnimInstaller** (который расположен прямо тут) чтобы менять анимации. На данный момент у нас имеются:
1. Анимации из `Beatrun Reanimated Project`.
2. Оригинальные анимации с правками и фиксами.
## Как использовать
1. Запустите исполняемый файл.
2. Нажмите цифру желаемых анимаций на клавиатуре.
> [!NOTE]
> Если ничего не изменилось, закройте игру и/или запустите файл от имени администратора.
## Исходный код
Прочитайте этот файл [README](../BeatrunAnimInstaller_Source/README.md).

View file

@ -3,5 +3,6 @@
"base" "base" "base" "base"
"title" "Beatrun" "title" "Beatrun"
"maps" "^br_" "maps" "^br_"
"category" "other"
"menusystem" "1" "menusystem" "1"
} }

View file

@ -0,0 +1,238 @@
# Misc
beatrun.misc.ok=OK
beatrun.misc.noclipdetected=Noclip Detected! Respawn to restart the course
beatrun.misc.checkconsole=Check console!
# AddonWarning
beatrun.addonwarning.warntext=NOTICE\nPlease disable the following addons before playing\nor submitting any issues to GitHub:
beatrun.addonwarning.quitbutton=Quit to Main Menu
beatrun.addonwarning.play=Play
beatrun.addonwarning.conflictfound=CONFLICTING ADDONS FOUND
# BuildModeHUD
beatrun.buildmodehud.info=Index: %s\nSelected: %s\nAngle: %s
beatrun.buildmodehud.props=Menu / Props
beatrun.buildmodehud.entities=Menu / Entities
beatrun.buildmodehud.drag=Drag (G)
beatrun.buildmodehud.copy=Copy (SHIFT+D)
beatrun.buildmodehud.delete=Delete (DEL/BCKSPC)
beatrun.buildmodehud.highlight=Highlight (T)
beatrun.buildmodehud.select=Select
beatrun.buildmodehud.zipline=Zipline (SHIFT = 2-Way)
# All ConVars
beatrun.convars.hudxp=Show total XP near nickname
beatrun.convars.hudsway=Display HUD swaying
beatrun.convars.huddynamic=Hide HUD when moving
beatrun.convars.hudhidden=Hides most of the HUD
beatrun.convars.hudreticle=Display a reticle
beatrun.convars.hudtextcolor=HUD Text Color\nDefault: 255 255 255 255
beatrun.convars.hudcornercolor=HUD Corner Color\nDefault: 20 20 20 100
beatrun.convars.hudfloatxpcolor=HUD Floating XP Color\nDefault: 255 255 255 255
beatrun.convars.nametags=Display nametags above players
beatrun.convars.apikey=API key
beatrun.convars.domain=Domain of the courses database
beatrun.convars.viewbob=Viewbob Intensity
beatrun.convars.viewbobstabilization=Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered
beatrun.convars.fov=Changes player's Field Of View
beatrun.convars.cpsave=Respawning during a course will go back to the last hit checkpoint
beatrun.convars.faststart=Faster start countdown
beatrun.convars.disablegrapple=Disables grapple ability
beatrun.convars.puristmode=Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how ME games handle this.\n0 = No restrictions\n1 = Reduced move speed in the air
beatrun.convars.quickturnground=Enables quickturning with secondary attack while on the ground
beatrun.convars.quickturnhandsonly=Enables quickturning with "Runner Hands" only
# HUD
beatrun.hud.course=Course: %s
beatrun.hud.freeplay=Freeplay
beatrun.hud.lvl=Lvl: %s
beatrun.hud.infector=Infector
# Menu_Course
beatrun.coursemenu.trials=Courses - %s
beatrun.coursemenu.buildmode=Toggle Build Mode
beatrun.coursemenu.freeplay=Return to Freeplay
# CoursesDatabase
beatrun.coursesdatabase.cantuploadfreeplay=Can't upload in Freeplay
beatrun.coursesdatabase.upload1=You're trying to upload a course with the name %s on map %s.
beatrun.coursesdatabase.upload2=Use Beatrun_Confirm to continue or Beatrun_Cancel to cancel.
beatrun.coursesdatabase.update1=You are trying to update a course with this code %s to course with name %s on map %s.
# Tools Menu
beatrun.toolsmenu.client=Client
beatrun.toolsmenu.server=Server
# Tools Menu Courses Section
beatrun.toolsmenu.courses.name=Courses
beatrun.toolsmenu.courses.desc=Courses Settings
beatrun.toolsmenu.courses.faststart=Fast Start
beatrun.toolsmenu.courses.faststartdesc=Faster countdown at the start of the course
beatrun.toolsmenu.courses.checkpointsave=Save at Checkpoint
beatrun.toolsmenu.courses.checkpointsavedesc=Respawn at last hit checkpoint in courses
beatrun.toolsmenu.courses.database=Database Domain
beatrun.toolsmenu.courses.databasedesc=Domain/IP of the database\nDefault: courses.beatrun.ru
beatrun.toolsmenu.courses.changeapikey=Change API Key
beatrun.toolsmenu.courses.enterapikey=Enter your API key
beatrun.toolsmenu.courses.savecourse=Save Currently Running Course to a File
beatrun.toolsmenu.courses.namesavecourse=Enter a name for your course
beatrun.toolsmenu.courses.loadcourse=Load a Course from the Online Database
beatrun.toolsmenu.courses.enterloadcourse=Enter course code
beatrun.toolsmenu.courses.uploadcourse=Upload Currently Running Course to the Database
beatrun.toolsmenu.courses.updatecourse=Update a Course on the Database
beatrun.toolsmenu.courses.updatecoursehelp=Updates a course on the database with the currently running one
# Tools Menu HUD Section
beatrun.toolsmenu.hud.name=HUD
beatrun.toolsmenu.hud.desc=HUD Settings
beatrun.toolsmenu.hud.dynamic=Dynamic HUD
beatrun.toolsmenu.hud.dynamicdesc=Hides HUD when moving
beatrun.toolsmenu.hud.sway=HUD Sway
beatrun.toolsmenu.hud.swaydesc=Toggles HUD swaying
beatrun.toolsmenu.hud.reticle=Show Reticle
beatrun.toolsmenu.hud.reticledesc=Shows a dot in the center of the screen
beatrun.toolsmenu.hud.nametags=Show Nametags
beatrun.toolsmenu.hud.nametagsdesc=Toggles nametags above players
beatrun.toolsmenu.hud.hudxp=Show HUD XP
beatrun.toolsmenu.hud.hudxpdesc=Show total XP near your nickname
beatrun.toolsmenu.hud.wind=Wind Effect
beatrun.toolsmenu.hud.winddesc=Wind noises when running
beatrun.toolsmenu.hud.fov=FOV
beatrun.toolsmenu.hud.fovdesc=You need to respawn after changing your FOV!
beatrun.toolsmenu.hud.hidden=Hide HUD
beatrun.toolsmenu.hud.hiddendesc=0 - Shown\n1 - Gamemode only\n2 - Hidden
beatrun.toolsmenu.hud.textcolor=HUD Text Color
beatrun.toolsmenu.hud.cornercolor=HUD Corner Color
beatrun.toolsmenu.hud.floatxpcolor=HUD Floating XP Color
# Tools Menu Viewbob Section
beatrun.toolsmenu.viewbob.name=Viewbob
beatrun.toolsmenu.viewbob.desc=Viewbob Settings
beatrun.toolsmenu.viewbob.stabilization=Viewbob Stabilization
beatrun.toolsmenu.viewbob.stabilizationdesc=Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered
beatrun.toolsmenu.viewbob.intensity=Viewbob Intensity
# Tools Menu Gameplay Section
beatrun.toolsmenu.gameplay.name=Gameplay
beatrun.toolsmenu.gameplay.desc=Gameplay Settings
beatrun.toolsmenu.gameplay.quickturnground=Quickturn Ground
beatrun.toolsmenu.gameplay.quickturngrounddesc=Enables quickturning with secondary attack while on the ground
beatrun.toolsmenu.gameplay.quickturnhandsonly=Quickturn Hands Only
beatrun.toolsmenu.gameplay.quickturnhandsonlydesc=Enables quickturning with "Runner Hands" only
beatrun.toolsmenu.gameplay.puristmode=Purist Mode
beatrun.toolsmenu.gameplay.puristmodedesc=Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how Mirror's Edge games handle this.\nDisabled = No restrictions\nEnabled = Reduced move speed in the air
beatrun.toolsmenu.gameplay.disablegrapple=Disable Grapple Ability
beatrun.toolsmenu.gameplay.disablegrappledesc=Disables grapple ability
# Tools Menu Misc Section
beatrun.toolsmenu.misc.name=Misc
beatrun.toolsmenu.misc.desc=Misc Settings
beatrun.toolsmenu.misc.propspawn=Prop Spawning
beatrun.toolsmenu.misc.propspawndesc=Allows players without admin rights to spawn props, entities and weapons
beatrun.toolsmenu.misc.overdrivemp=Overdrive in Multiplayer
beatrun.toolsmenu.misc.overdrivempdesc=Allows Overdrive usage on the server
# Tools Menu Moves Section
beatrun.toolsmenu.moves.name=Moves
beatrun.toolsmenu.moves.desc=Moves Settings
beatrun.toolsmenu.moves.help=You Can Dive with Ctrl + RMB While Midair!\nOverdrive Toggles with E + LMB.
beatrun.toolsmenu.moves.speedlimit=Speed Limit
beatrun.toolsmenu.moves.speedlimitdesc=Changes player's speed limit\nDefault: 325
beatrun.toolsmenu.moves.forcepuristmode=Force Purist Mode
beatrun.toolsmenu.moves.forcepuristmodedesc=Forces Purist Mode to be enabled for all players
beatrun.toolsmenu.moves.realisticwallrunning="Realistic" wallrunning
beatrun.toolsmenu.moves.realisticwallrunningdesc=You don't lose speed when starting wallrunning when disabled
beatrun.toolsmenu.moves.kickglitch=Kick Glitch
beatrun.toolsmenu.moves.kickglitchdesc=Toggles Kick Glitch Move\nLMB when Wallrunning and Then Jumping Right After
beatrun.toolsmenu.moves.kickglitchversion=Kick Glitch Version
beatrun.toolsmenu.moves.kickglitchversiondesc=Enabled - Old version\nDisabled - New version\nNew version uses mechanic from ME that spawns a small platform under a player
beatrun.toolsmenu.moves.quakejump=Quake Jump
beatrun.toolsmenu.moves.quakejumpdesc=Toggles Quake Jump Move\nPress Jump Right After Side Step
beatrun.toolsmenu.moves.sidestep=Side Step
beatrun.toolsmenu.moves.sidestepdesc=Toggles Side Step Move\nA/D + RMB
beatrun.toolsmenu.moves.disarm=Disarm
beatrun.toolsmenu.moves.disarmdesc=Toggles Ability to Disarm NPC\nPress USE on an NPC
beatrun.toolsmenu.moves.divesettings=Dive Settings
beatrun.toolsmenu.moves.totsugeki=Totsugeki
beatrun.toolsmenu.moves.totsugekidesc=Toggles Totsugeki Move\nDive Right After Quake Jump
beatrun.toolsmenu.moves.totsugekispam=Totsugeki Spam
beatrun.toolsmenu.moves.totsugekispamdesc=Toggles Ability to Spam Totsugeki
beatrun.toolsmenu.moves.totsugekiheading=Totsugeki Heading
beatrun.toolsmenu.moves.totsugekiheadingdesc=Allows to Totsugeki on X axis (up/down)
beatrun.toolsmenu.moves.totsugekidirection=Totsugeki Direction
beatrun.toolsmenu.moves.totsugekidirectiondesc=Allows to Totsugeki into Another Direction\nCombined with Spam and Heading Allows You to Fly =)
# Tools Menu Gamemodes Section
beatrun.toolsmenu.gamemodes.name=Gamemodes
beatrun.toolsmenu.gamemodes.desc=Gamemodes Settings
beatrun.toolsmenu.gamemodes.error=Another gamemode is running!
beatrun.toolsmenu.gamemodes.infection=Toggle Infection Gamemode
beatrun.toolsmenu.gamemodes.infectionstarttime=Time before starting
beatrun.toolsmenu.gamemodes.infectiongametime=Length of the game
beatrun.toolsmenu.gamemodes.infectiontime=Time in seconds
beatrun.toolsmenu.gamemodes.datatheft=Toggle Data Theft Gamemode
beatrun.toolsmenu.gamemodes.deathmatch=Toggle Deathmatch Gamemode
# Checkpoints
beatrun.checkpoints.countdown1=Ready
beatrun.checkpoints.countdown2=Set
beatrun.checkpoints.countdown3=GO!
beatrun.checkpoints.speedometer=%s km/h
# DataTheft
beatrun.datatheft.name=Data Theft (%s)
beatrun.datatheft.start=Data Theft! Kill players to collect data, deposit data in banks
# Deathmatch
beatrun.deathmatch.name=Deathmatch
beatrun.deathmatch.start=Deathmatch! Kill players to get points!
# Infection
beatrun.infection.name=Infection
beatrun.infection.infectedtext=(Infected)
beatrun.infection.humantext=(Human)
beatrun.infection.start=Infection! Touch other players to infect them\n%s player(s) will become infected in %ss
beatrun.infection.nosurvivors=None...
beatrun.infection.infected=was infected!
beatrun.infection.infectedby=has infected
beatrun.infection.award=You were awarded 200 XP for surviving!
beatrun.infection.awardinfected=You were awarded 100 XP for spawning as an infected!
beatrun.infection.end=The game has ended!\nSurvivors: %s\nRestarting in 15s

View file

@ -0,0 +1,238 @@
# Misc
beatrun.misc.ok=Ок
beatrun.misc.noclipdetected=Обнаружен NoClip! Нажмите R чтобы начать заного
beatrun.misc.checkconsole=Проверьте консоль!
# AddonWarning
beatrun.addonwarning.warntext=ВНИМАНИЕ\nПожалуйста, отключите данные аддоны перед игрой\nили созданием сообщений на GitHub:
beatrun.addonwarning.quitbutton=Выйти в меню
beatrun.addonwarning.play=Играть
beatrun.addonwarning.conflictfound=НЕСОВМЕСТИМЫЕ АДДОНЫ ОБНАРУЖЕНЫ
# BuildModeHUD
beatrun.buildmodehud.info=Указатель: %s\nВыбрано: %s\nУгол: %s
beatrun.buildmodehud.props=Меню / Пропы
beatrun.buildmodehud.entities=Меню / Энтити
beatrun.buildmodehud.drag=Переместить (G)
beatrun.buildmodehud.copy=Копировать (SHIFT+D)
beatrun.buildmodehud.delete=Удалить (DEL/BCKSPC)
beatrun.buildmodehud.highlight=Подсветить (T)
beatrun.buildmodehud.select=Выбрать
beatrun.buildmodehud.zipline=Зиплайн (SHIFT = двухсторонний)
# All ConVars
beatrun.convars.hudxp=Показать весь опыт рядом с ником
beatrun.convars.hudsway=Отображать покачивание HUD
beatrun.convars.huddynamic=Скрыть HUD при движении
beatrun.convars.hudhidden=Скрыть HUD
beatrun.convars.hudreticle=Показать точку
beatrun.convars.hudtextcolor=Цвет текста в HUD\nDefault: 255 255 255 255
beatrun.convars.hudcornercolor=Цвет края в HUD\nDefault: 20 20 20 100
beatrun.convars.hudfloatxpcolor=Цвет всплывающего XP в HUD\nDefault: 255 255 255 255
beatrun.convars.nametags=Показать ники над игроками
beatrun.convars.apikey=API ключ
beatrun.convars.domain=Домен онлайн базы курсов
beatrun.convars.viewbob=Интенсивность покачивания камеры
beatrun.convars.viewbobstabilization=Включите чтобы снизить покачивание камеры центрируя её
beatrun.convars.fov=Угол обзора игрока
beatrun.convars.cpsave=Респавн в курсах отправляет на последнюю контрольную точку
beatrun.convars.faststart=Быстрый отчёт в начале курса
beatrun.convars.disablegrapple=Переключить крюк-кошку
beatrun.convars.puristmode=Режим Purist это клиентский параметр который сильно снижает движение игрока в стороны будучи в воздухе, прямо как в оригинальное ME.\n0 = Нет ограничений\n1 = Снижает движение игрока в воздухе в стороны
beatrun.convars.quickturnground=Переключить Quickturn будучи на земле
beatrun.convars.quickturnhandsonly=Переключить Quickturn только с "Runner Hands"
# HUD
beatrun.hud.course=Курс: %s
beatrun.hud.freeplay=Свободная игра
beatrun.hud.lvl=Лвл: %s
beatrun.hud.infector=Заражённый
# Menu_Course
beatrun.coursemenu.trials=Курсы - %s
beatrun.coursemenu.buildmode=Режим строительства
beatrun.coursemenu.freeplay=Свободная игра
# CoursesDatabase
beatrun.coursesdatabase.cantuploadfreeplay=Нельзя загружать во время свободной игры
beatrun.coursesdatabase.upload1=Вы пытаетесь загрузить курс с названием %s на карте %s.
beatrun.coursesdatabase.upload2=Используйте Beatrun_Confirm чтобы продолжить или Beatrun_Cancel чтобы отменить.
beatrun.coursesdatabase.update1=Вы пытаетесь обновить курс с кодом %s на курс с названием %s на карте %s.
# Tools Menu
beatrun.toolsmenu.client=Клиент
beatrun.toolsmenu.server=Сервер
# Tools Menu Courses Section
beatrun.toolsmenu.courses.name=Курсы
beatrun.toolsmenu.courses.desc=Настройки курсов
beatrun.toolsmenu.courses.faststart=Быстрый старт
beatrun.toolsmenu.courses.faststartdesc=Быстрый отчёт в начале курса
beatrun.toolsmenu.courses.checkpointsave=Сохранение на Контр. точках
beatrun.toolsmenu.courses.checkpointsavedesc=Респавн на последней контрольной точке
beatrun.toolsmenu.courses.database=Домен Базы
beatrun.toolsmenu.courses.databasedesc=Домен/IP онлайн базы курсов\nПо умолчанию: courses.beatrun.ru
beatrun.toolsmenu.courses.changeapikey=Изменить API Ключ
beatrun.toolsmenu.courses.enterapikey=Введите ваш API ключ
beatrun.toolsmenu.courses.savecourse=Сохранить Текущий Курс в Файл
beatrun.toolsmenu.courses.namesavecourse=Введите название для курса
beatrun.toolsmenu.courses.loadcourse=Загрузить Курс из Базы
beatrun.toolsmenu.courses.enterloadcourse=Введите код курса
beatrun.toolsmenu.courses.uploadcourse=Опубликовать Текущий Курс в Базу курсов
beatrun.toolsmenu.courses.updatecourse=Обновить курс в Базе
beatrun.toolsmenu.courses.updatecoursehelp=Обновляет курс в базе по коду на текущий
# Tools Menu HUD Section
beatrun.toolsmenu.hud.name=HUD
beatrun.toolsmenu.hud.desc=Настройки HUD
beatrun.toolsmenu.hud.dynamic=Динамический HUD
beatrun.toolsmenu.hud.dynamicdesc=Прячет HUD во время движения
beatrun.toolsmenu.hud.sway=Покачивание HUD
beatrun.toolsmenu.hud.swaydesc=Покачивает HUD при разнообразных действиях
beatrun.toolsmenu.hud.reticle=Показать Точку
beatrun.toolsmenu.hud.reticledesc=Показывает точку по середине экрана
beatrun.toolsmenu.hud.nametags=Показать Ники
beatrun.toolsmenu.hud.nametagsdesc=Показывает ники над игроками
beatrun.toolsmenu.hud.hudxp=Показать XP в HUD
beatrun.toolsmenu.hud.hudxpdesc=Показывает весь XP в HUD
beatrun.toolsmenu.hud.wind=Эффект Ветра
beatrun.toolsmenu.hud.winddesc=Шум ветра во время бега
beatrun.toolsmenu.hud.fov=Угол Обзора
beatrun.toolsmenu.hud.fovdesc=Вам нужно сделать респавн после изменения FOV!
beatrun.toolsmenu.hud.hidden=Скрыть HUD
beatrun.toolsmenu.hud.hiddendesc=0 - Показать\n1 - Только режим\n2 - Скрыть полностью
beatrun.toolsmenu.hud.textcolor=Цвет Текста в HUD
beatrun.toolsmenu.hud.cornercolor=Цвет Края в HUD
beatrun.toolsmenu.hud.floatxpcolor=Цвет Всплывающего XP в HUD
# Tools Menu Viewbob Section
beatrun.toolsmenu.viewbob.name=Покачивание Камеры
beatrun.toolsmenu.viewbob.desc=Настройки покачивания камеры
beatrun.toolsmenu.viewbob.stabilization=Стабилизация Покачивания
beatrun.toolsmenu.viewbob.stabilizationdesc=Включите чтобы снизить покачивание камеры центрируя её
beatrun.toolsmenu.viewbob.intensity=Интенсивность Покачивания Камеры
# Tools Menu Gameplay Section
beatrun.toolsmenu.gameplay.name=Геймплей
beatrun.toolsmenu.gameplay.desc=Настройки геймплея
beatrun.toolsmenu.gameplay.quickturnground=Quickturn на Земле
beatrun.toolsmenu.gameplay.quickturngrounddesc=Переключает Quickturn будучи на земле (быстрый разворот)
beatrun.toolsmenu.gameplay.quickturnhandsonly=Quickturn Только с Руками
beatrun.toolsmenu.gameplay.quickturnhandsonlydesc=Переключает Quickturn только с "Runner Hands"
beatrun.toolsmenu.gameplay.puristmode=Режим Purist
beatrun.toolsmenu.gameplay.puristmodedesc=Режим Purist это клиентский параметр который сильно снижает движение игрока в стороны будучи в воздухе, прямо как в оригинальное ME.\n0 = Нет ограничений\n1 = Снижает движение игрока в воздухе в стороны
beatrun.toolsmenu.gameplay.disablegrapple=Отключить Крюк-Кошку
beatrun.toolsmenu.gameplay.disablegrappledesc=Отключает использование крюка-кошки
# Tools Menu Misc Section
beatrun.toolsmenu.misc.name=Другое
beatrun.toolsmenu.misc.desc=Другие настройки
beatrun.toolsmenu.misc.propspawn=Создание Пропов/Оружия
beatrun.toolsmenu.misc.propspawndesc=Позволяет создавать игрокам без админ прав оружие, пропы и энтити
beatrun.toolsmenu.misc.overdrivemp=Overdrive в Мультиплеере
beatrun.toolsmenu.misc.overdrivempdesc=Разрешает использование Overdrive в мультиплеере
# Tools Menu Moves Section
beatrun.toolsmenu.moves.name=Движения
beatrun.toolsmenu.moves.desc=Настройки движений
beatrun.toolsmenu.moves.help=Нырнуть Можно с Помощью Ctrl + ПКМ Будучи в Воздухе!\nOverdrive Переключается с Помощью E + ЛКМ.
beatrun.toolsmenu.moves.speedlimit=Ограничение Скорости
beatrun.toolsmenu.moves.speedlimitdesc=Изменяет ограничение скорости передвижения\nПо умолчанию: 325
beatrun.toolsmenu.moves.forcepuristmode=Принудительный Режим Purist
beatrun.toolsmenu.moves.forcepuristmodedesc=Включает режим Purist для всех игроков
beatrun.toolsmenu.moves.realisticwallrunning="Реалистичный" Бег по Стенам
beatrun.toolsmenu.moves.realisticwallrunningdesc=Нет потери в скорости если отключить
beatrun.toolsmenu.moves.kickglitch=Kick Glitch
beatrun.toolsmenu.moves.kickglitchdesc=Переключает Kick Glitch\nНажмите ЛКМ во время бега по стене и зажатии/нажатии на прыжок сразу после
beatrun.toolsmenu.moves.kickglitchversion=Версия Kick Glitch
beatrun.toolsmenu.moves.kickglitchversiondesc=Вкл - Старая версия\nDisabled - Новая версия\nНовая версия использует механику из ME которая создаёт небольшую платформу под игроком
beatrun.toolsmenu.moves.quakejump=Quake Jump
beatrun.toolsmenu.moves.quakejumpdesc=Переключает Quake Jump\nНажмите Прыжок сразу после Side Step
beatrun.toolsmenu.moves.sidestep=Side Step
beatrun.toolsmenu.moves.sidestepdesc=Переключает Side Step\nA/D + ПКМ
beatrun.toolsmenu.moves.disarm=Разоружение
beatrun.toolsmenu.moves.disarmdesc=Переключает возможность разоружить (убить) NPC\nНажмите ИСПОЛЬЗОВАТЬ на NPC
beatrun.toolsmenu.moves.divesettings=Настройки ныряния
beatrun.toolsmenu.moves.totsugeki=Totsugeki
beatrun.toolsmenu.moves.totsugekidesc=Переключает Totsugeki\nНырнуть сразу после Quake Jump
beatrun.toolsmenu.moves.totsugekispam=Спам Totsugeki
beatrun.toolsmenu.moves.totsugekispamdesc=Переключает возможность спамить Totsugeki
beatrun.toolsmenu.moves.totsugekiheading=Угол Totsugeki
beatrun.toolsmenu.moves.totsugekiheadingdesc=Позволяет делать Totsugeki по оси X (вверх/вниз)
beatrun.toolsmenu.moves.totsugekidirection=Направление Totsugeki
beatrun.toolsmenu.moves.totsugekidirectiondesc=Позволяет делать Totsugeki в направлении глаз\nCombined with Spam and Heading Allows You to Fly =)
# Tools Menu Gamemodes Section
beatrun.toolsmenu.gamemodes.name=Режимы
beatrun.toolsmenu.gamemodes.desc=Настройка режимов
beatrun.toolsmenu.gamemodes.error=Другой режим уже запущен!
beatrun.toolsmenu.gamemodes.infection=Переключить Infection
beatrun.toolsmenu.gamemodes.infectionstarttime=Время перед началом
beatrun.toolsmenu.gamemodes.infectiongametime=Продолжительность
beatrun.toolsmenu.gamemodes.infectiontime=Время в секундах
beatrun.toolsmenu.gamemodes.datatheft=Переключить Data Theft
beatrun.toolsmenu.gamemodes.deathmatch=Переключить Deathmatch
# Checkpoints
beatrun.checkpoints.countdown1=Раз
beatrun.checkpoints.countdown2=Два
beatrun.checkpoints.countdown3=ПОШЁЛ!
beatrun.checkpoints.speedometer=%s км/ч
# DataTheft
beatrun.datatheft.name=Data Theft (%s)
beatrun.datatheft.start=Data Theft! Убивайте игроков, собирайте кубики и вкладывайте в банк и зарабатывайте очки
# Deathmatch
beatrun.deathmatch.name=Deathmatch
beatrun.deathmatch.start=Deathmatch! Убивайте игроков чтобы зарабатывать очки
# Infection
beatrun.infection.name=Infection
beatrun.infection.infectedtext=(Заражённый)
beatrun.infection.humantext=(Человек)
beatrun.infection.start=Infection! Дотрагивайтесь до других игроков чтобы заразить их\n%s игрок(а/ов) будет выбрано через %s сек
beatrun.infection.nosurvivors=Никто...
beatrun.infection.infected=был заражён!
beatrun.infection.infectedby=заразил
beatrun.infection.award=Вы получили 200 XP за выживание!
beatrun.infection.awardinfected=Вы получили 100 XP за спавн заражённым!
beatrun.infection.end=Игра окончена!\nВыжившие: %s\nПерезапуск через 15 сек

View file

@ -202,6 +202,7 @@ local function RabbitCalcView(ply, origin, ang)
neweye = true neweye = true
ply:CLViewPunch(Angle(12, 0, 0)) ply:CLViewPunch(Angle(12, 0, 0))
if VManip then if VManip then
VManip:PlayAnim("vault") VManip:PlayAnim("vault")
end end

View file

@ -100,7 +100,7 @@ function ENT:DrawTranslucent()
render.DrawBeam(newpos, newpos + circleup, 8, 0, 1, red, true) render.DrawBeam(newpos, newpos + circleup, 8, 0, 1, red, true)
end end
local nextCP = Checkpoints[self:GetCPNum() + 1] or self local nextCP = IsValid(Checkpoints[self:GetCPNum() + 1]) and Checkpoints[self:GetCPNum() + 1] or self
local selfpos = self:GetPos() + checkheight local selfpos = self:GetPos() + checkheight
local fwAng = (nextCP:GetPos() - selfpos):GetNormalized():Angle() local fwAng = (nextCP:GetPos() - selfpos):GetNormalized():Angle()

View file

@ -1,9 +1,7 @@
local cvarwindsound local windsound
local minimalvm
if CLIENT then if CLIENT then
minimalvm = CreateClientConVar("Beatrun_MinimalVM", 1, true, true, "Lowers the running viewmodel", 0, 1) windsound = CreateClientConVar("Beatrun_Wind", 1, true, false, "Wind noises", 0, 1)
cvarwindsound = CreateClientConVar("Beatrun_Wind", 1, true, false, "Wind noises", 0, 1)
SWEP.PrintName = "Runner Hands" SWEP.PrintName = "Runner Hands"
SWEP.Slot = 0 SWEP.Slot = 0
@ -12,7 +10,7 @@ if CLIENT then
SWEP.DrawCrosshair = false SWEP.DrawCrosshair = false
hook.Add("VManipPrePlayAnim", "LOCNoVManip", function() hook.Add("VManipPrePlayAnim", "LOCNoVManip", function()
if LocalPlayer():GetActiveWeapon():GetClass() == "runnerhands" or blinded then return false end if LocalPlayer():UsingRH() or blinded then return false end
end) end)
end end
@ -73,10 +71,10 @@ function SWEP:SetupDataTables()
self:NetworkVar("Float", 2, "PunchReset") self:NetworkVar("Float", 2, "PunchReset")
end end
local runseq = { -- local runseq = {
[6] = true, -- [6] = true,
[7] = true -- [7] = true
} -- }
local oddseq = { local oddseq = {
[8] = true, [8] = true,
@ -86,22 +84,6 @@ local oddseq = {
} }
function SWEP:GetViewModelPosition(pos, ang) function SWEP:GetViewModelPosition(pos, ang)
if minimalvm:GetBool() then
if not self.posz then
self.posz = pos.z
end
local seq = self:GetSequence()
if runseq[seq] then
self.posz = Lerp(10 * FrameTime(), self.posz, -2)
else
self.posz = Lerp(10 * FrameTime(), self.posz, 0)
end
pos.z = pos.z + self.posz
end
if oddseq[self:GetSequence()] then return pos, ang end if oddseq[self:GetSequence()] then return pos, ang end
self.BobScale = 0 self.BobScale = 0
@ -142,6 +124,7 @@ local fallct = 0
function SWEP:Think() function SWEP:Think()
local ply = self:GetOwner() local ply = self:GetOwner()
local viewmodel = ply:GetViewModel() local viewmodel = ply:GetViewModel()
if not IsValid(viewmodel) then return end if not IsValid(viewmodel) then return end
if self:GetHoldType() == "fist" and CurTime() > self:GetPunchReset() then if self:GetHoldType() == "fist" and CurTime() > self:GetPunchReset() then
@ -163,6 +146,36 @@ function SWEP:Think()
local injump = curseq == 13 or curseq == 14 or curseq == 17 or curseq == -1 or curseq == 1 local injump = curseq == 13 or curseq == 14 or curseq == 17 or curseq == -1 or curseq == 1
infall = curseq == 19 infall = curseq == 19
--[[ what a piece of shit, send help
if vel:Length() == 0 and util.QuickTrace(ply:GetShootPos(), ply:GetAimVector() * 30, ply).Hit and ply:GetMoveType() ~= MOVETYPE_NOCLIP and not ply:Crouching() and ply:WaterLevel() == 0 and ply:GetWallrun() == 0 then
if (math.floor(ply:LocalEyeAngles().y) <= 35 and math.floor(ply:LocalEyeAngles().y) >= 5) or (math.floor(ply:LocalEyeAngles().y) <= 125 and math.floor(ply:LocalEyeAngles().y) >= 95) or (math.floor(ply:LocalEyeAngles().y) <= -55 and math.floor(ply:LocalEyeAngles().y) >= -85) or (math.floor(ply:LocalEyeAngles().y) <= -145 and math.floor(ply:LocalEyeAngles().y) >= -175) then
if CLIENT then
BodyLimitX = 20
return ArmInterrupt("standhandwallright")
elseif game.SinglePlayer() then
return ply:SendLua("BodyLimitX = 20 ArmInterrupt('standhandwallright')")
end
elseif (math.floor(ply:LocalEyeAngles().y) <= 5 and math.floor(ply:LocalEyeAngles().y) >= -5) or (math.floor(ply:LocalEyeAngles().y) <= 95 and math.floor(ply:LocalEyeAngles().y) >= 85) or (math.floor(ply:LocalEyeAngles().y) <= -85 and math.floor(ply:LocalEyeAngles().y) >= -95) or (math.floor(ply:LocalEyeAngles().y) <= -175 or math.floor(ply:LocalEyeAngles().y) >= 175) then
if CLIENT then
BodyLimitX = 20
return ArmInterrupt("standhandwallboth")
elseif game.SinglePlayer() then
return ply:SendLua("BodyLimitX = 20 ArmInterrupt('standhandwallboth')")
end
elseif (math.floor(ply:LocalEyeAngles().y) <= 5 and math.floor(ply:LocalEyeAngles().y) >= -35) or (math.floor(ply:LocalEyeAngles().y) <= 85 and math.floor(ply:LocalEyeAngles().y) >= 55) or (math.floor(ply:LocalEyeAngles().y) <= -95 and math.floor(ply:LocalEyeAngles().y) >= -125) or (math.floor(ply:LocalEyeAngles().y) <= 175 and math.floor(ply:LocalEyeAngles().y) >= 145) then
if CLIENT then
BodyLimitX = 20
return ArmInterrupt("standhandwallleft")
elseif game.SinglePlayer() then
return ply:SendLua("BodyLimitX = 20 ArmInterrupt('standhandwallleft')")
end
end
end
--]]
self:SetSideStep((curseq == 15 or curseq == 16) and GetConVar("Beatrun_SideStep"):GetBool()) self:SetSideStep((curseq == 15 or curseq == 16) and GetConVar("Beatrun_SideStep"):GetBool())
local insidestep = self:GetSideStep() local insidestep = self:GetSideStep()
@ -296,7 +309,7 @@ function SWEP:Think()
self.RunWind2 = CreateSound(self, "runwind.wav") self.RunWind2 = CreateSound(self, "runwind.wav")
end end
if velocity > 250 and cvarwindsound:GetBool() then if velocity > 250 and windsound:GetBool() then
self.RunWind1:Play() self.RunWind1:Play()
self.RunWind2:Play() self.RunWind2:Play()
@ -510,4 +523,4 @@ function SWEP:PrimaryAttack()
end end
function SWEP:SecondaryAttack() function SWEP:SecondaryAttack()
end end

View file

@ -67,7 +67,7 @@ end
function SWEP:PrimaryAttack() function SWEP:PrimaryAttack()
self:CallOnClient("PrimaryAttack") self:CallOnClient("PrimaryAttack")
local ply = self.Owner local ply = self:GetOwner()
if not self.points[#self.points] or (ply:EyePos() + ply:EyeAngles():Forward() * 50):Distance(self.points[#self.points]) > 5 then if not self.points[#self.points] or (ply:EyePos() + ply:EyeAngles():Forward() * 50):Distance(self.points[#self.points]) > 5 then
table.insert(self.points, ply:EyePos() + ply:EyeAngles():Forward() * 50) table.insert(self.points, ply:EyePos() + ply:EyeAngles():Forward() * 50)
@ -77,17 +77,20 @@ end
function SWEP:SecondaryAttack() function SWEP:SecondaryAttack()
self:CallOnClient("SecondaryAttack") self:CallOnClient("SecondaryAttack")
local ply = self.Owner local ply = self:GetOwner()
self.center:Set(ply:GetEyeTrace().HitPos) self.center:Set(ply:GetEyeTrace().HitPos)
end end
hook.Add("PostDrawTranslucentRenderables", "ShapeGun", function() hook.Add("PostDrawTranslucentRenderables", "ShapeGun", function()
local ply = Entity(1) if not CLIENT then return end
local wep = ply:GetActiveWeapon() or nil
if IsValid(wep) and wep:GetClass() == "shapedrawer" then local ply = LocalPlayer()
for k, v in ipairs(wep.points) do local wep = ply:GetActiveWeapon()
local isShapeDrawer = IsValid(wep) and wep:GetClass() == "shapedrawer"
if IsValid(ply) and isShapeDrawer then
for _, v in ipairs(wep.points) do
render.DrawWireframeBox(v, angle_zero, Vector(-1, -1, -1), Vector(1, 1, 1)) render.DrawWireframeBox(v, angle_zero, Vector(-1, -1, -1), Vector(1, 1, 1))
end end

View file

@ -66,6 +66,8 @@ function SWEP:PrimaryAttack()
if SERVER then if SERVER then
local zip = CreateZipline(ply:EyePos(), ply:GetEyeTrace().HitPos) local zip = CreateZipline(ply:EyePos(), ply:GetEyeTrace().HitPos)
zip:SetTwoWay(true)
table.insert(self.ziplines, zip) table.insert(self.ziplines, zip)
end end
end end

View file

@ -186,7 +186,7 @@ local spawn = {
} }
function PrintAllBars() function PrintAllBars()
for k, v in pairs(ents.FindByClass("br_swingbar")) do for _, v in pairs(ents.FindByClass("br_swingbar")) do
local pos, ang = v:GetPos(), v:GetAngles() local pos, ang = v:GetPos(), v:GetAngles()
local str = "{\"br_swingbar\", Vector(" .. pos.x .. ", " .. pos.y .. ", " .. pos.z .. "), Angle(" .. ang.x .. ", " .. ang.y .. ", " .. ang.z .. ")}," local str = "{\"br_swingbar\", Vector(" .. pos.x .. ", " .. pos.y .. ", " .. pos.z .. "), Angle(" .. ang.x .. ", " .. ang.y .. ", " .. ang.z .. ")},"
print(str) print(str)
@ -194,7 +194,7 @@ function PrintAllBars()
end end
function PrintAllCampBoxes() function PrintAllCampBoxes()
for k, v in pairs(ents.FindByClass("br_anticampbox")) do for _, v in pairs(ents.FindByClass("br_anticampbox")) do
local pos, ang = v:GetPos(), v:GetAngles() local pos, ang = v:GetPos(), v:GetAngles()
local str = "{\"br_anticampbox\", Vector(" .. pos.x .. ", " .. pos.y .. ", " .. pos.z .. "), Angle(" .. ang.x .. ", " .. ang.y .. ", " .. ang.z .. ")}," local str = "{\"br_anticampbox\", Vector(" .. pos.x .. ", " .. pos.y .. ", " .. pos.z .. "), Angle(" .. ang.x .. ", " .. ang.y .. ", " .. ang.z .. ")},"
print(str) print(str)
@ -202,7 +202,7 @@ function PrintAllCampBoxes()
end end
local function CreateSpawnEntities() local function CreateSpawnEntities()
for k, v in ipairs(spawn) do for _, v in ipairs(spawn) do
BRProtectedEntity(v[1], v[2], v[3]) BRProtectedEntity(v[1], v[2], v[3])
end end
end end

View file

@ -203,13 +203,13 @@ end
local function AEUIDraw() local function AEUIDraw()
if AEUI.NoDraw then return end if AEUI.NoDraw then return end
for k, v in ipairs(AEUI.Panels) do for _, v in ipairs(AEUI.Panels) do
surface.SetAlphaMultiplier(v.alpha or 1) surface.SetAlphaMultiplier(v.alpha or 1)
AEUI:DrawPanel(v) AEUI:DrawPanel(v)
surface.SetAlphaMultiplier(1) surface.SetAlphaMultiplier(1)
if v.elements then if v.elements then
for l, b in ipairs(v.elements) do for _, b in ipairs(v.elements) do
AEUI:DrawElement(v, b) AEUI:DrawElement(v, b)
end end
end end
@ -288,7 +288,7 @@ hook.Add("StartCommand", "AEUI_StartCommand", function(ply, cmd)
local click = input.WasMousePressed(MOUSE_LEFT) local click = input.WasMousePressed(MOUSE_LEFT)
if hoveredpanel then if hoveredpanel then
for k, v in ipairs(hoveredpanel.elements) do for _, v in ipairs(hoveredpanel.elements) do
if (v.onclick or v.hover) and (not v.greyed or not v.greyed()) and v.w and v.h then if (v.onclick or v.hover) and (not v.greyed or not v.greyed()) and v.w and v.h then
local x = SScaleX(hoveredpanel.x) + SScaleX(v.x) local x = SScaleX(hoveredpanel.x) + SScaleX(v.x)
local y = SScaleY(hoveredpanel.y) + SScaleY(v.y) + (hoveredpanel.scroll or 0) local y = SScaleY(hoveredpanel.y) + SScaleY(v.y) + (hoveredpanel.scroll or 0)

View file

@ -23,30 +23,33 @@ end
local addons = 0 local addons = 0
local incompatible = { local incompatible = {
["1581533176"] = true, ["1581533176"] = true, -- The Aperture [Reupload]
["2675972006"] = true, ["2675972006"] = true, -- Custom Loadout
["378401390"] = true, ["378401390"] = true, -- Quake/Half-Life View bobbing
["2027577882"] = true, ["2027577882"] = true, -- Mantle + Wallrun
["1190705063"] = true, ["1190705063"] = true, -- Lerped View Models
["123514260"] = true, ["123514260"] = true, -- SharpeYe
["2416989205"] = true, ["2416989205"] = true, -- Quick Slide
["2591814455"] = true, ["2591814455"] = true, -- [PF] Half-Life: Alyx
["240159269"] = true, ["240159269"] = true, -- S.M.A.R.T.:Smooth Parkour Movement
["2230307188"] = true, ["2230307188"] = true, -- EFT Walk Sounds (Footsteps)
["2137973704"] = true, ["2137973704"] = true, -- [PF] Modern Warfare 2
["577145478"] = true, ["577145478"] = true, -- ViewMod
["1632091428"] = true, ["1632091428"] = true, -- Fine Speed
["1622199072"] = true, ["1622199072"] = true, -- SaVav Parkour Mod
["2840019616"] = true, ["2840019616"] = true, -- cBobbing (Reupped & Fixed)
["583517911"] = true, ["583517911"] = true, -- Eye View Attachment
["2106330193"] = true, ["2106330193"] = true, -- BSMod Punch SWEP + Kick & KillMoves
["2593047682"] = true, ["2593047682"] = true, -- Viewpunch Viewbob
["142911907"] = true, ["142911907"] = true, -- Advanced Combat Rolls
["2316713217"] = true, ["2316713217"] = true, -- Player Speeds Changer 2.0 [REUPLOAD]
["2052642961"] = true, ["2635378860"] = true, -- MW/WZ Skydive/Parachute + Infil
["2635378860"] = true, ["2919957168"] = true, -- Modern Warfare II - Takedowns & Revive System
["2919957168"] = true, ["2600234804"] = true, -- ASTW2 - Base Weapons
["104815552"] = true ["2824714462"] = true, -- [TFA] Screen Shake
["3037375111"] = true, -- Quick Slide With Legs
["748422181"] = true, -- FOV Changer
["2930331275"] = true -- Realistic Fragmentation System
} }
local warnpanel = { local warnpanel = {
@ -79,7 +82,7 @@ local warntext = {
y = warnpanel.h * 0.125, y = warnpanel.h * 0.125,
centered = true, centered = true,
color = color_white, color = color_white,
string = "NOTICE\nPlease disable the following addons before playing\nor submitting any issues to GitHub:" string = language.GetPhrase("beatrun.addonwarning.warntext")
} }
table.insert(warnpanel.elements, warntext) table.insert(warnpanel.elements, warntext)
@ -91,21 +94,18 @@ local quitbutton = {
y = warnpanel.h * 0.85, y = warnpanel.h * 0.85,
centered = true, centered = true,
color = color_white, color = color_white,
string = "Return to Main Menu", string = "#beatrun.addonwarning.quitbutton",
onclick = function(self) onclick = function(self)
surface.PlaySound("garrysmod/ui_click.wav") surface.PlaySound("garrysmod/ui_click.wav")
MsgC(Color(255, 100, 100), "Quitting Beatrun due to conflicting addons!")
timer.Simple(0.5, function() timer.Simple(0.2, function()
RunConsoleCommand("killserver") RunConsoleCommand("disconnect")
end) end)
self.onclick = nil
end end
} }
table.insert(warnpanel.elements, quitbutton) table.insert(warnpanel.elements, quitbutton)
AEUI:AddButton(warnpanel, "Play", warnclosebutton, "AEUIDefault", warnpanel.w * 0.5, warnpanel.h * 0.93, true) AEUI:AddButton(warnpanel, "#beatrun.addonwarning.play", warnclosebutton, "AEUIDefault", warnpanel.w * 0.5, warnpanel.h * 0.93, true)
local conflictlist = { local conflictlist = {
type = "Text", type = "Text",
@ -132,8 +132,6 @@ local function CheckAddons()
end end
end end
print(conflictlist.string)
return addons return addons
end end
@ -142,7 +140,7 @@ local function WarningIcon()
surface.SetFont("BeatrunHUD") surface.SetFont("BeatrunHUD")
surface.SetTextPos(2, 0) surface.SetTextPos(2, 0)
surface.SetTextColor(220, 20, 20, math.abs(math.sin(CurTime() * 2) * 255)) surface.SetTextColor(220, 20, 20, math.abs(math.sin(CurTime() * 2) * 255))
surface.DrawText("CONFLICTING ADDONS FOUND") surface.DrawText("#beatrun.addonwarning.conflictfound")
return return
else else
@ -161,4 +159,4 @@ if conflictlist.string ~= "" then
AEUI:AddPanel(warnpanel) AEUI:AddPanel(warnpanel)
AEUI:AddPanel(conflictpanel) AEUI:AddPanel(conflictpanel)
end) end)
end end

View file

@ -10,11 +10,14 @@ BodyAnimString = "nil"
BodyAnimMDLString = "nil" BodyAnimMDLString = "nil"
BodyAnimSpeed = 1 BodyAnimSpeed = 1
bodyanimlastattachang = Angle(0, 0, 0) bodyanimlastattachang = Angle(0, 0, 0)
followplayer = true followplayer = true
deleteonend = true deleteonend = true
lockang = false lockang = false
CamAddAng = false CamAddAng = false
CamIgnoreAng = false CamIgnoreAng = false
-- local BodyAnimPos = Vector(0, 0, 0) -- local BodyAnimPos = Vector(0, 0, 0)
-- local BodyAnimAngLerp = Angle(0, 0, 0) -- local BodyAnimAngLerp = Angle(0, 0, 0)
-- local DidDraw = false -- local DidDraw = false
@ -24,29 +27,38 @@ local savedeyeangb = Angle(0, 0, 0)
-- local bodylockview = false -- local bodylockview = false
-- local bodyanimdone = false -- local bodyanimdone = false
-- local holstertime = 0 -- local holstertime = 0
local animmodelstring = "" local animmodelstring = ""
local showweapon = false local showweapon = false
local showvm = false local showvm = false
local usefullbody = false local usefullbody = false
local ignorez = false local ignorez = false
local customcycle = false local customcycle = false
deathanim = false deathanim = false
local allowmove = false local allowmove = false
local allowedangchange = false local allowedangchange = false
local attach, attachId, weapontoidle = nil, nil, nil local attach, attachId, weapontoidle = nil, nil, nil
local smoothend = false local smoothend = false
local endlerp = 0 local endlerp = 0
camoffset = Vector() camoffset = Vector()
camjoint = "eyes" camjoint = "eyes"
BodyAnimCrouchLerp = 1 BodyAnimCrouchLerp = 1
BodyAnimCrouchLerpZ = 0 BodyAnimCrouchLerpZ = 0
BodyAnimLimitEase = false BodyAnimLimitEase = false
CamShake = false CamShake = false
CamShakeAng = Angle() CamShakeAng = Angle()
CamShakeMult = 1 CamShakeMult = 1
local lastangy = 0 local lastangy = 0
viewtiltlerp = Angle() viewtiltlerp = Angle()
ViewTiltAngle = Angle() ViewTiltAngle = Angle()
local BodyAnimStartPos = Vector() local BodyAnimStartPos = Vector()
local view = {} local view = {}
local justremoved = false local justremoved = false
@ -108,7 +120,7 @@ function RemoveBodyAnim(noang)
local currentwep = ply:GetActiveWeapon() local currentwep = ply:GetActiveWeapon()
local vm = ply:GetViewModel() local vm = ply:GetViewModel()
if IsValid(currentwep) and currentwep:GetClass() ~= "runnerhands" then if ply:notUsingRH() then
if currentwep.PlayViewModelAnimation then if currentwep.PlayViewModelAnimation then
currentwep:PlayViewModelAnimation("Draw") currentwep:PlayViewModelAnimation("Draw")
else else
@ -210,13 +222,13 @@ function CacheLerpBodyAnim()
local pos = LocalPlayer():GetPos() local pos = LocalPlayer():GetPos()
-- local posdelta = pos - matrixfrompos -- local posdelta = pos - matrixfrompos
local self = BodyAnim local this = BodyAnim
self.m = self.m or Matrix() this.m = this.m or Matrix()
local from = matrixfrom local from = matrixfrom
local to = matrixto local to = matrixto
for bone = 0, self:GetBoneCount() - 1 do for bone = 0, this:GetBoneCount() - 1 do
if not armbones[BodyAnim:GetBoneName(bone)] then if not armbones[BodyAnim:GetBoneName(bone)] then
if not to[bone] then if not to[bone] then
to[bone] = {{}, {}, {}} to[bone] = {{}, {}, {}}
@ -228,7 +240,7 @@ function CacheLerpBodyAnim()
from[bone] = cachebody[bone]:FastToTable(from[bone]) or from[bone] from[bone] = cachebody[bone]:FastToTable(from[bone]) or from[bone]
to[bone] = to[bone] or ModelBoneMatrix:FastToTable(to[bone]) to[bone] = to[bone] or ModelBoneMatrix:FastToTable(to[bone])
local bonematrix = self:GetBoneMatrix(bone) local bonematrix = this:GetBoneMatrix(bone)
bonematrix:SetTranslation(bonematrix:GetTranslation() - pos) bonematrix:SetTranslation(bonematrix:GetTranslation() - pos)
to[bone] = bonematrix:FastToTable(to[bone]) to[bone] = bonematrix:FastToTable(to[bone])
@ -243,8 +255,8 @@ function CacheLerpBodyAnim()
v[4] = LerpL(transitionlerp, from[4], v[4]) v[4] = LerpL(transitionlerp, from[4], v[4])
end end
if not self.m then if not this.m then
self.m = Matrix(to[bone]) this.m = Matrix(to[bone])
else else
local bt = to[bone] local bt = to[bone]
local bt1 = bt[1] local bt1 = bt[1]
@ -252,12 +264,12 @@ function CacheLerpBodyAnim()
local bt3 = bt[3] local bt3 = bt[3]
slot15 = bt[4] slot15 = bt[4]
self.m:SetUnpacked(bt1[1], bt1[2], bt1[3], bt1[4], bt2[1], bt2[2], bt2[3], bt2[4], bt3[1], bt3[2], bt3[3], bt3[4], 0, 0, 0, 1) this.m:SetUnpacked(bt1[1], bt1[2], bt1[3], bt1[4], bt2[1], bt2[2], bt2[3], bt2[4], bt3[1], bt3[2], bt3[3], bt3[4], 0, 0, 0, 1)
end end
self.m:SetTranslation(self.m:GetTranslation() + pos) this.m:SetTranslation(this.m:GetTranslation() + pos)
self.m:SetScale(scalevec) this.m:SetScale(scalevec)
self:SetBoneMatrix(bone, self.m) this:SetBoneMatrix(bone, this.m)
end end
end end
@ -331,8 +343,8 @@ function StartBodyAnim(animtable)
if not IsValid(ply:GetHands()) then return end if not IsValid(ply:GetHands()) then return end
local plymodel = ply local plymodel = ply
local playermodel = string.Replace(ply:GetModel(), "models/models/", "models/") local playermodel = ply:GetModel()
local handsmodel = string.Replace(ply:GetHands():GetModel(), "models/models/", "models/") local handsmodel = ply:GetHands():GetModel()
if usefullbody == 2 then if usefullbody == 2 then
BodyAnimMDL = ClientsideModel(playermodel, RENDERGROUP_BOTH) BodyAnimMDL = ClientsideModel(playermodel, RENDERGROUP_BOTH)
@ -468,8 +480,7 @@ function BodyAnimCalcView2(ply, pos, angles, fov)
return return
end end
-- This is the issue with disappearing model when sliding, should be fixed for now if IsValid(BodyAnim) and pos:Distance(ply:EyePos()) > 20 then
if IsValid(BodyAnim) and pos:Distance(ply:EyePos()) > 20 then -- TODO: Something if appears again...
if updatethirdperson then if updatethirdperson then
ply:SetNoDraw(false) ply:SetNoDraw(false)
BodyAnim:SetNoDraw(true) BodyAnim:SetNoDraw(true)
@ -494,9 +505,8 @@ function BodyAnimCalcView2(ply, pos, angles, fov)
if ply:Crouching() then if ply:Crouching() then
local from = BodyAnimCrouchLerpZ local from = BodyAnimCrouchLerpZ
local activewep = ply:GetActiveWeapon()
if IsValid(activewep) and activewep:GetClass() == "runnerhands" then if ply:UsingRH() then
from = ply:EyePos().z - 64 from = ply:EyePos().z - 64
end end
@ -696,8 +706,6 @@ function BodyAnimCalcView2(ply, pos, angles, fov)
end end
hook.Add("CreateMove", "BodyLimitMove", function(cmd) hook.Add("CreateMove", "BodyLimitMove", function(cmd)
-- local ply = LocalPlayer()
if IsValid(BodyAnimMDL) and not allowmove then if IsValid(BodyAnimMDL) and not allowmove then
cmd:ClearButtons() cmd:ClearButtons()
cmd:ClearMovement() cmd:ClearMovement()

View file

@ -57,9 +57,10 @@ local function infostring()
y = math.Round(y) y = math.Round(y)
p = math.Round(p) p = math.Round(p)
local a = "Index: " .. BuildModeIndex .. "\nSelected: " .. table.Count(buildmode_selected) .. "\nAngle: " .. p .. ", " .. y .. ", " .. r local angle = p .. ", " .. y .. ", " .. r
local str = language.GetPhrase("beatrun.buildmodehud.info"):format(BuildModeIndex, table.Count(buildmode_selected), angle)
return a return str
end end
AEUI:AddText(bminfo, infostring, "AEUIDefault", bminfo.w / 2, bminfo.h / 2 - 20, true) AEUI:AddText(bminfo, infostring, "AEUIDefault", bminfo.w / 2, bminfo.h / 2 - 20, true)
@ -75,25 +76,27 @@ end
local function PanelElementsToggle(e) local function PanelElementsToggle(e)
local showingents = propspanel.elements == EntitiesElements local showingents = propspanel.elements == EntitiesElements
propspanel.elements = showingents and propspanel_elements or EntitiesElements propspanel.elements = showingents and propspanel_elements or EntitiesElements
e.string = showingents and "Menu / Props" or "Menu / Entities"
e.string = showingents and "#beatrun.buildmodehud.props" or "#beatrun.buildmodehud.entities"
propspanel.maxscroll = nil propspanel.maxscroll = nil
propspanel.scroll = nil propspanel.scroll = nil
end end
local b = AEUI:AddButton(bmbuttons, "Drag (G)", BuildModeHUDButton, "AEUIDefault", 2, 0, false) local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.drag", BuildModeHUDButton, "AEUIDefault", 2, 0, false)
b.key = KEY_G b.key = KEY_G
b.greyed = GreyButtons b.greyed = GreyButtons
local b = AEUI:AddButton(bmbuttons, "Copy (SHIFT+D)", BuildModeHUDButton, "AEUIDefault", 2, 25, false) local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.copy", BuildModeHUDButton, "AEUIDefault", 2, 25, false)
b.key = KEY_D b.key = KEY_D
b.greyed = GreyButtons b.greyed = GreyButtons
local b = AEUI:AddButton(bmbuttons, "Delete (DEL/BCKSPC)", BuildModeHUDButton, "AEUIDefault", 2, 50, false) local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.delete", BuildModeHUDButton, "AEUIDefault", 2, 50, false)
b.key = KEY_DELETE b.key = KEY_DELETE
b.greyed = GreyButtons b.greyed = GreyButtons
local b = AEUI:AddButton(bmbuttons, "Highlight (T)", BuildModeHUDButton, "AEUIDefault", 2, 75, false) local b = AEUI:AddButton(bmbuttons, "#beatrun.buildmodehud.highlight", BuildModeHUDButton, "AEUIDefault", 2, 75, false)
b.key = KEY_T b.key = KEY_T
b.greyed = GreyButtons b.greyed = GreyButtons
AEUI:AddButton(elementstogglepanel, "Menu / Props", PanelElementsToggle, "AEUILarge", 192, 20, true) AEUI:AddButton(elementstogglepanel, "#beatrun.buildmodehud.props", PanelElementsToggle, "AEUILarge", 192, 20, true)
local dummy = ClientsideModel("models/hunter/blocks/cube025x025x025.mdl") local dummy = ClientsideModel("models/hunter/blocks/cube025x025x025.mdl")
@ -150,7 +153,6 @@ end
local function BMPropClick(e) local function BMPropClick(e)
BuildModeIndex = e.prop or 0 BuildModeIndex = e.prop or 0
print(e.prop)
LocalPlayer():EmitSound("buttonclick.wav") LocalPlayer():EmitSound("buttonclick.wav")
if BuildModeIndex == 0 then if BuildModeIndex == 0 then
@ -168,7 +170,7 @@ end
local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 0, 0, 64, 64) local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 0, 0, 64, 64)
img.prop = 0 img.prop = 0
img.hover = "Select" img.hover = "#beatrun.buildmodehud.select"
local row = 1 local row = 1
local col = 0 local col = 0
@ -194,7 +196,7 @@ end
local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 64 * row, 64 * col, 64, 64) local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 64 * row, 64 * col, 64, 64)
img.prop = 0 img.prop = 0
img.hover = "Select" img.hover = "#beatrun.buildmodehud.select"
local function BuildModeElements() local function BuildModeElements()
propspanel.elements = EntitiesElements propspanel.elements = EntitiesElements
@ -206,7 +208,7 @@ local function BuildModeElements()
local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 0, 0, 64, 64) local img = AEUI:AddImage(propspanel, Material("vgui/empty.png"), BMPropClick, 0, 0, 64, 64)
img.prop = 0 img.prop = 0
img.hover = "Select" img.hover = "#beatrun.buildmodehud.select"
local buildmode_enticons = { local buildmode_enticons = {
br_swingbar = Material("vgui/editor/swingbar.png"), br_swingbar = Material("vgui/editor/swingbar.png"),
@ -221,7 +223,7 @@ local function BuildModeElements()
} }
local buildmode_entnames = { local buildmode_entnames = {
br_zipline = "Zipline (SHIFT = 2-Way)" br_zipline = "#beatrun.buildmodehud.zipline"
} }
local obsolete = Material("editor/obsolete") local obsolete = Material("editor/obsolete")

View file

@ -1,19 +1,26 @@
local apikey = CreateClientConVar("Beatrun_Apikey", "0", true, false, "API key") local apikey = CreateClientConVar("Beatrun_Apikey", "0", true, false, language.GetPhrase("beatrun.convars.apikey"))
local domain = CreateClientConVar("Beatrun_Domain", "courses.beatrun.ru", true, false, "Online courses domain") local domain = CreateClientConVar("Beatrun_Domain", "courses.beatrun.ru", true, false, language.GetPhrase("beatrun.convars.domain"))
local QueuedArgs = NULL local QueuedArgs = NULL
local QueuedFunction = NULL local QueuedFunction = NULL
concommand.Add("beatrun_confirm", function() local currentMap = game.GetMap()
concommand.Add("Beatrun_Confirm", function()
if QueuedArgs and QueuedFunction then if QueuedArgs and QueuedFunction then
QueuedFunction(QueuedArgs) QueuedFunction(QueuedArgs)
return return
end end
if QueuedFunction then if QueuedFunction then
QueuedFunction() QueuedFunction()
return return
end end
end) end)
concommand.Add("beatrun_cancel", function()
concommand.Add("Beatrun_Cancel", function()
QueuedArgs = NULL
QueuedFunction = NULL QueuedFunction = NULL
end) end)
@ -23,22 +30,22 @@ local function GetCurrentMapWorkshopID()
_, addon_folders = file.Find("*", addon.title) _, addon_folders = file.Find("*", addon.title)
if file.Exists("maps/" .. game.GetMap() .. ".bsp", addon.title) then return addon.wsid end if file.Exists("maps/" .. currentMap .. ".bsp", addon.title) then return addon.wsid end
end end
return 0 return 0
end end
function UploadCourse() function UploadCourse()
if Course_Name == "" or Course_ID == "" then return print("Can't upload in Freeplay") end if Course_Name == "" or Course_ID == "" then return print(language.GetPhrase("beatrun.coursesdatabase.cantuploadfreeplay")) end
local url = domain:GetString() .. "/upload.php" local url = domain:GetString() .. "/upload.php"
local data = file.Open("beatrun/courses/" .. game.GetMap() .. "/" .. Course_ID .. ".txt", "rb", "DATA") local data = file.Open("beatrun/courses/" .. currentMap .. "/" .. Course_ID .. ".txt", "rb", "DATA")
local filedata = util.Decompress(data:Read(data:Size())) local filedata = util.Decompress(data:Read(data:Size()))
http.Post(url, { http.Post(url, {
key = apikey:GetString(), key = apikey:GetString(),
map = string.Replace(game.GetMap(), " ", "-"), map = string.Replace(currentMap, " ", "-"),
course_data = util.Base64Encode(filedata, true), course_data = util.Base64Encode(filedata, true),
mapid = GetCurrentMapWorkshopID() mapid = GetCurrentMapWorkshopID()
}, function(body, length, headers, code) -- onSuccess function }, function(body, length, headers, code) -- onSuccess function
@ -54,24 +61,24 @@ end
concommand.Add("Beatrun_UploadCourse", function() concommand.Add("Beatrun_UploadCourse", function()
QueuedFunction = UploadCourse QueuedFunction = UploadCourse
print("You're trying to upload a course with the name "..Course_Name.." and on map "..game.GetMap()..".")
print("Write beatrun_confirm to continue, or beatrun_cancel to stop.") print(language.GetPhrase("beatrun.coursesdatabase.upload1"):format(Course_Name, currentMap))
print(language.GetPhrase("beatrun.coursesdatabase.upload2"))
end) end)
function GetCourse(sharecode) function GetCourse(sharecode)
local url = domain:GetString() .. "/getcourse.php" local url = domain:GetString() .. "/getcourse.php"
.. "?sharecode=" .. sharecode .. "?sharecode=" .. sharecode
.. "&map=" .. string.gsub(game.GetMap(), " ", "-") .. "&map=" .. string.Replace(currentMap, " ", "-")
.. "&key=" .. apikey:GetString() .. "&key=" .. apikey:GetString()
http.Fetch(url, function(body, length, headers, code) http.Fetch(url, function(body, length, headers, code)
if code == 200 then if code == 200 then
print("Success! | Response: " .. code .. " | Length: " .. length) print("Success! | Response: " .. code .. " | Length: " .. length .. "\nLoading course...")
print("Loading course...")
PrintTable(headers) PrintTable(headers)
local dir = "beatrun/courses/" .. game.GetMap() .. "/" local dir = "beatrun/courses/" .. currentMap .. "/"
file.CreateDir(dir) file.CreateDir(dir)
local coursedata = util.Compress(body) local coursedata = util.Compress(body)
@ -103,15 +110,15 @@ concommand.Add("Beatrun_LoadCode", function(ply, cmd, args, argstr)
end) end)
function UpdateCourse(course_code) function UpdateCourse(course_code)
if Course_Name == "" or Course_ID == "" then return print("Can't upload in Freeplay") end if Course_Name == "" or Course_ID == "" then return print(language.GetPhrase("beatrun.coursesdatabase.cantuploadfreeplay")) end
local url = domain:GetString() .. "/updatecourse.php" local url = domain:GetString() .. "/updatecourse.php"
local data = file.Open("beatrun/courses/" .. game.GetMap() .. "/" .. Course_ID .. ".txt", "rb", "DATA") local data = file.Open("beatrun/courses/" .. currentMap .. "/" .. Course_ID .. ".txt", "rb", "DATA")
local filedata = util.Decompress(data:Read(data:Size())) local filedata = util.Decompress(data:Read(data:Size()))
http.Post(url, { http.Post(url, {
key = apikey:GetString(), key = apikey:GetString(),
map = string.Replace(game.GetMap(), " ", "-"), map = string.Replace(currentMap, " ", "-"),
course_data = util.Base64Encode(filedata, true), course_data = util.Base64Encode(filedata, true),
code = course_code code = course_code
}, function(body, length, headers, code) -- onSuccess function }, function(body, length, headers, code) -- onSuccess function
@ -128,6 +135,7 @@ end
concommand.Add("Beatrun_UpdateCode", function(ply, cmd, args, argstr) concommand.Add("Beatrun_UpdateCode", function(ply, cmd, args, argstr)
QueuedFunction = UpdateCourse QueuedFunction = UpdateCourse
QueuedArgs = args[1] QueuedArgs = args[1]
print("You're trying to update a course with this code: "..args[1]..", with a course on map "..game.GetMap().." and name "..Course_Name..".")
print("Write beatrun_confirm to continue, or beatrun_cancel to stop.") print(language.GetPhrase("beatrun.coursesdatabase.update1"):format(QueuedArgs, Course_Name, currentMap))
end) print(language.GetPhrase("beatrun.coursesdatabase.upload2"))
end)

View file

@ -1,4 +1,4 @@
if not util.IsBinaryModuleInstalled("gdiscord", "GAME") then return end if not util.IsBinaryModuleInstalled("gdiscord") then return end
require("gdiscord") require("gdiscord")
@ -8,6 +8,10 @@ local refresh_time = 60
local discord_start = discord_start or -1 local discord_start = discord_start or -1
function DiscordUpdate() function DiscordUpdate()
local ply = LocalPlayer()
if not ply.GetLevel then return end
local rpc_data = {} local rpc_data = {}
if game.SinglePlayer() then if game.SinglePlayer() then
@ -34,14 +38,10 @@ function DiscordUpdate()
rpc_data["partyMax"] = 0 rpc_data["partyMax"] = 0
end end
local level = LocalPlayer():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"
if course == nil then
course = "Freeplay"
end
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

View file

@ -16,6 +16,7 @@ local vignettealpha = 0
local function FallCheck() local function FallCheck()
local ply = LocalPlayer() local ply = LocalPlayer()
if not IsValid(ply) then return end if not IsValid(ply) then return end
local speed = ply:GetVelocity().z local speed = ply:GetVelocity().z
if not ply.FallStatic and speed <= -800 and ply:GetMoveType() ~= MOVETYPE_NOCLIP and ply:GetDive() == false then if not ply.FallStatic and speed <= -800 and ply:GetMoveType() ~= MOVETYPE_NOCLIP and ply:GetDive() == false then

View file

@ -1,16 +1,17 @@
local showtotalXP = CreateClientConVar("Beatrun_HUDXP", "1", true, false, "Show total XP near nickname", 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, "Display HUD swaying", 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, "Hide HUD when moving", 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, "Hides most of the XP HUD", 0, 2) local hidden = CreateClientConVar("Beatrun_HUDHidden", "0", true, false, language.GetPhrase("beatrun.convars.hudhidden"), 0, 2)
local reticle = CreateClientConVar("Beatrun_HUDReticle", "1", true, false, "Display a reticle", 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_HUDCornerColor", "20 20 20 100", true, true, language.GetPhrase("beatrun.convars.hudcornercolor"))
CreateClientConVar("Beatrun_HUDFloatingXPColor", "255 255 255 255", true, true, language.GetPhrase("beatrun.convars.hudfloatxpcolor"))
local packetloss = Material("vgui/packetloss.png") local packetloss = Material("vgui/packetloss.png")
local lastloss = 0 local lastloss = 0
local MELogo = Material("vgui/MELogo.png", "mips smooth") local MELogo = Material("vgui/MELogo.png", "mips smooth")
CreateClientConVar("Beatrun_HUDTextColor", "255 255 255 255", true, true, "HUD Text Color\nDefault: 255 255 255 255")
CreateClientConVar("Beatrun_HUDCornerColor", "20 20 20 100", true, true, "HUD Left Corner Color\nDefault: 20 20 20 100")
CreateClientConVar("Beatrun_HUDFloatingXPColor", "255 255 255 255", true, true, "HUD Floating XP Color\nDefault: 255 255 255 255")
local hide = { local hide = {
CHudBattery = true, CHudBattery = true,
CHudHealth = true, CHudHealth = true,
@ -129,12 +130,12 @@ local function BeatrunHUD()
surface.SetFont("DebugFixedSmall") surface.SetFont("DebugFixedSmall")
-- local vtext = (ply:SteamID() or "?") .. " | " .. VERSIONGLOBAL local vtext = VERSIONGLOBAL
-- local tw, th = surface.GetTextSize(vtext) local tw, _ = surface.GetTextSize(vtext)
-- surface.SetTextColor(255, 255, 255, 15) surface.SetTextColor(255, 255, 255, 15)
-- surface.SetTextPos(scrw - tw, 0) surface.SetTextPos(scrw - tw, 0)
-- surface.DrawText(vtext) surface.DrawText(vtext)
-- surface.SetFont("BeatrunHUD") surface.SetFont("BeatrunHUD")
local pl = ply:GetNW2Int("PLoss") local pl = ply:GetNW2Int("PLoss")
local CT = CurTime() local CT = CurTime()
@ -170,7 +171,7 @@ local function BeatrunHUD()
local coursename = nil local coursename = nil
local customname = hook.Run("BeatrunHUDCourse") local customname = hook.Run("BeatrunHUDCourse")
coursename = customname and customname or Course_Name ~= "" and "Course: " .. Course_Name or "Freeplay" coursename = customname and customname or Course_Name ~= "" and language.GetPhrase("beatrun.hud.course"):format(Course_Name) or "#beatrun.hud.freeplay"
-- local lastxp = ply.LastXP or 0 -- local lastxp = ply.LastXP or 0
local nicktext = nil local nicktext = nil
@ -223,7 +224,7 @@ local function BeatrunHUD()
surface.SetFont("BeatrunHUD") surface.SetFont("BeatrunHUD")
surface.SetTextColor(text_color) surface.SetTextColor(text_color)
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("Lv." .. ply:GetLevel()) surface.DrawText(language.GetPhrase("beatrun.hud.lvl"):format(ply:GetLevel()))
if tobool(LocalPlayer():GetInfo("Beatrun_PuristMode")) then if tobool(LocalPlayer():GetInfo("Beatrun_PuristMode")) then
surface.SetDrawColor(230, 230, 230) surface.SetDrawColor(230, 230, 230)
@ -396,7 +397,7 @@ function BeatrunLeaderboard(forced)
if isinfection and pbtimenum == 0 and v:GetNW2Bool("Infected") then if isinfection and pbtimenum == 0 and v:GetNW2Bool("Infected") then
surface.SetTextColor(infectorcolor) surface.SetTextColor(infectorcolor)
surface.DrawText(" | Infector") surface.DrawText(" | " .. language.GetPhrase("beatrun.hud.infector"))
else else
surface.DrawText(" | " .. pbtime) surface.DrawText(" | " .. pbtime)
end end
@ -541,7 +542,7 @@ local function BeatrunReticle()
local wep = LocalPlayer():GetActiveWeapon() local wep = LocalPlayer():GetActiveWeapon()
if not IsValid(wep) or wep:GetClass() ~= "runnerhands" then return end if not IsValid(wep) or LocalPlayer():notUsingRH() then return end
surface.SetDrawColor(255, 255, 255) surface.SetDrawColor(255, 255, 255)
surface.SetMaterial(crosshair_standard) surface.SetMaterial(crosshair_standard)

View file

@ -16,11 +16,9 @@ local animtable = {
fbanims = { fbanims = {
ladderexittoplefthand = true, ladderexittoplefthand = true,
runfwdstart = true, runfwdstart = true,
vaultkong = true,
walktostandleft = true, walktostandleft = true,
wallrunverticalstart = true, wallrunverticalstart = true,
meleeair = true, meleeair = true,
vaultonto = true,
fallinguncontrolled = true, fallinguncontrolled = true,
stand = true, stand = true,
meslideend = true, meslideend = true,
@ -36,7 +34,6 @@ fbanims = {
hangheaveup = true, hangheaveup = true,
jumpwrright = true, jumpwrright = true,
meleeairhit = true, meleeairhit = true,
vaultover = true,
jumpstill = true, jumpstill = true,
dodgejumpright = true, dodgejumpright = true,
jumpturnflyidle = true, jumpturnflyidle = true,
@ -75,10 +72,8 @@ fbanims = {
diveslideidle = true, diveslideidle = true,
wallrunright = true, wallrunright = true,
diveslideend = true, diveslideend = true,
vaultontohigh = true,
divestart = true, divestart = true,
hangfoldedheaveup = true, hangfoldedheaveup = true,
vaultoverhigh = true,
ziplinestart = true, ziplinestart = true,
dodgejumpleft = true, dodgejumpleft = true,
evaderoll = true, evaderoll = true,
@ -107,10 +102,20 @@ fbanims = {
ladderclimbuprighthandstill = true, ladderclimbuprighthandstill = true,
jumpidle = true, jumpidle = true,
jumpair = true, jumpair = true,
vaultkong = true,
vaultonto = true,
vaultover = true,
vaultontohigh = true,
vaultoverhigh = true,
walkbalancefalloffright = true, walkbalancefalloffright = true,
meleeairstill = true, meleeairstill = true,
swingjumpoff = true, swingjumpoff = true,
snatchscar = true snatchscar = true,
water_swimfwd = true,
water_swimright = true,
water_swimleft = true,
water_swimback = true,
water_float = true
} }
local jumpanims = { local jumpanims = {
@ -149,7 +154,6 @@ local events = {
fall = true, fall = true,
ladderclimbleft = true, ladderclimbleft = true,
jumpwallrun = true, jumpwallrun = true,
vaultonto = true,
ziplinestart = true, ziplinestart = true,
hangstrafeleft = true, hangstrafeleft = true,
hangstraferight = true, hangstraferight = true,
@ -165,7 +169,6 @@ local events = {
jumpslide = true, jumpslide = true,
swingpipeleft = true, swingpipeleft = true,
ladderenterhang = true, ladderenterhang = true,
vault = true,
disarmsniper = true, disarmsniper = true,
jumpstill = true, jumpstill = true,
climb = true, climb = true,
@ -199,10 +202,13 @@ local events = {
ladderexittoprighthand = true, ladderexittoprighthand = true,
hangend = true, hangend = true,
springboard = true, springboard = true,
vault = true,
vaultkong = true, vaultkong = true,
vaultonto = true,
vaultover = true,
vaultontohigh = true,
ladderclimbright = true, ladderclimbright = true,
meleeairstill = true, meleeairstill = true
vaultontohigh = true
} }
local eventslut = { local eventslut = {
@ -275,7 +281,10 @@ local armfollowanims = {
diestandlong = true, diestandlong = true,
diveslidestart = true, diveslidestart = true,
vaultoverhigh = true, vaultoverhigh = true,
walkfwd = true walkfwd = true,
crouchstill = true,
crouchfwd = true,
crouchbwd = true
} }
local armlock = { local armlock = {
@ -321,10 +330,13 @@ local stillanims = {
local arminterrupts = { local arminterrupts = {
punchright = true, punchright = true,
doorbash = true,
punchmid = true,
punchleft = true, punchleft = true,
jumpturnflypiecesign = true punchmid = true,
doorbash = true,
jumpturnflypiecesign = true,
standhandwallright = true,
standhandwallleft = true,
standhandwallboth = true
} }
local transitionanims = { local transitionanims = {
@ -333,8 +345,6 @@ local transitionanims = {
ladderexittoplefthand = "runfwd", ladderexittoplefthand = "runfwd",
walktostandleft = "stand", walktostandleft = "stand",
fallinguncontrolled = "runfwd", fallinguncontrolled = "runfwd",
vaultoverhigh = "runfwd",
vaultonto = "runfwd",
hangstrafeleft = "hang", hangstrafeleft = "hang",
ladderclimbhangstart = "ladderclimbuprighthandstill", ladderclimbhangstart = "ladderclimbuprighthandstill",
hanghardstart2 = "hang", hanghardstart2 = "hang",
@ -350,7 +360,6 @@ local transitionanims = {
hangheaveup = "runfwd", hangheaveup = "runfwd",
dodgejumpleft = "stand", dodgejumpleft = "stand",
walkbalancefalloffleft = "jumpair", walkbalancefalloffleft = "jumpair",
vaultover = "jumpair",
meleeairhit = "jumpair", meleeairhit = "jumpair",
dodgejumpright = "stand", dodgejumpright = "stand",
meleeair = "jumpair", meleeair = "jumpair",
@ -368,7 +377,6 @@ local transitionanims = {
ladderclimbuplefthand = "ladderclimbuplefthandstill", ladderclimbuplefthand = "ladderclimbuplefthandstill",
jumpturnfly = "jumpturnflyidle", jumpturnfly = "jumpturnflyidle",
meleewrleft = "jumpair", meleewrleft = "jumpair",
vaultkong = "runfwd",
meleeslide = "meslideloop", meleeslide = "meslideloop",
stepuprightleg = "runfwd", stepuprightleg = "runfwd",
snatchsniper = "stand", snatchsniper = "stand",
@ -377,8 +385,17 @@ local transitionanims = {
wallrunverticalturn = "jumpslow", wallrunverticalturn = "jumpslow",
ladderclimbuprighthand = "ladderclimbuprighthandstill", ladderclimbuprighthand = "ladderclimbuprighthandstill",
meleeairstill = "jumpair", meleeairstill = "jumpair",
vaultoverhigh = "runfwd",
vaultonto = "runfwd",
vaultover = "jumpair",
vaultkong = "runfwd",
vaultontohigh = "runfwd", vaultontohigh = "runfwd",
snatchscar = "stand" snatchscar = "stand",
water_swimfwd = "runfwd",
water_swimright = "runfwd",
water_swimleft = "runfwd",
water_swimback = "runfwd",
water_float = "runfwd"
} }
local nospinebend = { local nospinebend = {
@ -412,7 +429,10 @@ local nospinebend = {
ladderclimbuprighthand = true, ladderclimbuprighthand = true,
ladderclimbhangstart = true, ladderclimbhangstart = true,
vaultontohigh = true, vaultontohigh = true,
snatchscar = true snatchscar = true,
crouchstill = true,
crouchfwd = true,
crouchbwd = true
} }
local worldarm = { local worldarm = {
@ -442,8 +462,12 @@ local worldarm = {
ladderclimbuprighthand = true, ladderclimbuprighthand = true,
ladderclimbhangstart = true, ladderclimbhangstart = true,
snatchscar = true, snatchscar = true,
jumpcoil = true, jumpturnlandidle = true,
jumpturnlandidle = true standhandwallright = true,
standhandwallleft = true,
standhandwallboth = true,
swing = true,
swingstraight = true
} }
local ignorezarm = { local ignorezarm = {
@ -464,7 +488,8 @@ local nocyclereset = {
local ignorebac = { local ignorebac = {
evaderoll = true, evaderoll = true,
meroll = true meroll = true,
merollgun = true
} }
local customspeed = { local customspeed = {
@ -489,7 +514,7 @@ local customarmoffset = {
meslidestart45 = Vector(2, 5, 5), meslidestart45 = Vector(2, 5, 5),
meslideloop45 = Vector(2, 5, 5), meslideloop45 = Vector(2, 5, 5),
meslideend = Vector(2, 5, 9.5), meslideend = Vector(2, 5, 9.5),
meslideendprone = Vector(2, 5, 9.5), meslideendprone = Vector(0, 0, 3),
meleeslide = Vector(2, 5, 9.5), meleeslide = Vector(2, 5, 9.5),
jumpturnfly = Vector(0, 2.5, 7.5), jumpturnfly = Vector(0, 2.5, 7.5),
jumpturnflyidle = Vector(0, 2.5, 7.5), jumpturnflyidle = Vector(0, 2.5, 7.5),
@ -508,9 +533,9 @@ local customarmoffset = {
ladderexittoprighthand = Vector(5, 0, 0), ladderexittoprighthand = Vector(5, 0, 0),
ladderclimbhangstart = Vector(-5, 0, 0), ladderclimbhangstart = Vector(-5, 0, 0),
ladderenterbottom = Vector(-7.5, 0, 0), ladderenterbottom = Vector(-7.5, 0, 0),
crouchstill = Vector(-4, 0, -5), crouchstill = Vector(-4, 0, -2),
crouchfwd = Vector(-4, 0, -5), crouchfwd = Vector(-4, 0, -2),
crouchbwd = Vector(0, 0, 0), crouchbwd = Vector(-4, 0, -2),
walkfwd = Vector(10, 0, -10), walkfwd = Vector(10, 0, -10),
runbwd = Vector(0, 0, 3), runbwd = Vector(0, 0, 3),
stand = Vector(10, 0, -10), stand = Vector(10, 0, -10),
@ -533,9 +558,9 @@ local customcamoffset = {
hangstrafeleft = Vector(-2.5, 0, 0), hangstrafeleft = Vector(-2.5, 0, 0),
hangstraferight = Vector(-2.5, 0, 0), hangstraferight = Vector(-2.5, 0, 0),
snatchscar = snatchscarcam1, snatchscar = snatchscarcam1,
crouchstill = Vector(0, 0, 2.5), crouchstill = Vector(2, 0, 2.5),
crouchfwd = Vector(0, 0, 2.5), crouchfwd = Vector(2, 0, 2.5),
crouchbwd = Vector(0, 0, 2.5) crouchbwd = Vector(2, 0, 2.5)
} }
local transitionchecks = { local transitionchecks = {
@ -753,7 +778,14 @@ local transitionchecks = {
fbfunctions = { fbfunctions = {
vaultontohigh = function(ply) return true end, vaultontohigh = function(ply) return true end,
swing = function(ply)
CamIgnoreAng = false
BodyLimitY = 180
end,
swingstraight = function(ply) swingstraight = function(ply)
CamIgnoreAng = false
BodyLimitY = 180
BodyAnim:SetPoseParameter("swing", (ply:GetSBOffset() / 45 - 1) * 100) BodyAnim:SetPoseParameter("swing", (ply:GetSBOffset() / 45 - 1) * 100)
end, end,
ziplinestart = function(ply) ziplinestart = function(ply)
@ -914,7 +946,6 @@ fbfunctions = {
local defaultcamoffset = Vector() local defaultcamoffset = Vector()
local playermodelbones = {"ValveBiped.Bip01_L_UpperArm", "ValveBiped.Bip01_R_UpperArm"} local playermodelbones = {"ValveBiped.Bip01_L_UpperArm", "ValveBiped.Bip01_R_UpperArm"}
local fingers = {"ValveBiped.Bip01_L_Finger4", "ValveBiped.Bip01_L_Finger41", "ValveBiped.Bip01_L_Finger3", "ValveBiped.Bip01_L_Finger31", "ValveBiped.Bip01_L_Finger2", "ValveBiped.Bip01_L_Finger21", "ValveBiped.Bip01_L_Finger1", "ValveBiped.Bip01_L_Finger11", "ValveBiped.Bip01_R_Finger4", "ValveBiped.Bip01_R_Finger41", "ValveBiped.Bip01_R_Finger3", "ValveBiped.Bip01_R_Finger31", "ValveBiped.Bip01_R_Finger2", "ValveBiped.Bip01_R_Finger21", "ValveBiped.Bip01_R_Finger1", "ValveBiped.Bip01_R_Finger11"} local fingers = {"ValveBiped.Bip01_L_Finger4", "ValveBiped.Bip01_L_Finger41", "ValveBiped.Bip01_L_Finger3", "ValveBiped.Bip01_L_Finger31", "ValveBiped.Bip01_L_Finger2", "ValveBiped.Bip01_L_Finger21", "ValveBiped.Bip01_L_Finger1", "ValveBiped.Bip01_L_Finger11", "ValveBiped.Bip01_R_Finger4", "ValveBiped.Bip01_R_Finger41", "ValveBiped.Bip01_R_Finger3", "ValveBiped.Bip01_R_Finger31", "ValveBiped.Bip01_R_Finger2", "ValveBiped.Bip01_R_Finger21", "ValveBiped.Bip01_R_Finger1", "ValveBiped.Bip01_R_Finger11"}
local fingerscustom = { local fingerscustom = {
@ -1011,7 +1042,6 @@ eventsounds = {
} }
local CharaName = "Faith" local CharaName = "Faith"
local CharaLen = #CharaName
local function BodyEventSounds(anim) local function BodyEventSounds(anim)
local tbl = eventsounds[anim] local tbl = eventsounds[anim]
@ -1022,7 +1052,7 @@ local function BodyEventSounds(anim)
for k, v in pairs(tbl) do for k, v in pairs(tbl) do
local func = nil local func = nil
if v:Left(CharaLen) == CharaName then if v:Left(#CharaName) == CharaName then
func = ply.FaithVO func = ply.FaithVO
else else
func = ply.EmitSound func = ply.EmitSound
@ -1212,7 +1242,7 @@ local function JumpArmDraw(a, b, c)
local activewep = ply:GetActiveWeapon() local activewep = ply:GetActiveWeapon()
if IsValid(activewep) and activewep:GetClass() == "runnerhands" then if ply:UsingRH() then
if not worldarm[BodyAnimString] then if not worldarm[BodyAnimString] then
cam.Start3D(pos, ang) cam.Start3D(pos, ang)
cam.IgnoreZ(ignorezarm[BodyAnimString] or false) cam.IgnoreZ(ignorezarm[BodyAnimString] or false)
@ -1372,7 +1402,7 @@ function ArmInterrupt(anim)
local arm = CreateBodyAnimArmCopy() local arm = CreateBodyAnimArmCopy()
if IsValid(arm) then if IsValid(arm) then
for k, v in ipairs(fingers) do for _, v in ipairs(fingers) do
local b = BodyAnimArmCopy:LookupBone(v) local b = BodyAnimArmCopy:LookupBone(v)
if b then if b then
@ -1380,7 +1410,7 @@ function ArmInterrupt(anim)
end end
end end
for k, v in pairs(fingerscustom) do for k, _ in pairs(fingerscustom) do
local b = BodyAnimArmCopy:LookupBone(k) local b = BodyAnimArmCopy:LookupBone(k)
if b then if b then
@ -1388,6 +1418,22 @@ function ArmInterrupt(anim)
end end
end end
--[[ TODO: make work good
if string.match(anim, "standhandwall") then
local ply = LocalPlayer()
local trace = util.QuickTrace(ply:GetShootPos(), ply:GetAimVector() * 30, ply)
local x = trace.Normal.x < 0.6 and trace.Normal.x or trace.Normal.y
local y = trace.Normal.y > -0.8 and trace.Normal.y or -trace.Normal.x
local newAng = Angle(x * (5 * trace.Fraction * x), 0, x * (10 * trace.Fraction * y))
ply:ChatPrint("Fraction: " .. tostring(trace.Fraction))
ply:ChatPrint("Normal: " .. tostring(trace.Normal))
arm:SetAngles(newAng)
end
--]]
arm:SetSequence(anim) arm:SetSequence(anim)
arm:SetCycle(0) arm:SetCycle(0)
end end
@ -1623,6 +1669,20 @@ local function JumpThink()
BodyAnim:SetSequence(transitionanims[BodyAnimString]) BodyAnim:SetSequence(transitionanims[BodyAnimString])
end end
if ply:WaterLevel() >= 2 and not ply:Crouching() and not ply:OnGround() and ply:GetMoveType() ~= MOVETYPE_NOCLIP then
BodyAnim:SetSequence(BodyAnim:LookupSequence("water_float"))
if ply:KeyDown(IN_MOVELEFT) and vel_l > 5 then
BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimleft"))
elseif ply:KeyDown(IN_MOVERIGHT) and vel_l > 5 then
BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimright"))
elseif ply:KeyDown(IN_FORWARD) and vel_l > 5 then
BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimfwd"))
elseif ply:KeyDown(IN_BACK) and vel_l > 5 then
BodyAnim:SetSequence(BodyAnim:LookupSequence("water_swimback"))
end
end
if BodyAnimString == "wallrunverticalstart" or BodyAnimString == "wallrunvertical" then if BodyAnimString == "wallrunverticalstart" or BodyAnimString == "wallrunvertical" then
ang = ply.WallrunOrigAng or ang ang = ply.WallrunOrigAng or ang
BodyAnimSpeed = 1.2 * math.Clamp((LocalPlayer():GetWallrunTime() - CurTime()) / 1.2, 0.5, 1) BodyAnimSpeed = 1.2 * math.Clamp((LocalPlayer():GetWallrunTime() - CurTime()) / 1.2, 0.5, 1)
@ -1728,4 +1788,4 @@ local function JumpThink()
end end
end end
hook.Add("Think", "JumpThink", JumpThink) hook.Add("Think", "JumpThink", JumpThink)

View file

@ -25,12 +25,12 @@ local function buildmodebutton()
LocalPlayer():ConCommand("buildmode") LocalPlayer():ConCommand("buildmode")
end end
AEUI:AddText(coursepanel, "Time Trials - " .. game.GetMap(), "AEUIVeryLarge", 20, 30) AEUI:AddText(coursepanel, language.GetPhrase("beatrun.coursemenu.trials"):format(game.GetMap()), "AEUIVeryLarge", 20, 30)
local buildmodebutton = AEUI:AddButton(coursepanel, "Build Mode Toggle", buildmodebutton, "AEUILarge", coursepanel.w - 400, coursepanel.h - 50) local buildmodebutton = AEUI:AddButton(coursepanel, "#beatrun.coursemenu.buildmode", buildmodebutton, "AEUILarge", coursepanel.w - 400, coursepanel.h - 50)
buildmodebutton.greyed = sacheck buildmodebutton.greyed = sacheck
local stopbutton = AEUI:AddButton(coursepanel, "Return to Freeplay", stopbutton, "AEUILarge", coursepanel.w - 750, coursepanel.h - 50) local stopbutton = AEUI:AddButton(coursepanel, "#beatrun.coursemenu.freeplay", stopbutton, "AEUILarge", coursepanel.w - 750, coursepanel.h - 50)
stopbutton.greyed = sacheck stopbutton.greyed = sacheck
local courselist = { local courselist = {

View file

@ -1,4 +1,4 @@
local NametagsEnable = CreateClientConVar("Beatrun_Nametags", "1", true, false, "Toggles nametags above players", 0, 1) local NametagsEnable = CreateClientConVar("Beatrun_Nametags", "1", true, false, language.GetPhrase("beatrun.convars.nametags"), 0, 1)
local enemy = Color(255, 0, 0) local enemy = Color(255, 0, 0)

View file

@ -1,4 +1,4 @@
if not util.IsBinaryModuleInstalled("steamrichpresencer", "GAME") then return end if not util.IsBinaryModuleInstalled("steamrichpresencer") then return end
require("steamrichpresencer") require("steamrichpresencer")
@ -7,17 +7,13 @@ 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 = LocalPlayer():GetLevel() local level = ply:GetLevel()
local course = nil
local customname = hook.Run("BeatrunHUDCourse") local customname = hook.Run("BeatrunHUDCourse")
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"
if course == nil then
course = "Freeplay"
end
local updatedtext = "Beatrun Lv. " .. level .. " (" .. map .. ") | " .. course local updatedtext = "Beatrun Lv. " .. level .. " (" .. map .. ") | " .. course

View file

@ -5,33 +5,33 @@ local function ToggleGamemode(gm)
end end
hook.Add("AddToolMenuCategories", "Beatrun_Category", function() hook.Add("AddToolMenuCategories", "Beatrun_Category", function()
spawnmenu.AddToolCategory("Beatrun", "Client", "Client") spawnmenu.AddToolCategory("Beatrun", "Client", language.GetPhrase("beatrun.toolsmenu.client"))
spawnmenu.AddToolCategory("Beatrun", "Server", "Server") spawnmenu.AddToolCategory("Beatrun", "Server", language.GetPhrase("beatrun.toolsmenu.server"))
end) end)
hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function() hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_courses", "Courses", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_courses", language.GetPhrase("beatrun.toolsmenu.courses.name"), "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("Courses Setttings") panel:SetName("#beatrun.toolsmenu.courses.desc")
panel:CheckBox("Fast Start", "Beatrun_FastStart") panel:CheckBox("#beatrun.toolsmenu.courses.faststart", "Beatrun_FastStart")
panel:ControlHelp("Faster countdown in courses") panel:ControlHelp("#beatrun.toolsmenu.courses.faststartdesc")
panel:CheckBox("Save at Checkpoint", "Beatrun_CPSave") panel:CheckBox("#beatrun.toolsmenu.courses.checkpointsave", "Beatrun_CPSave")
panel:ControlHelp("Respawn at last hit checkpoint in courses") panel:ControlHelp("#beatrun.toolsmenu.courses.checkpointsavedesc")
local divider = vgui.Create("DHorizontalDivider") local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider) panel:AddItem(divider)
panel:TextEntry("Courses server", "Beatrun_Domain") panel:TextEntry("#beatrun.toolsmenu.courses.database", "Beatrun_Domain")
panel:ControlHelp("Database domain\nDefault: courses.beatrun.ru") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.courses.databasedesc"))
local apiKeyButton = vgui.Create("DButton", panel) local apiKeyButton = vgui.Create("DButton", panel)
apiKeyButton:SetText("Change API Key") apiKeyButton:SetText("#beatrun.toolsmenu.courses.changeapikey")
apiKeyButton:SetSize(0, 20) apiKeyButton:SetSize(0, 20)
apiKeyButton.DoClick = function() apiKeyButton.DoClick = function()
local frame = vgui.Create("DFrame") local frame = vgui.Create("DFrame")
frame:SetTitle("Enter your API Key") frame:SetTitle("#beatrun.toolsmenu.courses.enterapikey")
frame:SetSize(300, 100) frame:SetSize(300, 100)
frame:SetDeleteOnClose(true) frame:SetDeleteOnClose(true)
frame:Center() frame:Center()
@ -41,11 +41,13 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP) TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame) local okButton = vgui.Create("DButton", frame)
okButton:SetText("OK") okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60) okButton:SetPos(25, 60)
okButton:SetSize(250, 30) okButton:SetSize(250, 30)
okButton.DoClick = function() okButton.DoClick = function()
RunConsoleCommand("Beatrun_Apikey", TextEntry:GetValue()) local key = string.Replace(TextEntry:GetValue(), " ", "")
RunConsoleCommand("Beatrun_Apikey", key)
frame:Close() frame:Close()
end end
end end
@ -55,11 +57,11 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(divider) panel:AddItem(divider)
local saveCourseButton = vgui.Create("DButton", panel) local saveCourseButton = vgui.Create("DButton", panel)
saveCourseButton:SetText("Save current course to a file") saveCourseButton:SetText("#beatrun.toolsmenu.courses.savecourse")
saveCourseButton:SetSize(0, 20) saveCourseButton:SetSize(0, 20)
saveCourseButton.DoClick = function() saveCourseButton.DoClick = function()
local frame = vgui.Create("DFrame") local frame = vgui.Create("DFrame")
frame:SetTitle("Enter a name for your course") frame:SetTitle("#beatrun.toolsmenu.courses.namesavecourse")
frame:SetSize(300, 100) frame:SetSize(300, 100)
frame:SetDeleteOnClose(true) frame:SetDeleteOnClose(true)
frame:Center() frame:Center()
@ -69,22 +71,24 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP) TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame) local okButton = vgui.Create("DButton", frame)
okButton:SetText("OK") okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60) okButton:SetPos(25, 60)
okButton:SetSize(250, 30) okButton:SetSize(250, 30)
okButton.DoClick = function() okButton.DoClick = function()
RunConsoleCommand("Beatrun_SaveCourse", TextEntry:GetValue()) local name = string.Replace(TextEntry:GetValue(), " ", "_")
RunConsoleCommand("Beatrun_SaveCourse", name)
frame:Close() frame:Close()
end end
end end
panel:AddItem(saveCourseButton) panel:AddItem(saveCourseButton)
local loadCodeButton = vgui.Create("DButton", panel) local loadCourseButton = vgui.Create("DButton", panel)
loadCodeButton:SetText("Load a course from the database") loadCourseButton:SetText("#beatrun.toolsmenu.courses.loadcourse")
loadCodeButton:SetSize(0, 20) loadCourseButton:SetSize(0, 20)
loadCodeButton.DoClick = function() loadCourseButton.DoClick = function()
local frame = vgui.Create("DFrame") local frame = vgui.Create("DFrame")
frame:SetTitle("Enter course code") frame:SetTitle("#beatrun.toolsmenu.courses.enterloadcourse")
frame:SetSize(300, 100) frame:SetSize(300, 100)
frame:SetDeleteOnClose(true) frame:SetDeleteOnClose(true)
frame:Center() frame:Center()
@ -94,31 +98,33 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP) TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame) local okButton = vgui.Create("DButton", frame)
okButton:SetText("OK") okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60) okButton:SetPos(25, 60)
okButton:SetSize(250, 30) okButton:SetSize(250, 30)
okButton.DoClick = function() okButton.DoClick = function()
RunConsoleCommand("Beatrun_LoadCode", TextEntry:GetValue()) local code = string.Replace(TextEntry:GetValue(), " ", "")
RunConsoleCommand("Beatrun_LoadCode", code)
frame:Close() frame:Close()
end end
end end
panel:AddItem(loadCodeButton) panel:AddItem(loadCourseButton)
local uploadCourseButton = vgui.Create("DButton", panel) local uploadCourseButton = vgui.Create("DButton", panel)
uploadCourseButton:SetText("Upload current course to the database") uploadCourseButton:SetText("#beatrun.toolsmenu.courses.uploadcourse")
uploadCourseButton:SetSize(0, 20) uploadCourseButton:SetSize(0, 20)
uploadCourseButton.DoClick = function() uploadCourseButton.DoClick = function()
RunConsoleCommand("Beatrun_UploadCourse") RunConsoleCommand("Beatrun_UploadCourse")
notification.AddLegacy("Open your console for the code!", NOTIFY_HINT, 5) notification.AddLegacy("#beatrun.misc.checkconsole", NOTIFY_HINT, 5)
end end
panel:AddItem(uploadCourseButton) panel:AddItem(uploadCourseButton)
local updateCodeButton = vgui.Create("DButton", panel) local updateCourseButton = vgui.Create("DButton", panel)
updateCodeButton:SetText("Update a course on the database") updateCourseButton:SetText("#beatrun.toolsmenu.courses.updatecourse")
updateCodeButton:SetSize(0, 20) updateCourseButton:SetSize(0, 20)
updateCodeButton.DoClick = function() updateCourseButton.DoClick = function()
local frame = vgui.Create("DFrame") local frame = vgui.Create("DFrame")
frame:SetTitle("Enter course code") frame:SetTitle("#beatrun.toolsmenu.courses.enterloadcourse")
frame:SetSize(300, 100) frame:SetSize(300, 100)
frame:SetDeleteOnClose(true) frame:SetDeleteOnClose(true)
frame:Center() frame:Center()
@ -128,53 +134,51 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
TextEntry:Dock(TOP) TextEntry:Dock(TOP)
local okButton = vgui.Create("DButton", frame) local okButton = vgui.Create("DButton", frame)
okButton:SetText("OK") okButton:SetText("#beatrun.misc.ok")
okButton:SetPos(25, 60) okButton:SetPos(25, 60)
okButton:SetSize(250, 30) okButton:SetSize(250, 30)
okButton.DoClick = function() okButton.DoClick = function()
RunConsoleCommand("Beatrun_UpdateCode", TextEntry:GetValue()) RunConsoleCommand("Beatrun_UpdateCode", TextEntry:GetValue())
notification.AddLegacy("Open your console for server's response!", NOTIFY_HINT, 5) notification.AddLegacy("#beatrun.misc.checkconsole", NOTIFY_HINT, 5)
frame:Close() frame:Close()
end end
end end
panel:AddItem(updateCodeButton) panel:AddItem(updateCourseButton)
panel:Help("#beatrun.toolsmenu.courses.updatecoursehelp")
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_hud", "HUD", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_hud", "#beatrun.toolsmenu.hud.name", "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("HUD Setttings") panel:SetName("#beatrun.toolsmenu.hud.desc")
panel:CheckBox("Dynamic HUD", "Beatrun_HUDDynamic") panel:CheckBox("#beatrun.toolsmenu.hud.dynamic", "Beatrun_HUDDynamic")
panel:ControlHelp("Hides HUD when moving") panel:ControlHelp("#beatrun.toolsmenu.hud.dynamicdesc")
panel:CheckBox("HUD Sway", "Beatrun_HUDSway") panel:CheckBox("#beatrun.toolsmenu.hud.sway", "Beatrun_HUDSway")
panel:ControlHelp("Toggles HUD swaying") panel:ControlHelp("#beatrun.toolsmenu.hud.swaydesc")
panel:CheckBox("Dot", "Beatrun_HUDReticle") panel:CheckBox("#beatrun.toolsmenu.hud.reticle", "Beatrun_HUDReticle")
panel:ControlHelp("Shows a dot in the center of the screen") panel:ControlHelp("#beatrun.toolsmenu.hud.reticledesc")
panel:CheckBox("Nametags", "Beatrun_Nametags") panel:CheckBox("#beatrun.toolsmenu.hud.nametags", "Beatrun_Nametags")
panel:ControlHelp("Toggles nametags above players") panel:ControlHelp("#beatrun.toolsmenu.hud.nametagsdesc")
panel:CheckBox("Floating XP", "Beatrun_HUDXP") panel:CheckBox("#beatrun.toolsmenu.hud.hudxp", "Beatrun_HUDXP")
panel:ControlHelp("Show total XP near your nickname") panel:ControlHelp("#beatrun.toolsmenu.hud.hudxpdesc")
panel:CheckBox("Lower Viewmodel", "Beatrun_MinimalVM") panel:CheckBox("#beatrun.toolsmenu.hud.wind", "Beatrun_Wind")
panel:ControlHelp("Lowers the running viewmodel") panel:ControlHelp("#beatrun.toolsmenu.hud.winddesc")
panel:CheckBox("Wind", "Beatrun_Wind") panel:NumSlider("#beatrun.toolsmenu.hud.fov", "Beatrun_FOV", 90, 120, 0)
panel:ControlHelp("Wind noises when running") panel:Help("#beatrun.toolsmenu.hud.fovdesc")
panel:NumSlider("FOV", "Beatrun_FOV", 90, 120, 0) panel:NumSlider("#beatrun.toolsmenu.hud.hidden", "Beatrun_HUDHidden", 0, 2, 0)
panel:ControlHelp("You need to respawn after changing the FOV!") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.hud.hiddendesc"))
panel:NumSlider("Hide HUD", "Beatrun_HUDHidden", 0, 2, 0)
panel:ControlHelp("0 - Shown\n1 - Gamemode only\n2 - Hidden")
local divider = vgui.Create("DHorizontalDivider") local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider) panel:AddItem(divider)
panel:Help("HUD Text Color") panel:Help("#beatrun.toolsmenu.hud.textcolor")
local HudTextColor = vgui.Create("DColorMixer", panel) local HudTextColor = vgui.Create("DColorMixer", panel)
HudTextColor:Dock(FILL) HudTextColor:Dock(FILL)
HudTextColor:SetPalette(true) HudTextColor:SetPalette(true)
@ -186,7 +190,7 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
end end
panel:AddItem(HudTextColor) panel:AddItem(HudTextColor)
panel:Help("HUD Corners Color") panel:Help("#beatrun.toolsmenu.hud.cornercolor")
local HudCornerColor = vgui.Create("DColorMixer", panel) local HudCornerColor = vgui.Create("DColorMixer", panel)
HudCornerColor:Dock(FILL) HudCornerColor:Dock(FILL)
HudCornerColor:SetPalette(true) HudCornerColor:SetPalette(true)
@ -198,7 +202,7 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
end end
panel:AddItem(HudCornerColor) panel:AddItem(HudCornerColor)
panel:Help("HUD Floating XP Color") panel:Help("#beatrun.toolsmenu.hud.floatxpcolor")
local HudFXPColor = vgui.Create("DColorMixer", panel) local HudFXPColor = vgui.Create("DColorMixer", panel)
HudFXPColor:Dock(FILL) HudFXPColor:Dock(FILL)
HudFXPColor:SetPalette(true) HudFXPColor:SetPalette(true)
@ -211,100 +215,115 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(HudFXPColor) panel:AddItem(HudFXPColor)
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_viewbob", "Viewbob", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_viewbob", "#beatrun.toolsmenu.viewbob.name", "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("Viewbob Settings") panel:SetName("#beatrun.toolsmenu.viewbob.desc")
panel:CheckBox("Viewbob Stabilization", "Beatrun_ViewbobStabilized") panel:CheckBox("#beatrun.toolsmenu.viewbob.stabilization", "Beatrun_ViewbobStabilized")
panel:ControlHelp("Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered") panel:ControlHelp("#beatrun.toolsmenu.viewbob.stabilizationdesc")
panel:NumSlider("Viewbob Intensity", "Beatrun_ViewbobIntensity", -100, 100, 0)
panel:NumSlider("#beatrun.toolsmenu.viewbob.intensity", "Beatrun_ViewbobIntensity", -100, 100, 0)
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_gameplay", "Gameplay", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Client", "beatrun_gameplay", "#beatrun.toolsmenu.gameplay.name", "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("Gameplay Settings") panel:SetName("#beatrun.toolsmenu.gameplay.desc")
panel:CheckBox("Quickturn", "Beatrun_QuickturnGround") panel:CheckBox("#beatrun.toolsmenu.gameplay.quickturnground", "Beatrun_QuickturnGround")
panel:ControlHelp("Enables quickturning with secondary attack while on the ground") panel:ControlHelp("#beatrun.toolsmenu.gameplay.quickturngrounddesc")
panel:CheckBox("Purist Mode", "Beatrun_PuristMode") panel:CheckBox("#beatrun.toolsmenu.gameplay.quickturnhandsonly", "Beatrun_QuickturnHandsOnly")
panel:ControlHelp("Purist mode is a clientside preference that severely weakens the ability to strafe while in the air, which is how Mirror's Edge games handle this.\nDisabled = No restrictions\nEnabled = Reduced move speed in the air") panel:ControlHelp("#beatrun.toolsmenu.gameplay.quickturnhandsonlydesc")
panel:CheckBox("Disable Grapple Ability", "Beatrun_DisableGrapple") panel:CheckBox("#beatrun.toolsmenu.gameplay.puristmode", "Beatrun_PuristMode")
panel:ControlHelp("Disables grapple ability") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.gameplay.puristmodedesc"))
panel:CheckBox("#beatrun.toolsmenu.gameplay.disablegrapple", "Beatrun_DisableGrapple")
panel:ControlHelp("#beatrun.toolsmenu.gameplay.disablegrappledesc")
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_main", "Main", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_misc", "#beatrun.toolsmenu.misc.name", "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("Misc Settings") panel:SetName("#beatrun.toolsmenu.misc.desc")
panel:CheckBox("Prop Spawning", "Beatrun_AllowPropSpawn") panel:CheckBox("#beatrun.toolsmenu.misc.propspawn", "Beatrun_AllowPropSpawn")
panel:ControlHelp("Allows players without admin rights to spawn props, entities and weapons") panel:ControlHelp("#beatrun.toolsmenu.misc.propspawndesc")
panel:CheckBox("Overdrive in Multiplayer", "Beatrun_AllowOverdriveInMultiplayer") panel:CheckBox("#beatrun.toolsmenu.misc.overdrivemp", "Beatrun_AllowOverdriveInMultiplayer")
panel:ControlHelp("Allows Overdrive usage on the server\nDoesn't affect singleplayer") panel:ControlHelp("#beatrun.toolsmenu.misc.overdrivempdesc")
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_moves", "Moves", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_moves", "#beatrun.toolsmenu.moves.name", "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("Moves Settings") panel:SetName("#beatrun.toolsmenu.moves.desc")
panel:Help("You Can Dive with Ctrl + RMB While Midair!\nOverdrive Toggles with E + LMB.") panel:Help(language.GetPhrase("beatrun.toolsmenu.moves.help"))
panel:CheckBox("Force Purist Mode", "Beatrun_PuristModeForce") panel:NumSlider("#beatrun.toolsmenu.moves.speedlimit", "Beatrun_SpeedLimit", 325, 1000, 0)
panel:ControlHelp("Forces Purist Mode for all players") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.speedlimitdesc"))
panel:CheckBox("\"Realistic\" wallrunning", "Beatrun_PuristWallrun") panel:CheckBox("#beatrun.toolsmenu.moves.forcepuristmode", "Beatrun_PuristModeForce")
panel:ControlHelp("You don't lose speed when starting wallrunning when disabled") panel:ControlHelp("#beatrun.toolsmenu.moves.forcepuristmodedesc")
panel:CheckBox("#beatrun.toolsmenu.moves.realisticwallrunning", "Beatrun_PuristWallrun")
panel:ControlHelp("#beatrun.toolsmenu.moves.realisticwallrunningdesc")
local divider = vgui.Create("DHorizontalDivider") local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider) panel:AddItem(divider)
panel:CheckBox("Kick-Glitch", "Beatrun_KickGlitch") panel:CheckBox("#beatrun.toolsmenu.moves.kickglitch", "Beatrun_KickGlitch")
panel:ControlHelp("Toggles Kick-Glitch Move\nLMB when Wallrunning and Then Jumping Right After") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.kickglitchdesc"))
panel:CheckBox("Kick-Glitch Version", "Beatrun_OldKickGlitch") panel:CheckBox("#beatrun.toolsmenu.moves.kickglitchversion", "Beatrun_OldKickGlitch")
panel:ControlHelp("Enabled - Old Kick-Glitch\nDisabled - New Kick-Glitch\nNew version uses mechanic from Mirror's Edge that spawns a small platform under a player") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.kickglitchversiondesc"))
panel:CheckBox("Quake Jump", "Beatrun_QuakeJump") panel:CheckBox("#beatrun.toolsmenu.moves.quakejump", "Beatrun_QuakeJump")
panel:ControlHelp("Toggles Quake Jump Move\nPress RMB Right After Side Step") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.quakejumpdesc"))
panel:CheckBox("Side Step", "Beatrun_SideStep") panel:CheckBox("#beatrun.toolsmenu.moves.sidestep", "Beatrun_SideStep")
panel:ControlHelp("Toggles Side Step Move\nA/D + RMB") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.sidestepdesc"))
panel:CheckBox("Disarm", "Beatrun_Disarm") panel:CheckBox("#beatrun.toolsmenu.moves.disarm", "Beatrun_Disarm")
panel:ControlHelp("Toggles Ability to Disarm NPC\nInteract with NPC") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.disarmdesc"))
local divider = vgui.Create("DHorizontalDivider") local divider = vgui.Create("DHorizontalDivider")
panel:AddItem(divider) panel:AddItem(divider)
panel:Help("Dive Settings") panel:Help("#beatrun.toolsmenu.moves.divesettings")
panel:CheckBox("Totsugeki", "Beatrun_Totsugeki") panel:CheckBox("#beatrun.toolsmenu.moves.totsugeki", "Beatrun_Totsugeki")
panel:ControlHelp("Toggles Totsugeki Move\nDive After Quake Jump") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.totsugekidesc"))
panel:CheckBox("Totsugeki Spam", "Beatrun_TotsugekiSpam") panel:CheckBox("#beatrun.toolsmenu.moves.totsugekispam", "Beatrun_TotsugekiSpam")
panel:ControlHelp("Toggles Ability to Spam Totsugeki") panel:ControlHelp("#beatrun.toolsmenu.moves.totsugekispamdesc")
panel:CheckBox("Totsugeki Heading", "Beatrun_TotsugekiHeading") panel:CheckBox("#beatrun.toolsmenu.moves.totsugekiheading", "Beatrun_TotsugekiHeading")
panel:ControlHelp("Allows to Totsugeki on X axis (up/down)") panel:ControlHelp("#beatrun.toolsmenu.moves.totsugekiheadingdesc")
panel:CheckBox("Totsugeki Direction", "Beatrun_TotsugekiDir") panel:CheckBox("#beatrun.toolsmenu.moves.totsugekidirection", "Beatrun_TotsugekiDir")
panel:ControlHelp("Allows to Totsugeki into Another Direction\nCombined with Spam and Heading Allows You to Fly =)") panel:ControlHelp(language.GetPhrase("beatrun.toolsmenu.moves.totsugekidirectiondesc"))
end) end)
spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_gamemodes", "Gamemodes", "", "", function(panel) spawnmenu.AddToolMenuOption("Beatrun", "Server", "beatrun_gamemodes", "#beatrun.toolsmenu.gamemodes.name", "", "", function(panel)
panel:ClearControls() panel:ClearControls()
panel:SetName("Gamemodes Settings") panel:SetName("#beatrun.toolsmenu.gamemodes.desc")
panel:NumSlider("#beatrun.toolsmenu.gamemodes.infectionstarttime", "Beatrun_InfectionStartTime", 5, 20, 0)
panel:Help("#beatrun.toolsmenu.gamemodes.infectiontime")
panel:NumSlider("#beatrun.toolsmenu.gamemodes.infectiongametime", "Beatrun_InfectionGameTime", 30, 600, 0)
panel:Help("#beatrun.toolsmenu.gamemodes.infectiontime")
local InfectionButton = vgui.Create("DButton", panel) local InfectionButton = vgui.Create("DButton", panel)
InfectionButton:SetText("Toggle Infection Gamemode") InfectionButton:SetText("#beatrun.toolsmenu.gamemodes.infection")
InfectionButton:SetSize(0, 20) InfectionButton:SetSize(0, 20)
InfectionButton.DoClick = function() InfectionButton.DoClick = function()
if GetGlobalBool("GM_DEATHMATCH") or GetGlobalBool("GM_DATATHEFT") then if GetGlobalBool("GM_DEATHMATCH") or GetGlobalBool("GM_DATATHEFT") then
InfectionButton:SetText("Another gamemode is running!") InfectionButton:SetText("#beatrun.toolsmenu.gamemodes.error")
timer.Simple(2, function() timer.Simple(2, function()
InfectionButton:SetText("Toggle Infection Gamemode") InfectionButton:SetText("#beatrun.toolsmenu.gamemodes.infection")
end) end)
return return
end end
@ -313,14 +332,16 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(InfectionButton) panel:AddItem(InfectionButton)
local DatatheftButton = vgui.Create("DButton", panel) local DatatheftButton = vgui.Create("DButton", panel)
DatatheftButton:SetText("Toggle Data Theft Gamemode") DatatheftButton:SetText("#beatrun.toolsmenu.gamemodes.datatheft")
DatatheftButton:SetSize(0, 20) DatatheftButton:SetSize(0, 20)
DatatheftButton.DoClick = function() DatatheftButton.DoClick = function()
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DEATHMATCH") then if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DEATHMATCH") then
DatatheftButton:SetText("Another gamemode is running!") DatatheftButton:SetText("#beatrun.toolsmenu.gamemodes.error")
timer.Simple(2, function() timer.Simple(2, function()
DatatheftButton:SetText("Toggle Data Theft Gamemode") DatatheftButton:SetText("#beatrun.toolsmenu.gamemodes.datatheft")
end) end)
return return
end end
@ -329,14 +350,16 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
panel:AddItem(DatatheftButton) panel:AddItem(DatatheftButton)
local DeathmatchButton = vgui.Create("DButton", panel) local DeathmatchButton = vgui.Create("DButton", panel)
DeathmatchButton:SetText("Toggle Deathmatch Gamemode") DeathmatchButton:SetText("#beatrun.toolsmenu.gamemodes.deathmatch")
DeathmatchButton:SetSize(0, 20) DeathmatchButton:SetSize(0, 20)
DeathmatchButton.DoClick = function() DeathmatchButton.DoClick = function()
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") then if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") then
DeathmatchButton:SetText("Another gamemode is running!") DeathmatchButton:SetText("#beatrun.toolsmenu.gamemodes.error")
timer.Simple(2, function() timer.Simple(2, function()
DeathmatchButton:SetText("Toggle Deathmatch Gamemode") DeathmatchButton:SetText("#beatrun.toolsmenu.gamemodes.deathmatch")
end) end)
return return
end end
@ -372,4 +395,4 @@ hook.Add("PopulateToolMenu", "Beatrun_ToolMenu", function()
-- end -- end
-- panel:AddItem(LoadoutMenuButton) -- panel:AddItem(LoadoutMenuButton)
end) end)
end) end)

View file

@ -2,8 +2,8 @@ local meta = FindMetaTable("Player")
local metavec = FindMetaTable("Vector") local metavec = FindMetaTable("Vector")
local PUNCH_DAMPING = 9 local PUNCH_DAMPING = 9
local PUNCH_SPRING_CONSTANT = 120 local PUNCH_SPRING_CONSTANT = 120
local viewbob_intensity = CreateClientConVar("Beatrun_ViewbobIntensity", "20", true, true, "Viewbob Intensity", -100, 100) local viewbob_intensity = CreateClientConVar("Beatrun_ViewbobIntensity", "20", true, true, language.GetPhrase("beatrun.convars.viewbob"), -100, 100)
local viewbob_stabilized = CreateClientConVar("Beatrun_ViewbobStabilized", "0", true, true, "Turn on to reduce motion sickness by making viewbobbing keep the player's look position centered", 0, 1) local viewbob_stabilized = CreateClientConVar("Beatrun_ViewbobStabilized", "0", true, true, language.GetPhrase("beatrun.convars.viewbobstabilization"), 0, 1)
local function lensqr(ang) local function lensqr(ang)
return ang[1] ^ 2 + ang[2] ^ 2 + ang[3] ^ 2 return ang[1] ^ 2 + ang[2] ^ 2 + ang[3] ^ 2

View file

@ -24,4 +24,4 @@ hook.Add("PostRender", "Watermark", function()
surface.DrawText(LocalPlayer():Nick()) surface.DrawText(LocalPlayer():Nick())
cam.End2D() cam.End2D()
end) end)
]] --]]

View file

@ -72,4 +72,4 @@ local function ToggleWhitescale()
end end
end end
concommand.Add("ToggleWhitescale", ToggleWhitescale) concommand.Add("Beatrun_ToggleWhitescale", ToggleWhitescale)

View file

@ -1,5 +1,4 @@
local meta = FindMetaTable("Player") local meta = FindMetaTable("Player")
-- local XP_max = 2000000
local XP_ratiocache = nil local XP_ratiocache = nil
local parkourevent_lastpos = Vector() local parkourevent_lastpos = Vector()

View file

@ -610,9 +610,8 @@ function ToggleBlindness(toggle)
if blinded then if blinded then
local ply = LocalPlayer() local ply = LocalPlayer()
local activewep = ply:GetActiveWeapon() local activewep = ply:GetActiveWeapon()
local usingrh = IsValid(activewep) and activewep:GetClass() == "runnerhands"
if usingrh and activewep.RunWind1 then if ply:UsingRH() and activewep.RunWind1 then
activewep.RunWind1:Stop() activewep.RunWind1:Stop()
activewep.RunWind2:Stop() activewep.RunWind2:Stop()
end end

View file

@ -1,5 +1,5 @@
include("shared.lua") include("shared.lua")
for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME", "nameasc")) do for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME")) do
include("cl/" .. v) include("cl/" .. v)
end end

View file

@ -2,18 +2,21 @@ AddCSLuaFile("cl_init.lua")
AddCSLuaFile("shared.lua") AddCSLuaFile("shared.lua")
include("shared.lua") include("shared.lua")
for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME", "nameasc")) do for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/cl/*.lua", "GAME")) do
print(v) print(v)
AddCSLuaFile("cl/" .. v) AddCSLuaFile("cl/" .. v)
end end
for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sh/*.lua", "GAME", "nameasc")) do for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sh/*.lua", "GAME")) do
print(v) print(v)
include("sh/" .. v)
AddCSLuaFile("sh/" .. v) AddCSLuaFile("sh/" .. v)
include("sh/" .. v)
end end
for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sv/*.lua", "GAME", "nameasc")) do for _, v in ipairs(file.Find("gamemodes/beatrun/gamemode/sv/*.lua", "GAME")) do
print(v) print(v)
include("sv/" .. v) include("sv/" .. v)
end end

View file

@ -319,7 +319,7 @@ end
hook.Add("EntityFireBullets", "thisengineismadebyacrackhead", function(ent, data) hook.Add("EntityFireBullets", "thisengineismadebyacrackhead", function(ent, data)
if not IsValid(ent) or not isfunction(ent.GetShootPos) or not ent:IsPlayer() then return end if not IsValid(ent) or not isfunction(ent.GetShootPos) or not ent:IsPlayer() then return end
for i, ply in ipairs(player.GetAll()) do for _, ply in ipairs(player.GetAll()) do
if ply == ent then continue end if ply == ent then continue end
local fov = calc_fov(data.Dir:Angle(), (ply:GetShootPos() - data.Src):Angle()) local fov = calc_fov(data.Dir:Angle(), (ply:GetShootPos() - data.Src):Angle())
@ -374,7 +374,7 @@ end
hook.Add("FinishMove", "BeatrunRHVelocity", function(ply, mv) hook.Add("FinishMove", "BeatrunRHVelocity", function(ply, mv)
local activewep = ply:GetActiveWeapon() local activewep = ply:GetActiveWeapon()
if IsValid(activewep) and activewep:GetClass() == "runnerhands" and activewep.SetOwnerVelocity then if ply:UsingRH() and activewep.SetOwnerVelocity then
activewep:SetOwnerVelocity(math.Round(mv:GetVelocity():Length())) activewep:SetOwnerVelocity(math.Round(mv:GetVelocity():Length()))
end end
end) end)

View file

@ -3,19 +3,6 @@ local playermeta = FindMetaTable("Player")
CLoadout = {} CLoadout = {}
function CLIENT_IFTP()
return CLIENT and IsFirstTimePredicted()
end
--[[
local matrixdatatmp = {
{0, 0, 0, 0},
{0, 0, 0, 0},
{0, 0, 0, 0},
{0, 0, 0, 1}
}
]]
local mtmp = { local mtmp = {
{0, 0, 0, 0}, {0, 0, 0, 0},
{0, 0, 0, 0}, {0, 0, 0, 0},
@ -81,5 +68,20 @@ end
function playermeta:UsingRH(wep) function playermeta:UsingRH(wep)
local activewep = wep or self:GetActiveWeapon() local activewep = wep or self:GetActiveWeapon()
if IsValid(activewep) then return activewep:GetClass() == "runnerhands" end
if IsValid(activewep) and activewep:GetClass() == "runnerhands" then
return true
else
return false
end
end
function playermeta:notUsingRH(wep)
local activewep = wep or self:GetActiveWeapon()
if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then
return true
else
return false
end
end end

View file

@ -1,6 +1,6 @@
if SERVER then local allowPropSpawn = CreateConVar("Beatrun_AllowPropSpawn", "0", {FCVAR_ARCHIVE})
local allowPropSpawn = CreateConVar("Beatrun_AllowPropSpawn", "0", {FCVAR_ARCHIVE}, "Allow players to spawn props and entities")
if SERVER then
util.AddNetworkString("SPParkourEvent") util.AddNetworkString("SPParkourEvent")
local spawn = {"PlayerGiveSWEP", "PlayerSpawnEffect", "PlayerSpawnNPC", "PlayerSpawnObject", "PlayerSpawnProp", "PlayerSpawnRagdoll", "PlayerSpawnSENT", "PlayerSpawnSWEP", "PlayerSpawnVehicle"} local spawn = {"PlayerGiveSWEP", "PlayerSpawnEffect", "PlayerSpawnNPC", "PlayerSpawnObject", "PlayerSpawnProp", "PlayerSpawnRagdoll", "PlayerSpawnSENT", "PlayerSpawnSWEP", "PlayerSpawnVehicle"}
@ -9,7 +9,7 @@ if SERVER then
if not ply:IsAdmin() and not allowPropSpawn:GetBool() then return false end if not ply:IsAdmin() and not allowPropSpawn:GetBool() then return false end
end end
for k, v in ipairs(spawn) do for _, v in ipairs(spawn) do
hook.Add(v, "BlockSpawn", BlockSpawn) hook.Add(v, "BlockSpawn", BlockSpawn)
end end
@ -21,18 +21,18 @@ if SERVER then
end end
if CLIENT then if CLIENT then
CreateClientConVar("Beatrun_FOV", 100, true, true, "'Woah how are you moving this fast' and other hilarious jokes", 70, 120) CreateClientConVar("Beatrun_FOV", 100, true, true, language.GetPhrase("beatrun.convars.fov"), 70, 120)
CreateClientConVar("Beatrun_CPSave", 1, true, true, "Respawning during a course will go back to the last hit checkpoint", 0, 1) CreateClientConVar("Beatrun_CPSave", 1, true, true, language.GetPhrase("beatrun.convars.cpsave"), 0, 1)
end end
hook.Add("PlayerNoClip", "BlockNoClip", function(ply, enabled) hook.Add("PlayerNoClip", "BlockNoClip", function(ply, enabled)
if enabled and Course_Name ~= "" and ply:GetNW2Int("CPNum", 1) ~= -1 then if enabled and Course_Name ~= "" and ply:GetNW2Int("CPNum", 1) ~= -1 then
ply:SetNW2Int("CPNum", -1) ply:SetNW2Int("CPNum", -1)
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
notification.AddLegacy("Noclip Detected! Respawn to restart the course", NOTIFY_ERROR, 4) notification.AddLegacy(language.GetPhrase("beatrun.misc.noclipdetected"), NOTIFY_ERROR, 4)
elseif SERVER and game.SinglePlayer() then elseif SERVER and game.SinglePlayer() then
ply:SendLua("notification.AddLegacy(\"Noclip Detected! Respawn to restart the course\", NOTIFY_ERROR, 4)") ply:SendLua("notification.AddLegacy(\"#beatrun.misc.noclipdetected\", NOTIFY_ERROR, 4)")
end end
end end
@ -70,9 +70,7 @@ hook.Add("SetupMove", "JumpDetect", function(ply, mv, cmd)
end end
end end
local activewep = ply:GetActiveWeapon() if ply:UsingRH() then
if IsValid(activewep) and activewep:GetClass() == "runnerhands" then
ply:SetWasOnGround(ply:OnGround()) ply:SetWasOnGround(ply:OnGround())
return return
@ -106,11 +104,11 @@ hook.Add("SetupMove", "JumpDetect", function(ply, mv, cmd)
end) end)
hook.Add("CanProperty", "BlockProperty", function(ply) hook.Add("CanProperty", "BlockProperty", function(ply)
if not ply:IsSuperAdmin() then return false end if not ply:IsAdmin() then return false end
end) end)
hook.Add("CanDrive", "BlockDrive", function(ply) hook.Add("CanDrive", "BlockDrive", function(ply)
if not ply:IsSuperAdmin() then return false end if not ply:IsAdmin() then return false end
end) end)
if CLIENT and game.SinglePlayer() then if CLIENT and game.SinglePlayer() then
@ -161,4 +159,4 @@ if CLIENT then
impactblurlerp = intensity impactblurlerp = intensity
lastintensity = intensity lastintensity = intensity
end end
end end

View file

@ -2,6 +2,7 @@ soundAdd_old = sound.Add
local function soundAdd_detour(tbl) local function soundAdd_detour(tbl)
if not tbl.name then return end if not tbl.name then return end
soundAdd_old(tbl) soundAdd_old(tbl)
timer.Simple(2, function() timer.Simple(2, function()

View file

@ -75,7 +75,7 @@ hook.Add("SetupMove", "Balance", function(ply, mv, cmd)
ParkourEvent("walkbalancestill", ply) ParkourEvent("walkbalancestill", ply)
end end
if CLIENT_IFTP() and mv:KeyPressed(IN_ATTACK2) then if CLIENT and IsFirstTimePredicted() and mv:KeyPressed(IN_ATTACK2) then
dircache.y = dircache.y - 180 dircache.y = dircache.y - 180
end end

View file

@ -1,23 +1,28 @@
local mousex = 0 local mousex = 0
local mousey = 0 local mousey = 0
local inf = math.huge local inf = math.huge
buildmode_props = {} buildmode_props = {}
local propmatsblacklist = {} local propmatsblacklist = {}
local blocksdir = "models/hunter/blocks/" local blocksdir = "models/hunter/blocks/"
local blocksdir_s = blocksdir .. "*.mdl" local blocksdir_s = blocksdir .. "*.mdl"
for k, v in ipairs(file.Find(blocksdir_s, "GAME")) do
for _, v in ipairs(file.Find(blocksdir_s, "GAME")) do
table.insert(buildmode_props, blocksdir .. v:lower()) table.insert(buildmode_props, blocksdir .. v:lower())
end end
local blocksdir = "models/hunter/triangles/" local blocksdir = "models/hunter/triangles/"
local blocksdir_s = blocksdir .. "*.mdl" local blocksdir_s = blocksdir .. "*.mdl"
for k, v in ipairs(file.Find(blocksdir_s, "GAME")) do
for _, v in ipairs(file.Find(blocksdir_s, "GAME")) do
table.insert(buildmode_props, blocksdir .. v:lower()) table.insert(buildmode_props, blocksdir .. v:lower())
end end
local blocksdir = "models/props_phx/construct/glass/" local blocksdir = "models/props_phx/construct/glass/"
local blocksdir_s = blocksdir .. "*.mdl" local blocksdir_s = blocksdir .. "*.mdl"
for k, v in ipairs(file.Find(blocksdir_s, "GAME")) do
for _, v in ipairs(file.Find(blocksdir_s, "GAME")) do
local key = table.insert(buildmode_props, blocksdir .. v:lower()) local key = table.insert(buildmode_props, blocksdir .. v:lower())
propmatsblacklist[key] = true propmatsblacklist[key] = true
end end
@ -323,9 +328,6 @@ if SERVER then
util.AddNetworkString("BuildMode_Sync") util.AddNetworkString("BuildMode_Sync")
util.AddNetworkString("Course_Stop") util.AddNetworkString("Course_Stop")
buildmodelogs = {}
local buildmodelogs = buildmodelogs
function Course_Sync() function Course_Sync()
net.Start("BuildMode_Sync") net.Start("BuildMode_Sync")
net.WriteFloat(Course_StartPos.x) net.WriteFloat(Course_StartPos.x)
@ -423,10 +425,6 @@ if SERVER then
end end
table.insert(buildmode_placed, a) table.insert(buildmode_placed, a)
local bmlog = tostring(ply) .. " placed " .. tostring(a)
table.insert(buildmodelogs, bmlog)
end) end)
net.Receive("BuildMode_Duplicate", function(len, ply) net.Receive("BuildMode_Duplicate", function(len, ply)
@ -435,7 +433,7 @@ if SERVER then
local selected = net.ReadTable() local selected = net.ReadTable()
local selectedents = net.ReadTable() local selectedents = net.ReadTable()
for k, v in pairs(selected) do for _, v in pairs(selected) do
local a = ents.Create("prop_physics") local a = ents.Create("prop_physics")
a:SetModel(v:GetModel()) a:SetModel(v:GetModel())
@ -456,17 +454,13 @@ if SERVER then
a:SetHealth(inf) a:SetHealth(inf)
end end
for k, v in pairs(selectedents) do for _, v in pairs(selectedents) do
local a = ents.Create(v:GetClass()) local a = ents.Create(v:GetClass())
a:SetPos(v:GetPos()) a:SetPos(v:GetPos())
a:SetAngles(v:GetAngles()) a:SetAngles(v:GetAngles())
a:Spawn() a:Spawn()
end end
local bmlog = tostring(ply) .. " duped " .. tostring(table.Count(selected)) .. " props"
table.insert(buildmodelogs, bmlog)
end) end)
net.Receive("BuildMode_Delete", function(len, ply) net.Receive("BuildMode_Delete", function(len, ply)
@ -474,15 +468,11 @@ if SERVER then
local selected = net.ReadTable() local selected = net.ReadTable()
for k, v in pairs(selected) do for _, v in pairs(selected) do
if IsValid(v) then if IsValid(v) then
v:Remove() v:Remove()
end end
end end
local bmlog = tostring(ply) .. " deleted " .. tostring(table.Count(selected)) .. " entities"
table.insert(buildmodelogs, bmlog)
end) end)
net.Receive("BuildMode_Highlight", function(len, ply) net.Receive("BuildMode_Highlight", function(len, ply)
@ -490,7 +480,7 @@ if SERVER then
local selected = net.ReadTable() local selected = net.ReadTable()
for k, v in pairs(selected) do for _, v in pairs(selected) do
v.hr = not v.hr v.hr = not v.hr
CustomPropMat(v) CustomPropMat(v)
@ -508,10 +498,10 @@ if SERVER then
net.Receive("BuildMode_ReadSave", function(len, ply) net.Receive("BuildMode_ReadSave", function(len, ply)
if not ply.BuildMode then return end if not ply.BuildMode then return end
local a = util.Decompress(net.ReadData(len)) local a = net.ReadData(len)
local props = util.JSONToTable(a) local props = util.JSONToTable(a)
for k, v in pairs(props) do for _, v in pairs(props) do
local a = ents.Create("prop_physics") local a = ents.Create("prop_physics")
a:SetModel(buildmode_props[v.model]) a:SetModel(buildmode_props[v.model])
@ -611,7 +601,7 @@ if SERVER then
local name = data[5] local name = data[5]
local entities = data[6] local entities = data[6]
for k, v in pairs(props) do for _, v in pairs(props) do
local a = ents.Create("prop_physics") local a = ents.Create("prop_physics")
a.hr = v.hr a.hr = v.hr
a:SetModel(buildmode_props[v.model]) a:SetModel(buildmode_props[v.model])
@ -629,7 +619,7 @@ if SERVER then
a:SetHealth(inf) a:SetHealth(inf)
end end
for k, v in ipairs(cp) do for _, v in ipairs(cp) do
LoadCheckpoints() LoadCheckpoints()
local a = ents.Create("tt_cp") local a = ents.Create("tt_cp")
@ -641,7 +631,7 @@ if SERVER then
end end
if entities then if entities then
for k, v in ipairs(entities) do for _, v in ipairs(entities) do
local a = ents.Create(v.ent) local a = ents.Create(v.ent)
local dontsetpos = nil local dontsetpos = nil
@ -666,7 +656,7 @@ if SERVER then
Course_Sync() Course_Sync()
for k, v in pairs(player.GetAll()) do for _, v in pairs(player.GetAll()) do
v:SetNW2Float("PBTime", 0) v:SetNW2Float("PBTime", 0)
v:SetNW2Int("CPNum", 1) v:SetNW2Int("CPNum", 1)
v:SetMoveType(MOVETYPE_WALK) v:SetMoveType(MOVETYPE_WALK)
@ -898,7 +888,7 @@ if CLIENT then
function CourseData(name) function CourseData(name)
local save = {{}, {}, Course_StartPos, Course_StartAng, name or "Unnamed", {}} local save = {{}, {}, Course_StartPos, Course_StartAng, name or "Unnamed", {}}
for k, v in pairs(buildmode_placed) do for _, v in pairs(buildmode_placed) do
if not IsValid(v) then -- Nothing if not IsValid(v) then -- Nothing
elseif v:GetNW2Bool("BRProtected") then elseif v:GetNW2Bool("BRProtected") then
print("ignoring protected ent") print("ignoring protected ent")
@ -930,7 +920,7 @@ if CLIENT then
end end
end end
for k, v in ipairs(Checkpoints) do for _, v in ipairs(Checkpoints) do
table.insert(save[2], v:GetPos()) table.insert(save[2], v:GetPos())
end end
@ -958,7 +948,6 @@ if CLIENT then
concommand.Add("Beatrun_SaveCourse", function(ply, cmd, args, argstr) concommand.Add("Beatrun_SaveCourse", function(ply, cmd, args, argstr)
local name = args[1] or "Unnamed" local name = args[1] or "Unnamed"
-- local compress = not args[2]
SaveCourse(name, args[2]) SaveCourse(name, args[2])
end) end)
@ -1155,24 +1144,13 @@ if CLIENT then
end end
end, end,
[KEY_BACKSPACE] = function() [KEY_BACKSPACE] = function()
if not dragging then buildmodeinputs[KEY_DELETE]()
local props = {}
for k, v in pairs(buildmode_selected) do
table.insert(props, k)
buildmode_selected[k] = nil
end
net.Start("BuildMode_Delete")
net.WriteTable(props)
net.SendToServer()
end
end, end,
[KEY_T] = function() [KEY_T] = function()
if not dragging then if not dragging then
local props = {} local props = {}
for k, v in pairs(buildmode_selected) do for k, _ in pairs(buildmode_selected) do
if not propmatsblacklist[buildmode_props_index[k:GetModel()]] then if not propmatsblacklist[buildmode_props_index[k:GetModel()]] then
table.insert(props, k) table.insert(props, k)
end end
@ -1216,7 +1194,7 @@ if CLIENT then
end end
end end
end, end,
[KEY_ENTER] = function() [KEY_PAD_MINUS] = function()
if table.Count(buildmode_selected) == 0 then return end if table.Count(buildmode_selected) == 0 then return end
local save = {} local save = {}
@ -1239,7 +1217,7 @@ if CLIENT then
local jsonsave = util.TableToJSON(save) local jsonsave = util.TableToJSON(save)
file.CreateDir("beatrun/savedbuilds") file.CreateDir("beatrun/savedbuilds")
file.Write("beatrun/savedbuilds/save.txt", util.Compress(jsonsave)) file.Write("beatrun/savedbuilds/save.txt", jsonsave)
end, end,
[KEY_PAD_PLUS] = function() [KEY_PAD_PLUS] = function()
local save = file.Read("beatrun/savedbuilds/save.txt", "DATA") local save = file.Read("beatrun/savedbuilds/save.txt", "DATA")
@ -1453,7 +1431,7 @@ if CLIENT then
cam.Start3D() cam.Start3D()
for k, v in ipairs(buildmode_placed) do for _, v in ipairs(buildmode_placed) do
if IsValid(v) and not v:GetNW2Bool("BRProtected") then if IsValid(v) and not v:GetNW2Bool("BRProtected") then
local pos = v:GetRenderOrigin() or v:GetPos() local pos = v:GetRenderOrigin() or v:GetPos()
local w2s = pos:ToScreen() local w2s = pos:ToScreen()
@ -1546,7 +1524,7 @@ if CLIENT then
surface.SetFont("DebugFixed") surface.SetFont("DebugFixed")
surface.SetTextColor(255, 255, 255) surface.SetTextColor(255, 255, 255)
for k, v in pairs(Checkpoints) do for _, v in pairs(Checkpoints) do
if not IsValid(v) then if not IsValid(v) then
LoadCheckpoints() LoadCheckpoints()
@ -1557,7 +1535,7 @@ if CLIENT then
local num = v:GetCPNum() local num = v:GetCPNum()
surface.SetTextPos(w2s.x, w2s.y) surface.SetTextPos(w2s.x, w2s.y)
surface.DrawText(num) surface.DrawText("Checkpoint: " .. num)
end end
local startw2s = Course_StartPos:ToScreen() local startw2s = Course_StartPos:ToScreen()
@ -1637,4 +1615,4 @@ if CLIENT then
hook.Run("BuildModeState", false) hook.Run("BuildModeState", false)
end end
end) end)
end end

View file

@ -44,28 +44,28 @@ function LoadCheckpoints()
table.Empty(Checkpoints) table.Empty(Checkpoints)
if SERVER then if SERVER then
for k, v in pairs(player.GetAll()) do for _, v in pairs(player.GetAll()) do
v:SetNW2Int("CPNum", 1) v:SetNW2Int("CPNum", 1)
end end
end end
if CLIENT then if CLIENT then
timer.Simple(1, function() timer.Simple(1, function()
for k, v in pairs(ents.FindByClass("tt_cp")) do for _, v in pairs(ents.FindByClass("tt_cp")) do
if IsValid(v) and v.GetCPNum then if IsValid(v) and v.GetCPNum then
Checkpoints[v:GetCPNum()] = v Checkpoints[v:GetCPNum()] = v
end end
end end
end) end)
else else
for k, v in pairs(ents.FindByClass("tt_cp")) do for _, v in pairs(ents.FindByClass("tt_cp")) do
Checkpoints[v:GetCPNum()] = v Checkpoints[v:GetCPNum()] = v
end end
end end
end end
if CLIENT then if CLIENT then
CreateClientConVar("Beatrun_FastStart", "0", true, true, "Faster start countdown", 0, 1) CreateClientConVar("Beatrun_FastStart", "0", true, true, language.GetPhrase("beatrun.convars.faststart"), 0, 1)
net.Receive("Checkpoint_Hit", function() net.Receive("Checkpoint_Hit", function()
local timetaken = CurTime() - lastcptime local timetaken = CurTime() - lastcptime
@ -181,7 +181,11 @@ end
local countdown = 0 local countdown = 0
local countdownalpha = 255 local countdownalpha = 255
local countdowntext = {"Ready", "Set", "Go!!"} local countdowntext = {
"#beatrun.checkpoints.countdown1",
"#beatrun.checkpoints.countdown2",
"#beatrun.checkpoints.countdown3"
}
local function StartCountdown() local function StartCountdown()
local CT = CurTime() local CT = CurTime()
@ -243,7 +247,8 @@ function CourseHUD()
speed = "0" .. speed speed = "0" .. speed
end end
text = speed .. " km/h" text = language.GetPhrase("beatrun.checkpoints.speedometer"):format(speed)
local w, _ = surface.GetTextSize(text) local w, _ = surface.GetTextSize(text)
w = w or 0 w = w or 0

View file

@ -159,7 +159,7 @@ local function ClimbingThink(ply, mv, cmd)
ParkourEvent("hangend", ply) ParkourEvent("hangend", ply)
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
lockang2 = false lockang2 = false
lockang = false lockang = false
BodyLimitX = 90 BodyLimitX = 90
@ -182,7 +182,7 @@ local function ClimbingThink(ply, mv, cmd)
ply:SetSafetyRollKeyTime(CurTime() + 0.1) ply:SetSafetyRollKeyTime(CurTime() + 0.1)
ParkourEvent("hangjump", ply) ParkourEvent("hangjump", ply)
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
lockang2 = false lockang2 = false
lockang = false lockang = false
BodyLimitX = 90 BodyLimitX = 90
@ -649,11 +649,7 @@ local function ClimbingCheck(ply, mv, cmd)
local activewep = ply:GetActiveWeapon() local activewep = ply:GetActiveWeapon()
if IsValid(activewep) then if ply:UsingRH() and activewep.SendWeaponAnim then
usingrh = activewep:GetClass() == "runnerhands"
end
if usingrh and activewep.SendWeaponAnim then
activewep:SendWeaponAnim(ACT_VM_HITCENTER) activewep:SendWeaponAnim(ACT_VM_HITCENTER)
activewep:SetBlockAnims(false) activewep:SetBlockAnims(false)
end end
@ -716,7 +712,7 @@ local function ClimbingCheck(ply, mv, cmd)
ply:EmitSound("Handsteps.ConcreteHard") ply:EmitSound("Handsteps.ConcreteHard")
ply:EmitSound("Cloth.RollLand") ply:EmitSound("Cloth.RollLand")
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
ply.OrigEyeAng = wallang ply.OrigEyeAng = wallang
lockang2 = true lockang2 = true

View file

@ -4,7 +4,7 @@ local problematichooks = {
local function RemoveConflicting() local function RemoveConflicting()
for k, v in pairs(problematichooks) do for k, v in pairs(problematichooks) do
for l, b in ipairs(v) do for _, b in ipairs(v) do
hook.Remove(k, b) hook.Remove(k, b)
end end
end end

View file

@ -1,4 +1,3 @@
local usingrh = nil
local punch = Angle(0.5, 0, 0) local punch = Angle(0.5, 0, 0)
local punchland = Angle(10, 0, 0.5) local punchland = Angle(10, 0, 0.5)
local punchthink = Angle() local punchthink = Angle()
@ -30,13 +29,9 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
ply:SetCrouchJumpBlocked(false) ply:SetCrouchJumpBlocked(false)
end end
local activewep = ply:GetActiveWeapon()
if ply:Alive() and not ply:GetCrouchJumpBlocked() and not IsValid(ply:GetZipline()) and not IsValid(ply:GetLadder()) and ply:GetClimbing() == 0 and not ply:GetJumpTurn() and ply:GetMantle() == 0 and not ply:OnGround() and ply:GetVelocity().z > -350 and ply:GetCrouchJumpTime() < CurTime() and ply:GetWallrun() == 0 and mv:KeyPressed(IN_DUCK) then if ply:Alive() and not ply:GetCrouchJumpBlocked() and not IsValid(ply:GetZipline()) and not IsValid(ply:GetLadder()) and ply:GetClimbing() == 0 and not ply:GetJumpTurn() and ply:GetMantle() == 0 and not ply:OnGround() and ply:GetVelocity().z > -350 and ply:GetCrouchJumpTime() < CurTime() and ply:GetWallrun() == 0 and mv:KeyPressed(IN_DUCK) then
local activewep = ply:GetActiveWeapon()
if IsValid(activewep) then
usingrh = activewep:GetClass() == "runnerhands"
end
if CLIENT then if CLIENT then
local ang = ply:EyeAngles() local ang = ply:EyeAngles()
ang.x = 0 ang.x = 0
@ -47,7 +42,7 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
BodyAnimCycle = 0 BodyAnimCycle = 0
BodyAnimCrouchLerp = 0 BodyAnimCrouchLerp = 0
if usingrh then if ply:UsingRH() then
BodyAnimCrouchLerpZ = mv:GetOrigin().z - 32 BodyAnimCrouchLerpZ = mv:GetOrigin().z - 32
else else
BodyAnimCrouchLerpZ = mv:GetOrigin().z BodyAnimCrouchLerpZ = mv:GetOrigin().z
@ -70,16 +65,10 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
ply:ViewPunch(punch) ply:ViewPunch(punch)
ply:SetViewOffsetDucked(Vector(0, 0, 28)) ply:SetViewOffsetDucked(Vector(0, 0, 28))
if usingrh then if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_HOLSTER) activewep:SendWeaponAnim(ACT_VM_HOLSTER)
end end
elseif (ply:OnGround() or ply:GetCrouchJumpTime() < CurTime() or not ply:Alive()) and ply:GetCrouchJump() then elseif (ply:OnGround() or ply:GetCrouchJumpTime() < CurTime() or not ply:Alive()) and ply:GetCrouchJump() then
local activewep = ply:GetActiveWeapon()
if IsValid(activewep) then
usingrh = activewep:GetClass() == "runnerhands"
end
if game.SinglePlayer() then if game.SinglePlayer() then
net.Start("CrouchJumpSP") net.Start("CrouchJumpSP")
net.WriteBool(false) net.WriteBool(false)
@ -88,7 +77,7 @@ hook.Add("SetupMove", "CrouchJump", function(ply, mv, cmd)
ply:SetCrouchJump(false) ply:SetCrouchJump(false)
if usingrh and IsValid(activewep) then if ply:UsingRH() then
activewep:SendWeaponAnim(ACT_VM_DRAW) activewep:SendWeaponAnim(ACT_VM_DRAW)
end end

View file

@ -1,4 +1,3 @@
GM_DATATHEFT = 0
DATATHEFT_LOADOUTS = { DATATHEFT_LOADOUTS = {
{"weapon_357", "weapon_ar2"} {"weapon_357", "weapon_ar2"}
} }
@ -87,7 +86,7 @@ if CLIENT then
if GetGlobalBool("GM_DATATHEFT") then if GetGlobalBool("GM_DATATHEFT") then
local datacubes = LocalPlayer():GetNW2Int("DataCubes", 0) local datacubes = LocalPlayer():GetNW2Int("DataCubes", 0)
return "Data Theft (" .. datacubes .. ")" return language.GetPhrase("beatrun.datatheft.name"):format(datacubes)
else else
hook.Remove("BeatrunHUDCourse", "DataTheftHUDName") hook.Remove("BeatrunHUDCourse", "DataTheftHUDName")
end end
@ -99,6 +98,6 @@ if CLIENT then
net.Receive("DataTheft_Start", function() net.Receive("DataTheft_Start", function()
hook.Add("BeatrunHUDCourse", "DataTheftHUDName", DataTheftHUDName) hook.Add("BeatrunHUDCourse", "DataTheftHUDName", DataTheftHUDName)
chat.AddText(Color(200, 200, 200), "Data Theft! Kill players to collect data, deposit data in banks") chat.AddText(Color(200, 200, 200), language.GetPhrase("beatrun.datatheft.start"))
end) end)
end end

View file

@ -1,5 +1,3 @@
GM_DEATHMATCH = 0
if SERVER then if SERVER then
util.AddNetworkString("Deathmatch_Start") util.AddNetworkString("Deathmatch_Start")
util.AddNetworkString("Deathmatch_Sync") util.AddNetworkString("Deathmatch_Sync")
@ -17,7 +15,8 @@ if SERVER then
else else
for _, b in ipairs(DATATHEFT_LOADOUTS[math.random(#DATATHEFT_LOADOUTS)]) do for _, b in ipairs(DATATHEFT_LOADOUTS[math.random(#DATATHEFT_LOADOUTS)]) do
local wep = v:Give(b) local wep = v:Give(b)
v:GiveAmmo(1000, wep:GetPrimaryAmmoType())
v:GiveAmmo(9999, wep:GetPrimaryAmmoType() or "Pistol", true)
end end
end end
end end
@ -66,7 +65,7 @@ end
if CLIENT then if CLIENT then
local function DeathmatchHUDName() local function DeathmatchHUDName()
if GetGlobalBool("GM_DEATHMATCH") then if GetGlobalBool("GM_DEATHMATCH") then
return "Deathmatch" return "#beatrun.deathmatch.name"
else else
hook.Remove("BeatrunHUDCourse", "DeathmatchHUDName") hook.Remove("BeatrunHUDCourse", "DeathmatchHUDName")
end end
@ -78,6 +77,6 @@ if CLIENT then
net.Receive("Deathmatch_Start", function() net.Receive("Deathmatch_Start", function()
hook.Add("BeatrunHUDCourse", "DeathmatchHUDName", DeathmatchHUDName) hook.Add("BeatrunHUDCourse", "DeathmatchHUDName", DeathmatchHUDName)
chat.AddText(Color(200, 200, 200), "Deathmatch! Kill players to get points!") chat.AddText(Color(200, 200, 200), language.GetPhrase("beatrun.deathmatch.start"))
end) end)
end end

View file

@ -1,7 +1,7 @@
local totsugeki = CreateConVar("Beatrun_Totsugeki", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Oh no...", 0, 1) local totsugeki = CreateConVar("Beatrun_Totsugeki", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
local totsugekispam = CreateConVar("Beatrun_TotsugekiSpam", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "OH NO...", 0, 1) local totsugekispam = CreateConVar("Beatrun_TotsugekiSpam", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
local totsugekiheading = CreateConVar("Beatrun_TotsugekiHeading", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Can we dive on the x axis?", 0, 1) local totsugekiheading = CreateConVar("Beatrun_TotsugekiHeading", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
local totsugekidir = CreateConVar("Beatrun_TotsugekiDir", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "Can we dive into another dir?", 0, 1) local totsugekidir = CreateConVar("Beatrun_TotsugekiDir", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 0, 1)
local function Dive(ply, mv, cmd) local function Dive(ply, mv, cmd)
if (not ply:GetDive() or ply:GetDive() and ply.QuakeJumping and totsugeki:GetBool() and totsugekispam:GetBool()) and ply:GetCrouchJump() and mv:KeyPressed(IN_ATTACK2) then if (not ply:GetDive() or ply:GetDive() and ply.QuakeJumping and totsugeki:GetBool() and totsugekispam:GetBool()) and ply:GetCrouchJump() and mv:KeyPressed(IN_ATTACK2) then
@ -37,7 +37,7 @@ local function Dive(ply, mv, cmd)
effectdata:SetOrigin(vPoint) effectdata:SetOrigin(vPoint)
util.Effect("WaterSurfaceExplosion", effectdata) util.Effect("WaterSurfaceExplosion", effectdata)
elseif CLIENT_IFTP() then elseif CLIENT and IsFirstTimePredicted() then
local vPoint = mv:GetOrigin() local vPoint = mv:GetOrigin()
local effectdata = EffectData() local effectdata = EffectData()

View file

@ -1,5 +1,6 @@
local quakejump = CreateConVar("Beatrun_QuakeJump", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE}) local quakejump = CreateConVar("Beatrun_QuakeJump", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
local sidestep = CreateConVar("Beatrun_SideStep", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE}) local sidestep = CreateConVar("Beatrun_SideStep", 1, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
local speed_limit = CreateConVar("Beatrun_SpeedLimit", 325, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
local function Hardland(jt) local function Hardland(jt)
local ply = LocalPlayer() local ply = LocalPlayer()
@ -16,6 +17,7 @@ local function Hardland(jt)
end end
DoJumpTurn(jt) DoJumpTurn(jt)
BodyAnim:SetSequence("jumpturnflyidle") BodyAnim:SetSequence("jumpturnflyidle")
else else
BodyAnim:SetSequence("jumpcoilend") BodyAnim:SetSequence("jumpcoilend")
@ -34,8 +36,7 @@ if game.SinglePlayer() and CLIENT then
end end
hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking) hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking)
local activewep = ply:GetActiveWeapon() local sprint = ply:GetMEMoveLimit() < speed_limit:GetInt() - 25
local sprint = ply:GetMEMoveLimit() < 300
local stepmod = ply:GetStepRight() and 1 or -1 local stepmod = ply:GetStepRight() and 1 or -1
local stepvel = 1.25 local stepvel = 1.25
local stepvel2 = 1 local stepvel2 = 1
@ -49,7 +50,7 @@ hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking)
local stepmod2 = 1 local stepmod2 = 1
local stepmod3 = 1 local stepmod3 = 1
if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then if ply:notUsingRH() then
stepmod2 = 0.25 stepmod2 = 0.25
if not ply:IsSprinting() then if not ply:IsSprinting() then
@ -57,7 +58,7 @@ hook.Add("PlayerStepSoundTime", "MEStepTime", function(ply, step, walking)
end end
end end
if not ply:Crouching() and not ply:KeyDown(IN_WALK) then if not ply:Crouching() and not walking then
if game.SinglePlayer() then if game.SinglePlayer() then
local intensity = ply:GetInfoNum("Beatrun_ViewbobIntensity", 20) / 20 local intensity = ply:GetInfoNum("Beatrun_ViewbobIntensity", 20) / 20
@ -92,7 +93,7 @@ hook.Add("PlayerFootstep", "MEStepSound", function(ply, pos, foot, sound, volume
ply:SetStepRight(not ply:GetStepRight()) ply:SetStepRight(not ply:GetStepRight())
if (ply:GetSliding() or CurTime() < ply:GetSafetyRollTime() - 0.5) and not skipcheck then return true end if (ply:GetSliding() or CurTime() < ply:GetSafetyRollTime() - 0.5) and not skipcheck then return true end
if ply:GetMEMoveLimit() < 155 and ply:KeyDown(IN_FORWARD) and not ply.FootstepLand and not IsValid(ply:GetBalanceEntity()) then return true end if ply:GetMEMoveLimit() < 100 and ply:KeyDown(IN_FORWARD) and not ply.FootstepLand and not IsValid(ply:GetBalanceEntity()) then return true end
local mat = sound:sub(0, -6) local mat = sound:sub(0, -6)
local newsound = FOOTSTEPS_LUT[mat] local newsound = FOOTSTEPS_LUT[mat]
@ -124,11 +125,11 @@ hook.Add("PlayerFootstep", "MEStepSound", function(ply, pos, foot, sound, volume
ply:EmitSound("Footsteps.Water") ply:EmitSound("Footsteps.Water")
end end
if ply:InOverdrive() and ply:GetVelocity():Length() > 300 then if ply:InOverdrive() and ply:GetVelocity():Length() > 400 then
ply:EmitSound("Footsteps.Spark") ply:EmitSound("Footsteps.Spark")
end end
if (CLIENT_IFTP() or game.SinglePlayer()) and ply.FootstepLand then if (CLIENT and IsFirstTimePredicted() or game.SinglePlayer()) and ply.FootstepLand then
local landsound = FOOTSTEPS_LAND_LUT[mat] or "Concrete" local landsound = FOOTSTEPS_LAND_LUT[mat] or "Concrete"
ply:EmitSound("Land." .. landsound) ply:EmitSound("Land." .. landsound)
@ -157,7 +158,7 @@ hook.Add("OnPlayerHitGround", "MELandSound", function(ply, water, floater, speed
ParkourEvent("land", ply) ParkourEvent("land", ply)
if ply:GetMelee() == MELEE_DROPKICK and ply:GetMeleeTime() < CurTime() and vel:Length() < 300 then if ply:GetMelee() == MELEE_DROPKICK and ply:GetMeleeTime() < CurTime() and vel:Length() < 300 then
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
Hardland(false) Hardland(false)
elseif SERVER and game.SinglePlayer() then elseif SERVER and game.SinglePlayer() then
net.Start("Beatrun_HardLand") net.Start("Beatrun_HardLand")
@ -185,7 +186,7 @@ hook.Add("OnPlayerHitGround", "MELandSound", function(ply, water, floater, speed
ply:SetJumpTurn(true) ply:SetJumpTurn(true)
end end
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
Hardland(jt) Hardland(jt)
elseif SERVER and game.SinglePlayer() then elseif SERVER and game.SinglePlayer() then
net.Start("Beatrun_HardLand") net.Start("Beatrun_HardLand")
@ -210,8 +211,7 @@ hook.Add("OnPlayerHitGround", "MELandSound", function(ply, water, floater, speed
end) end)
hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd) hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local activewep = ply:GetActiveWeapon() local usingrh = ply:UsingRH()
local usingrh = IsValid(activewep) and activewep:GetClass() == "runnerhands"
local ismoving = (mv:KeyDown(IN_FORWARD) or not ply:OnGround() or ply:Crouching()) and not mv:KeyDown(IN_BACK) and ply:Alive() and (mv:GetVelocity():Length() > 50 or ply:GetMantle() ~= 0 or ply:Crouching()) local ismoving = (mv:KeyDown(IN_FORWARD) or not ply:OnGround() or ply:Crouching()) and not mv:KeyDown(IN_BACK) and ply:Alive() and (mv:GetVelocity():Length() > 50 or ply:GetMantle() ~= 0 or ply:Crouching())
if (CLIENT or game.SinglePlayer()) and CurTime() > (ply:GetStepRelease() or 0) and ply.FootstepReleaseLand then if (CLIENT or game.SinglePlayer()) and CurTime() > (ply:GetStepRelease() or 0) and ply.FootstepReleaseLand then
@ -229,12 +229,12 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
ply.FootstepLand = true ply.FootstepLand = true
end end
if ply:GetRunSpeed() ~= 325 * ply:GetOverdriveMult() then if ply:GetRunSpeed() ~= speed_limit:GetInt() * ply:GetOverdriveMult() then
ply:SetRunSpeed(325 * ply:GetOverdriveMult()) ply:SetRunSpeed(speed_limit:GetInt() * ply:GetOverdriveMult())
end end
if not ply:GetMEMoveLimit() then if not ply:GetMEMoveLimit() then
ply:SetMEMoveLimit(150) ply:SetMEMoveLimit(speed_limit:GetInt())
ply:SetMESprintDelay(0) ply:SetMESprintDelay(0)
ply:SetMEAng(0) ply:SetMEAng(0)
end end
@ -246,8 +246,6 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
ply:SetMEMoveLimit(150) ply:SetMEMoveLimit(150)
ply:SetMESprintDelay(0) ply:SetMESprintDelay(0)
ply:SetMEAng(0) ply:SetMEAng(0)
-- mv:SetButtons(bit.band(mv:GetButtons(), bit.bnot(IN_JUMP)))
end end
local ang = mv:GetAngles() local ang = mv:GetAngles()
@ -259,14 +257,14 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local weaponspeed = 150 local weaponspeed = 150
local activewep = ply:GetActiveWeapon() local activewep = ply:GetActiveWeapon()
if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then if ply:notUsingRH() then
weaponspeed = 250 weaponspeed = speed_limit:GetInt()
end end
if (ismoving or ply:GetMantle() ~= 0) and ply:GetMESprintDelay() < CurTime() and (cmd:KeyDown(IN_SPEED) or ply:GetMantle() ~= 0 or not ply:OnGround() or (not ply:OnGround() or ply:GetMantle() ~= 0) and mv:GetVelocity().z > -450) then if (ismoving or ply:GetMantle() ~= 0) and ply:GetMESprintDelay() < CurTime() and (cmd:KeyDown(IN_SPEED) or ply:GetMantle() ~= 0 or not ply:OnGround() or (not ply:OnGround() or ply:GetMantle() ~= 0) and mv:GetVelocity().z > -450) then
local mult = 0.6 + math.abs(ply:GetMEMoveLimit() / 300 - 1) local mult = 0.6 + math.abs(ply:GetMEMoveLimit() / (speed_limit:GetInt() - 25) - 1)
if not ply:InOverdrive() and ply:GetMEMoveLimit() > 225 then if not ply:InOverdrive() and ply:GetMEMoveLimit() > (speed_limit:GetInt() - 100) then
mult = mult * 0.35 mult = mult * 0.35
end end
@ -274,9 +272,9 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
mult = mult * ply:GetMEMoveLimit() / 1000 mult = mult * ply:GetMEMoveLimit() / 1000
end end
ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() + mult * ply:GetOverdriveMult() * 2, 0, 325 * ply:GetOverdriveMult())) ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() + mult * ply:GetOverdriveMult() * 2, 0, speed_limit:GetInt() * ply:GetOverdriveMult()))
elseif not ismoving and (not ply:Crouching() or ply:GetCrouchJump()) or CurTime() < ply:GetMESprintDelay() and ply:OnGround() then elseif not ismoving and (not ply:Crouching() or ply:GetCrouchJump()) or CurTime() < ply:GetMESprintDelay() and ply:OnGround() then
ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() - 40, weaponspeed, 325 * ply:GetOverdriveMult())) ply:SetMEMoveLimit(math.Clamp(ply:GetMEMoveLimit() - 40, weaponspeed, speed_limit:GetInt() * ply:GetOverdriveMult()))
end end
if MEAngDiff > 1.25 and ply:GetWallrun() == 0 then if MEAngDiff > 1.25 and ply:GetWallrun() == 0 then
@ -288,9 +286,9 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local stepheight = mv:GetOrigin().z - (ply.LastOrigin or vector_origin).z local stepheight = mv:GetOrigin().z - (ply.LastOrigin or vector_origin).z
if stepheight > 1.5 then if stepheight > 1.5 then
ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), 250, FrameTime() * 100)) ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), speed_limit:GetInt() - 75, FrameTime() * 100))
elseif stepheight < -0.8 then elseif stepheight < -0.8 then
ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), 400, FrameTime() * 100)) ply:SetMEMoveLimit(math.Approach(ply:GetMEMoveLimit(), speed_limit:GetInt() + 75, FrameTime() * 100))
end end
end end
@ -310,7 +308,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
activewep:SendWeaponAnim(ACT_TURNLEFT45) activewep:SendWeaponAnim(ACT_TURNLEFT45)
activewep:SetSideStep(true) activewep:SetSideStep(true)
mv:SetVelocity(cmd:GetViewAngles():Right() * -600) mv:SetVelocity(cmd:GetViewAngles():Right() * -(speed_limit:GetInt() * 1.8))
ply:ViewPunch(Angle(-3, 0, -4.5)) ply:ViewPunch(Angle(-3, 0, -4.5))
@ -325,7 +323,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
activewep:SendWeaponAnim(ACT_TURNRIGHT45) activewep:SendWeaponAnim(ACT_TURNRIGHT45)
activewep:SetSideStep(true) activewep:SetSideStep(true)
mv:SetVelocity(cmd:GetViewAngles():Right() * 600) mv:SetVelocity(cmd:GetViewAngles():Right() * (speed_limit:GetInt() * 1.8))
ply:ViewPunch(Angle(-3, 0, 4.5)) ply:ViewPunch(Angle(-3, 0, 4.5))
@ -341,7 +339,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
local forwarddelta = activewep.SideStepDir:Dot(ang:Forward()) local forwarddelta = activewep.SideStepDir:Dot(ang:Forward())
if forwarddelta > 0.35 then if forwarddelta > 0.35 then
ply:SetMEMoveLimit(250) ply:SetMEMoveLimit(speed_limit:GetInt())
end end
if forwarddelta < 0.65 then if forwarddelta < 0.65 then
@ -356,7 +354,7 @@ hook.Add("SetupMove", "MESetupMove", function(ply, mv, cmd)
if mv:KeyPressed(IN_JUMP) and not quakejump:GetBool() and activewep:GetWasOnGround() and not ply:GetJumpTurn() and ply:GetViewModel():GetCycle() < 0.25 then if mv:KeyPressed(IN_JUMP) and not quakejump:GetBool() and activewep:GetWasOnGround() and not ply:GetJumpTurn() and ply:GetViewModel():GetCycle() < 0.25 then
local vel = mv:GetVelocity() local vel = mv:GetVelocity()
vel:Mul(0.75) vel:Mul(0.75)
vel.z = -300 vel.z = -speed_limit:GetInt() + 25
mv:SetVelocity(vel) mv:SetVelocity(vel)
@ -370,7 +368,6 @@ if CLIENT then
hook.Add("CreateMove", "MECreateMove", function(cmd) hook.Add("CreateMove", "MECreateMove", function(cmd)
local ply = LocalPlayer() local ply = LocalPlayer()
local usingrh = ply:UsingRH()
local hardland = CurTime() < (ply.hardlandtime or 0) local hardland = CurTime() < (ply.hardlandtime or 0)
if hardland and not ply:InOverdrive() then if hardland and not ply:InOverdrive() then
@ -379,7 +376,7 @@ if CLIENT then
cmd:SetSideMove(cmd:GetSideMove() * 0.01) cmd:SetSideMove(cmd:GetSideMove() * 0.01)
end end
if (ply:InOverdrive() or usingrh and ply:GetMoveType() == MOVETYPE_WALK and not hardland and ply:OnGround()) and not cmd:KeyDown(IN_SPEED) and not ply:GetSliding() and not IsValid(ply:GetBalanceEntity()) then if (ply:InOverdrive() or ply:UsingRH() and ply:GetMoveType() == MOVETYPE_WALK and not hardland and ply:OnGround()) and not cmd:KeyDown(IN_SPEED) and not ply:GetSliding() and not IsValid(ply:GetBalanceEntity()) then
cmd:SetButtons(cmd:GetButtons() + IN_SPEED) cmd:SetButtons(cmd:GetButtons() + IN_SPEED)
end end
end) end)
@ -396,7 +393,7 @@ if CLIENT then
vel = vector_origin vel = vector_origin
end end
if vel:Length() > 300 then if vel:Length() > speed_limit:GetInt() + 75 then
ply.blurspeed = Lerp(0.001, ply.blurspeed, 0.1) ply.blurspeed = Lerp(0.001, ply.blurspeed, 0.1)
elseif ply:GetMantle() == 0 then elseif ply:GetMantle() == 0 then
ply.blurspeed = math.Approach(ply.blurspeed, 0, 0.005) ply.blurspeed = math.Approach(ply.blurspeed, 0, 0.005)

View file

@ -1,18 +1,15 @@
local disable_grapple = CreateClientConVar("Beatrun_DisableGrapple", 0, true, true, "Disables grapple ability", 0, 1)
if CLIENT then if CLIENT then
local disable_grapple = CreateClientConVar("Beatrun_DisableGrapple", 0, true, true, language.GetPhrase("beatrun.convars.disablegrapple"), 0, 1)
local circle = Material("circlesmooth.png", "nocull smooth") local circle = Material("circlesmooth.png", "nocull smooth")
hook.Add("HUDPaint", "grappleicon", function() hook.Add("HUDPaint", "grappleicon", function()
local ply = LocalPlayer() local ply = LocalPlayer()
if disable_grapple:GetBool() then return end if disable_grapple:GetBool() and Course_Name == "" then return end
if ply:GetMantle() ~= 0 or ply:GetClimbing() ~= 0 then return end if ply:GetMantle() ~= 0 or ply:GetClimbing() ~= 0 then return end
if not ply:Alive() or Course_Name ~= "" then return end if not ply:Alive() or Course_Name ~= "" then return end
if ply:notUsingRH() then return end
local activewep = ply:GetActiveWeapon()
if IsValid(activewep) and activewep:GetClass() ~= "runnerhands" then return end
if ply:GetMoveType() == MOVETYPE_NOCLIP then return end if ply:GetMoveType() == MOVETYPE_NOCLIP then return end
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") or GetGlobalBool("GM_DEATHMATCH") then return end if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") or GetGlobalBool("GM_DEATHMATCH") then return end
@ -60,8 +57,7 @@ hook.Add("SetupMove", "Grapple", function(ply, mv, cmd)
if not ply:Alive() or Course_Name ~= "" and ply:GetNW2Int("CPNum", 1) ~= -1 and not ply:GetNW2Entity("Swingrope"):IsValid() then return end if not ply:Alive() or Course_Name ~= "" and ply:GetNW2Int("CPNum", 1) ~= -1 and not ply:GetNW2Entity("Swingrope"):IsValid() then return end
if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") or GetGlobalBool("GM_DEATHMATCH") and not ply:GetNW2Entity("Swingrope"):IsValid() then return end if GetGlobalBool("GM_INFECTION") or GetGlobalBool("GM_DATATHEFT") or GetGlobalBool("GM_DEATHMATCH") and not ply:GetNW2Entity("Swingrope"):IsValid() then return end
local activewep = ply:GetActiveWeapon() local usingrh = ply:UsingRH()
local usingrh = IsValid(activewep) and activewep:GetClass() == "runnerhands"
if not ply.Grapple_tr then if not ply.Grapple_tr then
ply.Grapple_tr = {} ply.Grapple_tr = {}
@ -91,7 +87,7 @@ hook.Add("SetupMove", "Grapple", function(ply, mv, cmd)
ply:SetNW2Entity("grappleEntity", trout.Entity) ply:SetNW2Entity("grappleEntity", trout.Entity)
ply:SetNW2Bool("grappledNonCourse", true) ply:SetNW2Bool("grappledNonCourse", true)
if CLIENT_IFTP() or game.SinglePlayer() then if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("MirrorsEdge/Gadgets/ME_Magrope_Fire.wav", 40, 100 + math.random(-25, 10)) ply:EmitSound("MirrorsEdge/Gadgets/ME_Magrope_Fire.wav", 40, 100 + math.random(-25, 10))
end end
@ -131,7 +127,7 @@ hook.Add("SetupMove", "Grapple", function(ply, mv, cmd)
ply:SetGrappling(false) ply:SetGrappling(false)
if CLIENT_IFTP() or game.SinglePlayer() then if CLIENT and IsFirstTimePredicted() or game.SinglePlayer() then
ply:EmitSound("MirrorsEdge/zipline_detach.wav", 40, 100 + math.random(-25, 10)) ply:EmitSound("MirrorsEdge/zipline_detach.wav", 40, 100 + math.random(-25, 10))
end end

View file

@ -1,7 +1,9 @@
GM_INFECTION = 0
Infection_StartTime = 0 Infection_StartTime = 0
Infection_EndTime = 0 Infection_EndTime = 0
local startTime = CreateConVar("Beatrun_InfectionStartTime", 10, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 5, 20)
local gameTime = CreateConVar("Beatrun_InfectionGameTime", 190, {FCVAR_REPLICATED, FCVAR_ARCHIVE}, "", 30, 600)
function table.Shuffle(t) function table.Shuffle(t)
local n = #t local n = #t
@ -18,7 +20,7 @@ end
local function HumanCount() local function HumanCount()
local count = 0 local count = 0
for k, v in ipairs(player.GetAll()) do for _, v in ipairs(player.GetAll()) do
if IsValid(v) and not v:GetNW2Bool("Infected") then if IsValid(v) and not v:GetNW2Bool("Infected") then
count = count + 1 count = count + 1
end end
@ -240,8 +242,8 @@ if SERVER then
end end
end end
Infection_StartTime = CurTime() + 10 Infection_StartTime = CurTime() + startTime:GetInt()
Infection_EndTime = CurTime() + 190 Infection_EndTime = CurTime() + gameTime:GetInt()
hook.Add("Think", "InfectionTimer", InfectionTimer) hook.Add("Think", "InfectionTimer", InfectionTimer)
end end
@ -284,7 +286,7 @@ if SERVER then
if timeremaining <= 70 and timeremaining >= 50 and player.GetCount() > 6 and humancount == 1 then if timeremaining <= 70 and timeremaining >= 50 and player.GetCount() > 6 and humancount == 1 then
timer.Simple(0.1, function() timer.Simple(0.1, function()
for k, v in ipairs(player.GetAll()) do for _, v in ipairs(player.GetAll()) do
if v:Alive() and not v:GetNW2Bool("Infected") then if v:Alive() and not v:GetNW2Bool("Infected") then
net.Start("Infection_LastMan") net.Start("Infection_LastMan")
net.Send(v) net.Send(v)
@ -307,7 +309,7 @@ if CLIENT then
local function InfectionHUDName() local function InfectionHUDName()
if GetGlobalBool("GM_INFECTION") then if GetGlobalBool("GM_INFECTION") then
local team = LocalPlayer():GetNW2Bool("Infected") and "(Infected)" or "(Human)" local team = LocalPlayer():GetNW2Bool("Infected") and language.GetPhrase("beatrun.infection.infectedtext") or language.GetPhrase("beatrun.infection.humantext")
return "Infection " .. team return "Infection " .. team
else else
@ -371,13 +373,13 @@ if CLIENT then
noclipkey = input.GetKeyCode(noclipbind) noclipkey = input.GetKeyCode(noclipbind)
endtime = 0 endtime = 0
Infection_StartTime = start + 10 Infection_StartTime = start + startTime:GetInt()
Infection_EndTime = start + 190 Infection_EndTime = start + gameTime:GetInt()
hook.Add("BeatrunHUDCourse", "InfectionHUDName", InfectionHUDName) hook.Add("BeatrunHUDCourse", "InfectionHUDName", InfectionHUDName)
hook.Add("CalcView", "InfectionCalcView", InfectionCalcView) hook.Add("CalcView", "InfectionCalcView", InfectionCalcView)
chat.AddText(chatcolor, "Infection! Touch other players to infect them\n", math.max(math.floor(player.GetCount() / 4), 1) .. " player(s) will become infected in 10s") chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.start"):format(math.max(math.floor(player.GetCount() / 4), 1), startTime:GetInt()))
end) end)
local music = nil local music = nil
@ -400,12 +402,12 @@ if CLIENT then
survivors = survivors:sub(1, -3) survivors = survivors:sub(1, -3)
if survivors == "" then if survivors == "" then
survivors = "None..." survivors = language.GetPhrase("beatrun.infection.nosurvivors")
LocalPlayer():EmitSound("death.wav") LocalPlayer():EmitSound("death.wav")
end end
chat.AddText(chatcolor, "The game has ended!\nSurvivors: " .. survivors .. "\nRestarting in 15s") chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.end"):format(survivors, _time))
end) end)
if music and music.Stop then if music and music.Stop then
@ -433,9 +435,9 @@ if CLIENT then
if IsValid(attacker) and IsValid(victim) then if IsValid(attacker) and IsValid(victim) then
if attacker == victim then if attacker == victim then
chat.AddText(attacker, red, " died!") chat.AddText(attacker, red, " " .. language.GetPhrase("beatrun.infection.infected"))
else else
chat.AddText(attacker, red, " has infected ", yellow, victim, "!") chat.AddText(attacker, red, " " .. language.GetPhrase("beatrun.infection.infectedby") .. " ", yellow, victim, "!")
end end
attacker.InfectionTouchDelay = CurTime() + 3 attacker.InfectionTouchDelay = CurTime() + 3
@ -498,10 +500,10 @@ if CLIENT then
if humanwin then if humanwin then
LocalPlayer():AddXP(200) LocalPlayer():AddXP(200)
chat.AddText(chatcolor, "You were awarded 200 XP for surviving") chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.award"))
else else
LocalPlayer():AddXP(100) LocalPlayer():AddXP(100)
chat.AddText(chatcolor, "You were awarded 100 XP for spawning as an infected") chat.AddText(chatcolor, language.GetPhrase("beatrun.infection.awardinfected"))
end end
end) end)

View file

@ -36,7 +36,7 @@ local function LadderCheck(ply, mv, cmd, ladder)
ply:SendLua("BodyAnimSetEase(LocalPlayer():GetNW2Vector('SPBAEase'))") ply:SendLua("BodyAnimSetEase(LocalPlayer():GetNW2Vector('SPBAEase'))")
end end
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
local ang = ply:EyeAngles() local ang = ply:EyeAngles()
ang.y = ladder:GetAngles().y - 180 ang.y = ladder:GetAngles().y - 180
ang.x = 0 ang.x = 0
@ -141,7 +141,7 @@ local function LadderThink(ply, mv, cmd, ladder)
elseif ply.LadderDown and ply:GetLadderDelay() < CurTime() then elseif ply.LadderDown and ply:GetLadderDelay() < CurTime() then
ply.LadderDown = false ply.LadderDown = false
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
ply:CLViewPunch(Angle(5, 0, 0)) ply:CLViewPunch(Angle(5, 0, 0))
BodyAnim:SetSequence("ladderclimbuprighthandstill") BodyAnim:SetSequence("ladderclimbuprighthandstill")
elseif game.SinglePlayer() then elseif game.SinglePlayer() then
@ -233,7 +233,7 @@ local function LadderThink(ply, mv, cmd, ladder)
mv:SetOrigin(newpos) mv:SetOrigin(newpos)
mv:SetVelocity(vector_origin) mv:SetVelocity(vector_origin)
if CLIENT_IFTP() then if CLIENT and IsFirstTimePredicted() then
BodyAnim:SetSequence("jumpfast") BodyAnim:SetSequence("jumpfast")
elseif game.SinglePlayer() then elseif game.SinglePlayer() then
ply:SendLua("BodyAnim:SetSequence('jumpfast')") ply:SendLua("BodyAnim:SetSequence('jumpfast')")

Some files were not shown because too many files have changed in this diff Show more