User:Ashe/Sandbox2
Contents
Requirements
- Being able to run TF2 at a resolution of 1920x1080 or higher (must be 16:9 ratio), at more than 60 frames per second, on medium settings or higher, with DirectX 9, and at least 4x multisample anti-aliasing (MSAA), and recording with any screen recording programs at the same time.
- Preferably, you should use mastercomfig with at least the "High" preset with the following changes: Shadows: High, Model quality: Ultra, Texture quality: Ultra, Player Model: Disabled, Contracts: Disabled, Match HUD: Disabled, HUD Achievements: Disabled, no modifying anything in the Weapons tab.
- In TF2's launch options (see the article for more info), use
-dxlevel 95
and-no_texture_stream
(disables texture streaming).
- Having the item you want to demonstrate. No name tag, no description tag, no craft number, no gifted item, and no Community quality. Item quality preference will be Normal > Unique > Vintage or Genuine > Other quality. Exceptions can be made for items that cannot exist in any of these qualities. If an item is more abundant or more easily obtainable in a different quality than these (e.g. Haunted quality for Halloween items), that alternate quality is also acceptable. If the item can be sprayed on, don't spray anything on it.
- Note: If you edit your game's files there must not be any way for viewers to tell that you did so (identical item level, plausible quality, same attributes, non-visibly-edited loadout screen). This guide will not provide any help on doing that.
- Some knowledge about TF2, console commands, how to use any screen recording software, and video editing software.
Preparation
- Reserve the item demonstration first on the talk page! Check Talk page reservations section for how and why. If you don't have a TF Wiki account yet, you would probably want register one now at the top right corner of the page.
- Download necessary custom files: weaponref.zip. This can be extracted using 7zip or WinRAR. The
weaponref
folder and VPK file go into<your team fortress 2 folder>/tf/custom
. - Set your game to appropriate graphic settings.
- Disable any custom files you may have, such as custom HUDs, custom configs, sounds, models; the included
demonstration_hud.vpk
will override custom HUDs. The only exception are mastercomfig's files (the VPK and the CFG files) - Make a backup of your
tf/cfg
folder! Several cvars will be changed when executing the required config files (for example, the value ofcl_hud_playerclass_use_playermodel
, the 3D character in the HUD, will be overwritten to use the 2D character), and you may want to keep your preferences. Once you are done with recording the clips, you can delete your cfg folder and replace it with the backup. - Disable the Steam overlay or go offline; quiet or quit all background applications that may interfere with the recording, specially ones that have overlays (such as Discord, Mumble or TeamSpeak) or notification sounds (such as Discord or WhatsApp).
- The video should be recorded on
tr_karma
(preferred) ortr_target_weaponref_hdr
(legacy, still acceptable if reusing.dem
replays recorded on it or if you have performance issues with the other maps). All maps are included in the download. Open the console and type:map tr_karma
ormap tr_target_weaponref_hdr
. - Once the map has loaded, pick the class corresponding to the item you want to demonstrate.
- Before doing the demonstration, use the
A
loadout. Make sure the only thing equipped is the item that you want to demonstrate (possible exceptions are item that are meant to be demonstrated together, for example, Jarate + Bushwacka). Leave all other item slots with the default item that comes in these slots or empty. If you are demonstrating a taunt, equip it in the first slot and leave all others spaces empty. If you are demonstrating an item set, only equip the pertinent items. - Wait for the setup time to finish and verify that your new loadout has been equipped (by taunting).
- Open the console (default key: `) and type
exec tr_karma_basic
. The config file will change some of your settings to meet recording standard, such as FOV, HUD settings, etc., and some server cvars.
For weapons, if you execute thetr_karma_4bots
config file, four bots should spawn: A Pyro in front of you, a Soldier on the right side at mid-range, a Medic on the left side at long-range, and a Spy behind the crates on the left side (not visible by default). Re-executing the file will respawn all the bots at the correct location, in case you mess up. Pressing F makes the bots fire. - Open your Loadout, click the item you want to demonstrate, and equip it again so that your avatar equips it in the loadout preview. Rotate it to show off the item.
- Move your mouse over the item slot and wait for the tooltip to appear.
Things to consider:
- Always have auto-reloading disabled (
cl_autoreload 0
). - Some demonstration videos may require a split-screen. Try running the game in a window at a half-width (
-w 960 -h 1080 -windowed -noborder
, for 1920x1080 screens) or third-width resolution (-w 640 -h 1080 -windowed -noborder
). If you use Source Recorder, you can record a demo at normal full resolution, then relaunch the game at half-width resolution and render the demo from it.- Some HUD elements may break with third-width resolution. If so, ask for help in the Talk page.
- If the item you will demonstrate has a holiday restriction (e.g. Halloween / Full Moon), set
tf_forced_holiday
to the proper value in order to use that item. See below for a list of values. Specifically, usetf_forced_holiday 8
(Full Moon) for Halloween-restricted items.
Post-processing
- You may not modify the contrast, speed, size, etc. of the video.
- Add one of the
training_vid_*.mp3
files extracted from.../steam/steamapps/common/Team Fortress 2/tf/tf2_sound_misc_dir.vpk → sound → misc
. If necessary, adjust the relative volumes between music and in-game sounds to match the ratio of the reference video. The default volume should be okay though. You can also use this set of pre-lengthened music files by Karmacharger. - Edit your video so it's just like the video already on the channel. Add fade out effects to the end of the video, at the start of the video, and before and after every scene transition.
- Export/Convert your video to a web-friendly format: It is recommended that you use HEVC/h265 compression. Only 60 FPS videos are accepted (FPS are capped to 60 in YouTube).
Useful information
Below is a list of console commands that might help when demonstrating more complex behaviors. Most of these work only when sv_cheats
has been set to 1.
Map chat commands
As of December 2023, tr_karma
includes vscripts that can be used via the chat typing the following commands. Remember that the chat is hidden if you executed tr_karma.cfg and can only be seen if you open it.
!c
- Toggles a critical boost on the user.!n
- Togglesnoclip
on the user.!am
- Spawns a large ammo pack at the player's crosshair.!r
- Regenerates the player (gives health and ammo).
You can bind a key to one of the commands as follows: bind "kp_end" "say !c"
.
General console commands
bind <key> <command>
- Binds a key to a command. Use this to use one of the below commands without opening the console window (for final take) if you don't want to edit it out.impulse 101
- Restores the player's health and ammo.hurtme <number>
- Deals the stated amount of damage to the player. Can be used with a negative number to heal or overheal yourself.getpos
- Displays the current position and rotation (aiming angle) of the player in x, y, and z coordinates.setpos <x y z>
- Teleports the player to a given position. Use the numbers acquired fromgetpos
to place yourself into that same exact position.setang <x y z>
- Sets the view angle of the player, akin tosetpos
. Use with the numbers fromgetpos
to make your crosshair point the exact same way. The<z>
parameter should be left at 0, or else the camera will appear to be tilting onto its side.ent_create <entity name>
- Spawns a health kit or ammo box at the player's crosshair when used with entity namesitem_ammopack_small
,item_ammopack_medium
,item_ammopack_full
,item_healthkit_small
,item_healthkit_medium
, oritem_healthkit_full
.
- To make the process easier, you can use this script, which binds the spawning of health kits and ammo boxes to Numpad keys.
mp_restartgame 1
- Restarts the map without rebooting the server, as opposed to themap
command. You can use it with the name of the current map to reload the map, cleaning it of bodies, excess blood, and bullet marks.r_cleardecals
- Clears all decals (blood and bullet holes) from the map.cl_jiggle_bone_framerate_cutoff
- the minimum framerate at which the item's jigglebones still work. It is set to 20 FPS by default, lower it to the desired value if you're rendering at low FPS.ent_fire team_round_timer addtime <number>
- Adds time to the timer of the round. Can be used with a negative number to remove time instead.cl_yawspeed <value>
- Adjusts left/right turning (yaw) speed. Value should be changed to match the duration of a taunt (if infinite, simply set to a value that feels right). Use in combination with a+right
and+left
keybind to smoothly rotate the camera around your class.tf_use_match_hud 0
- Disables the team information HUD on the top of the screen.hud_reloadscheme
- Refreshes the TF2 HUD.tf_forced_holiday
<0-11> - Forces holiday mode (0: default; 1: TFBirthday; 2: Halloween; 3: Christmas; 8 : FullMoon)
Bot scripting commands
bot -team XX -class XX -name XX
- Adds a puppet bot with the specified parameters. For the sake of consistency, the bots' names must correspond with their classes, with a prefix "Friendly" if it is on the BLU team, and have a single-digit postfix if there is more than one bot of the same class on the given team. This command is not to be confused withaddbot
, which adds an AI-controlled bot instead of a puppet bot.
- Example:
bot -team blu -class medic -name "Friendly Medic"; bot -team red -class heavy -name "Heavy 1"; bot -team red -class heavy name "Heavy 2"
bot_command <bot name> <console command>
- Makes the specified bot perform the specified command. Particularly useful for making engineer bots enter build mode.
- Example:
bot_command "Friendly Engineer" build <number from 0 to 3>
(0 for the Dispenser, 1 for the Teleporter Entrance, 2 for the Sentry, and 3 for the Teleport Exit)
bot_mimic <0 or 1>
- Makes all the bots mimic the player's actions.
- Example: In order to make a Spy disguise, you need to perform the keystrokes for disguising while playing as a Spy and having the mimic option enabled. Similarly, the only way to make Engineer bots rotate buildings is to press Mouse2 with the mimic option on. Note that Engineer bots will not mimic you creating buildings as an Engineer, you must use
bot_command <bot name> build <number>
instead.
bot_mimic_yaw_offset <angle from 0 to 360>
- Makes the bots face in a direction this angle from the player while thebot_mimic
is active. By default it is set to180
so each bot faces the player when stared at.bot_dontmove <0 or 1>
- Allows or prevents all bots from moving. Takes priority overbot_mimic
.bot_refill
- Restores ammo and health for all bots.bot_teleport <name> <x y z x1 y1 z1>
- Teleports the specified bot to the given coordinates.X
,y
andz
define the position andx1
,y1
andz1
define where the bot aims its weapon. The needed numbers can be acquired by placing yourself on the bot's desired future position and using thegetpos
command.cc_bot_selectweapon <name> <slot>
- Forces a bot to switch to a specified weapon slot.
- Example:
cc_bot_selectweapon heavy 2
will make a bot named "Heavy" switch to his Fists.
bot_forcefireweapon <weapon name>
- Makes all the bots fire the specified weapon if they possess it. This can be used to make only one bot fire its weapon instead of all the bots when using thebot_forceattack
command. If the weapon name is invalid, all bots will stop firing. Scout and Engineer pistols are regarded as different weapons, and so are Soldier, Pyro, Heavy, and Engineer shotguns. See this page for a full list of valid weapon names.
- Example:
alias "+rocket" "bot_forcefireweapon tf_weapon_rocketlauncher";
alias "-rocket" "bot_forcefireweapon randomword";
alias "+flame" "bot_forcefireweapon tf_weapon_flamethrower";
alias "-flame" "bot_forcefireweapon herpderp";
bind f +flame;
bind t +rocket
- Note: Bots cannot equip non-stock weapons or items. If you need an enemy character to use an unlockable weapon, you'll need a second human player to play as that character. Feel free to ask for cooperation on the discussion page.
bot_forceattack <0 or 1>
- Make all bots perform their primary attack (+attack
)bot_forceattack2 <0 or 1>
- Make all bots perform their secondary attack (+attack2
)
- Whilst the above two commands may not seem as immediately useful as
bot_forecefireweapon
, they are best suited to making a bot perform their secondary fire for a weapon. For example, using the following code, you can make Sniper bots scope-in or Spy bots engage their cloak:alias +cloak "bot_forceattack 1; bot_forceattack2 1"
alias -cloak "bot_forceattack 0; bot_forceattack2 0"
bind key +cloak
Note: You cannot alias or bind a bot action to a key if the bot's name has spaces in it. This can be avoided by creating a config file containing the desired commands and binding the execution of said file to a key.
- Example:
bind p "bot_teleport Friendly Spy x y z x1 y1 z1"
- Wrong.bind p "exec action.cfg"
while the fileaction.cfg
containsbot_teleport "Friendly Spy" x y z x1 y1 z1
- Correct.
List of screen recording programs
These programs have been successfully used to create demonstrations videos in the past.
- Source Recorder is part of TF2, and should be used for in-game footage when doing so has no visible side-effects.
- Although not required, SrcDemo² can be used with it to make it less painful to record smooth high-framerate footage.
- Open Broadcaster Software. Remember to adjust the video quality settings in Output -> Recording -> Recording Quality = High Quality (refrain to use higher values, as it will increase file sizes unnecessarily) and in Video.
- Fraps (full version only, require purchase)
- ShadowPlay from Nvidia's Geforce Experience (Nvidia graphics card required)
- Xbox Game Bar (Windows 10 built-in)