LeagueRecord isn't endorsed by Riot Games and doesn't reflect the views or opinions of Riot Games or anyone officially involved in producing or managing Riot Games properties. Riot Games, and all associated properties are trademarks or registered trademarks of Riot Games, Inc.
LeagueRecord automatically detects when a League of Legends game is running and records it.
Currently only supports Windows.
Downloads are available on the Releases page as an installer (*.msi file) or as a portable version (*.zip file)
LeagueRecord launches minimized to the windows tray to get out of your way.
Right-clicking the LeagueRecord tray item opens a menu.
- The topmost grayed out "Recording" entry has a checkmark next to it if your game is currently being recorded.
- The 'Settings' button opens the LeagueRecord settings in the windows text editor. See Settings for more information.
- The 'Open' button opens a window that shows you all your recordings.
- The 'Quit' button stops LeagueRecord completely.
Double left-clicking the LeagueRecord tray icon or clicking 'right-click' -> 'Open' in the tray menu opens a window that shows all your recordings.
There are 3 parts to the window.
- At the top left there is a small info that shows you how much space your recordings take up as well as a box with a button to open the folder in which your recordings are stored.
- On the left side under the info box there is a list of all you recordings. The name of each recording is the timestamp of the game. Clicking on a recording shows it in the right part of the window. When moving your mouse over a recording there is a button to mark a recording as a 'favorite' (see Settings). There are also buttons to rename or delete a recording.
- The right part of the window shows the currently selected recording with some information about the game at the bottom. The timeline of the video includes colored markers for the most important events that happened in the game. In case you don't want to see ALL events because they clutter the timeline you can enable/disable them by clicking the corresponding checkbox on the bottom right.
Just closing the window doesn't completely stop LeagueRecord because it needs to run in the background to record your games. In order to completely stop LeagueRecord you have to right-click the tray-icon at the bottom right of your screen and click the 'Quit' button.
Note
A bunch of stuff can be customized in the Settings. Video resolution, framerate, record voice-comms or only game audio, autostart LeagueRecord when you turn on your PC, ...
Note
In case LeagueRecord only records a black screen instead of the game, try running the software as Admin. That should fix the Problem!
Key | Function |
---|---|
Space | Play/Pause |
Arrow Right | +5 seconds |
Arrow Left | -5 seconds |
Shift + Arrow Right | next event |
Shift + Arrow Left | previous event |
Arrow Up | +10% volume |
Arrow Down | -10% volume |
f | toggle fullscreen |
m | toggle mute |
> | +0.25 playbackrate |
< | -0.25 playbackrate |
Esc | exit fullscreen |
It is possible to adjust the settings via the settings button in the tray menu.
It opens the settings file in the windows text editor.
Settings get applied as soon as you save and close the text editor.
If you write an invalid setting or delete an entry it gets reset to the default value.
Name | Value | Default | Description |
---|---|---|---|
recordingsFolder | String (only characters that can be in a filename) | {System Video Folder}/league_recordings | The name of the folder in which the recordings are stored. Relative paths are appended to your default video folder. |
filenameFormat | String (with special placeholders) | %Y-%m-%d_%H-%M.mp4 | Format string for naming new recordings. Can contain special placeholders in order to make each name unique. If a new recording has the same name as an already existing recording, the old recording gets overwritten! |
encodingQuality | positive whole number from 0-50 | 30 | Determines the size vs. quality tradeoff for the mp4 files. Zero means best encoding quality with a big filesize. 50 means heavily compressed with a small filesize. |
outputResolution | ['480p', '720p', '1080p', '1440p', '2160p', '4320p'] | null | null | Sets the output resolution of the recordings to a fixed resolution. If null uses the resolution of the LoL ingame window. |
outputFramerate | [whole number > 0, whole number > 0] | 30 | Sets the framerate of the recordings as a fraction (numerator/denominator). e.g. [30, 1] => 30fps, [30, 2] => 15fps |
recordAudio | 'NONE' | 'APPLICATION' | 'SYSTEM' | ALL | APPLICATION | Determines what audio gets recorded. 'NONE' records no audio. 'APPLICATION' records only the games' audio. 'SYSTEM' records all sound output of your pc (e.g music in the background). 'ALL' records everything that 'SYSTEM' records but also your microphone input. |
markerFlags | { 'kill', 'death', 'assist', 'turret', 'inhibitor', 'dragon', 'herald', 'baron' } : true | false | all true | Choose which events are shown by default in the timeline when playing a recording. |
checkForUpdates | true | false | true | Determines if on start LeagueRecord checks for new releases on GitHub |
debugLog | true | false | false | If true prints logs to the console and saves it to a log file names after the current date in %APPDATA%/fx.LeagueRecord/logs/ |
autostart | true | false | false | If true runs LeagueRecord when you start your PC |
onlyRecordRanked | true | false | false | If true only records Solo/DuoQ and FlexQ games |
maxRecordingAgeDays | positive numbers | null | null | Recordings that are not marked as favorites (golden star) get deleted after X days. null means disabled. |
maxRecordingsSizeGb | positive numbers | null | null | Recordings that are not marked as favorites (golden star) get deleted if the size of all your recordings exceeds this number (in Gigabytes). null means disabled. |
LeagueRecord takes up ~70MB of your disk space with most of that coming from the libobs dependency.
On a system with a Ryzen 3600 CPU and RX5700 GPU these are the performance numbers measured with Windows Taskmanager.
CPU | RAM | GPU | |
---|---|---|---|
idle | ~0% | ~5MB | 0% |
record | ~3% | ~50MB | ~4% |
watch recording | ~2.5% | ~160MB | ~2.5% |
The high RAM usage when watching a recording is due to using a WebView2 Window for the UI, which basically is a Chromium version that is pre-installed on most windows PCs. UIs are easy to make with HTML + some CSS. It also keeps the program size small and the common case - running hidden in the taskbar - efficient.
This is just a rough estimate with the default settings so you can get a sense for how much resources LeagueRecord uses.
There is a release for Windows-x64, but you can build the project on your own.
You need the cargo tauri CLI: cargo install tauri
, NPM and the nightly Rust toolchain rustup toolchain install nightly
.
Build the project with cargo tauri build
to create an msi installer.
In order to pack the compiles files into a standalone archive, run the following commands after a successful cargo tauri build
:
tar -cvzf LeagueRecord.tar.gz -C ./target/release/ ./licenses/ ./libobs/ ./LeagueRecord.exe
or
cd target/release
7z a -tzip LeagueRecord.zip ./licenses/ ./libobs/ ./LeagueRecord.exe
The libobs library is licensed under the GNU General Public License v2 (GPLv2).
The Javascript library videojs is licensed under the Apache License v2.0 and the plugin video-js markers is licensed under the MIT License.
This project (LeagueRecord) is distributed under the GNU General Public License v3 (GPLv3).
In case you have any problems, suggestions or questions feel free to open an issue or email me at fffffffxxxxxxxfffffffxxxxxxx@gmail.com.