Painted variants (tutorial)
|
This painted variants tutorial will document the current methods of painting cosmetic items using Half-Life Model Viewer (HLMV). This tutorial assumes that you already have HLMV working. If you haven't gotten HLMV set up, navigate to this page and read the information on it.
Contents
Other necessary programs
For this tutorial, we will utilize GCFScape, which may be downloaded here, as either an installer or a portable archive. In addition, if painting cosmetics which have jigglebones, it may be useful to remove them by decompiling the model, removing references to the jigglebones, and recompiling a new model file. For this process, you will also need the Crowbar tool. If you plan on using the semi automatic methods you will need HLMV++ and TFMV for capturing the images. Additionally you will need GIMP and the Batch Image Manipulation Plugin (BIMP) for processing the images before uploading.
Removing jigglebones from models
Cosmetics with jigglebones may prove to be an issue when painting, as their jigglebones may move when you refresh HLMV, in the process of changing paint colors. This may make it difficult to take identical-looking images, in which case, the jigglebones can be removed with the use of the Crowbar tool.
Decompiling the models
- Upon first booting Crowbar, you will be presented with the Set Up Games tab. Here, you may configure which game you would like to use with the program, and enter the location of your Steam executable, so that Crowbar can find the tools it needs to work. Select Team Fortress 2 from the drop down menu at the top, and enter the location of your Steam executable in the
<library1>
macro section at the bottom. - Using GCFScape, extract the
.mdl
file you wish to remove jigglebones from, and all matching.vtx
and.vvd
files. - In Crowbar's Decompile tab, you will notice the
MDL input
field, and theOutput to:
selector. In theMDL input
field, select the.mdl
file you extracted previously. - Set
Output to:
to theWork folder
option, and create a directory where you would like to save the decompiled files on your computer. - Press the Decompile button. If successful, you should have a
.qc
file, and.smd
files present in your work folder. These files are all necessary to recompile the model, and should follow the same file names as the model file you extracted.
Removing jigglebones and recompiling
- Open the
.qc
file from your decompilation work folder in a text editor, and remove all references to jigglebones. Save the file. - Back in Crowbar, select the Compile tab. In the
QC input
section, select the.qc
file from your decompilation work folder. - Just as before, set
Output to:
to theWork folder
option, and create a directory to save the compiled files to. - Press the Compile button. If successful, your compilation work folder should now have identical files to the ones you extracted from GCFScape, nested within subfolders.
Note: If you run into an error while compiling, it may be that Team Fortress 2, or the location of your Steam executable, was improperly set up in the Set Up Games tab; or that the decompilation process failed to produce the necessary files to recompile the model. Check that you have properly set up Team Fortress 2 and the file paths to its tools, and that you have properly extracted all relevant files from GCFScape.
Note: Be sure to upload your recompiled files to a file sharing site, and link to them when adding details to the Rotations page! This will help other users to create identical images to yours, should the need arise.
Setting up HLMV
We want the images to be the best quality possible, so you need to set up HLMV so that it generates high quality images. You can force high quality settings in your graphics cards control panel, but this does not work for some people - so I will document the alternate method.
Dxsupport.cfg
- Navigate to this directory:
\Steam\steamapps\common\Team Fortress 2\bin\
. - Open up
dxsupport.cfg
in a text editor of your choice. If you do not have this file, create it with the content from here. - Find your graphics card within that file. If it is not listed go to the bottom and use
ATI Unknown
,NVidia Unknown
orIntel Unknown
depending on your graphics card manufacturer. - Add or modify the following lines in
dxsupport.cfg
within the section for your graphics card, and save it."setting.dxlevel" "99"
"ConVar.mat_antialias" "8"
"ConVar.mat_forceaniso" "8"
"ConVar.mat_picmip" "-10" - Open up a model and ensure there is no aliasing or other quality defects. If there is it's likely your graphics card is not able to render images of high enough quality, or you will need to adjust the settings in your graphics card's control panel.
HLMV options
- Open up HLMV through the hlmv.exe in this directory:
\Steam\steamapps\common\Team Fortress 2\bin\
. - Check (if it's not already checked) the "Normal Mapping" checkbox.
- Set the background colour to white for each item:
Options... > Background Color...
. - Full-screen HLMV (so you get a nice big image).
- When generating hat images, you should use the red team texture and angle the hat slightly forward and facing left or right (get as much of the hat in view as possible). For example: File:Painted_Tough_Guy's_Toque_7D4071.png. All the painted images of a certain hat should be in the same position.
Taking the images
Rotations
Before you start taking images, check rotations and see if the item you're painting is noted on there. If it is, follow the "Setting rotations" section, otherwise when you've finished, follow the "Saving rotations" section.
Setting rotations
- Open regedit.exe (Start - Run).
- Navigate to:
HKEY_CURRENT_USER\Software\Valve\hlmv
- For your item, pick the associated directory - these will be listed on the rotations page.
- In the right-panel, double click "Rot" and copy-paste the value in the Rotations page for your item.
- Also do this for any "trans" and "lightrot" values, if provided.
- Close regedit, and re-open your item in HLMV.
- If there is a "FOV" value on the Rotations page for your item, you can enter this into HLMV - at the bottom left of the "Render" tab.
- You may need to move the item around a bit to get it to show up correctly, and as large as possible. If this happens, read the "Saving rotations" section.
- Generally, when choosing your own rotations, you'll need to find an angle that shows off the painted area the most.
Saving rotations
If your item does not have an entry on the rotations page...
- Open the item in HLMV.
- Play around with the positioning - positioning it slightly forward, and then left or right - until you get a good view of the hat. The positioning should show as much of the item as possible.
- Follow the "Setting rotations" section, however instead of replacing the "Rot" value - copy it.
- Do the same for "trans" and "lightrot" - if they have been adjusted.
- Make an entry in the Rotations page, in the relevant position, documenting your item. Note the name of the item, it's registry-folder name and the rotation used.
- Commence generating the images, sticking to this rotation.
VMT Editing Method
- Open
tf2_misc_dir.vpk
in GCFScape. - Extract the relevant VMT to the right place. For example, Tough Guy's Toque would use
\materials\models\player\items\heavy\heavy_stocking_cap.vmt
, and should be extracted to:\Steam\steamapps\common\Team Fortress 2\tf\custom\folder\materials\models\player\items\heavy
. - Open the VMT file in VTFEdit or any text editor, and position the camera in HLMV to take screenshots.
- Near the top of the VMT, change
$detailblendfactor
to.00
. This removes the faint fire overlay (most noticeable on black painted items).- There is another option to remove the fire overlay, which is downloading and extracting this texture replacement, and copying the contents to
\Steam\steamapps\common\Team Fortress 2\tf\custom\
. This will replace the default file texture with a 512x512 black material, effectively nullifying the effect for all models.
- There is another option to remove the fire overlay, which is downloading and extracting this texture replacement, and copying the contents to
- Create a new line in the VMT file underneath
"$colortint_base" "{VALUE}"
and fill it with this content"$color2" "{R G B}"
. You can find a complete list of colours to copy/paste below. - Paste the relevant RGB value found in the table below.
- Hit F5 in HLMV to refresh the model and then take a screenshot of this color, and paste it into a new document in an image editor of your choice.
- If the image editor you are using supports layers, and you are taking multiple screenshots, paste the first one into a new document. Any screenshots of that image you take after that should then go into a new layer in that document.
- Repeat the previous two steps for each color.
// Uncomment and re-comment as necessary." // "$color2" "{}" // Stock - Copy the value of "$colortint_base" into here." // "$color2" "{230 230 230}" // An Extraordinary Abundance of Tinge" // "$color2" "{216 190 216}" // Color No. 216-190-216" // "$color2" "{197 175 145}" // Peculiarly Drab Tincture" // "$color2" "{126 126 126}" // Aged Moustache Grey" // "$color2" "{20 20 20}" // A Distinctive Lack of Hue" // "$color2" "{45 45 36}" // After Eight" // "$color2" "{105 77 58}" // Radigan Conagher Brown" // "$color2" "{124 108 87}" // Ye Olde Rustic Color" // "$color2" "{165 117 69}" // Muskelmannbraun" // "$color2" "{207 115 54}" // Mann Co. Orange" // "$color2" "{231 181 59}" // Australium Gold" // "$color2" "{240 230 140}" // The Color of a Gentlemann's Business Pants" // "$color2" "{233 150 122}" // Dark Salmon Injustice" // "$color2" "{255 105 180}" // Pink as Hell" // "$color2" "{125 64 113}" // A Deep Commitment to Purple" // "$color2" "{81 56 74}" // Noble Hatter's Violet" // "$color2" "{47 79 79}" // A Color Similar to Slate" // "$color2" "{66 79 59}" // Zephaniah's Greed // "$color2" "{128 128 0}" // Drably Olive" // "$color2" "{114 158 66}" // Indubitably Green" // "$color2" "{50 205 50}" // The Bitter Taste of Defeat and Lime" // "$color2" "{188 221 179}" // A Mann's Mint" // "$color2" "{168 154 140}" // Waterlogged Lab Coat (RED)" // "$color2" "{131 159 163}" // Waterlogged Lab Coat (BLU)" // "$color2" "{59 31 35}" // Balaclavas Are Forever (RED)" // "$color2" "{24 35 61}" // Balaclavas Are Forever (BLU)" // "$color2" "{184 56 59}" // Team Spirit (RED)" // "$color2" "{88 133 162}" // Team Spirit (BLU)" // "$color2" "{72 56 56}" // Operator's Overalls (RED)" // "$color2" "{56 66 72}" // Operator's Overalls (BLU)" // "$color2" "{128 48 32}" // The Value of Teamwork (RED)" // "$color2" "{37 109 141}" // The Value of Teamwork (BLU)" // "$color2" "{101 71 64}" // An Air of Debonair (RED)" // "$color2" "{40 57 77}" // An Air of Debonair (BLU)" // "$color2" "{195 108 45}" // Cream Spirit (RED)" // "$color2" "{184 128 53}" // Cream Spirit (BLU)"
Styles
If the item has an alternate style that's not a separate model, rename the style's VMT to the normal VMT. For instance, for the Reggaelator, the normal VMT (and the Original style) is demo_dreads.vmt
, and the style VMTS are demo_dreads_style01.vmt
for Burst, demo_dreads_style02.vmt
for Bones, and demo_dreads_style03.vmt
for Designer. To use the Burst style, rename demo_dreads_style01.vmt
to demo_dreads.vmt
and hit F5 in HLMV. The same thing would then be done for each other style, just using the appropriate VMT for it. Everything else on this page will then apply in the same way.
If an item has an alternate style that is a separate model, the style's model has to be loaded separately. For instance, for the Front Runner, the model for the Stylin' style is scout_headband.mdl
, whereas the model for the Indifferent style is scout_headband_s01.mdl
. For most items, the registry settings for it can be set exactly the same for each style, and then everything else on this page will apply in the same way.
Semi Automatic Methods
HLMV++ Method
Note While the script is running the background will flash black and white very quickly so be careful if you are sensitve to that sort of thing.
- Load the model in HLMV++
- Download the AUTO-PaintedVariants mvscripts.
- In HLMV++ select
File > Run .mvscript
then openAUTO-PaintedVariants-Part1.mvscript
. The script should cylce through the paint colors taking screenshots after each one. The images will be saved to wherever the script is located so you may choose to make a folder and drag the script into it so the images are organized. - Part1 of the script will handle the single color paints (Pink as Hell, Drabby Olive etc.) and the red team colors (Team Spirit, Value of Teamwork). To get the Blu colors you need to set the skin of the cosmetic to the blu version in the model tab of HLMV++ then hit F5 to refresh and reset the cosmetic to unpainted
- Like with Part1, select
File > Run .mvscript
then openAUTO-PaintedVariants-Part2.mvscript
. - Once the images have been captured open GIMP and select
File > Batch Image Manipulation...
- Where it says Manipulation set click
Add > Load set
and open theAuto-Crop and Convert to PNG.bimp
set which can be found here. - Click
Add images > Add folders...
and open the folder where the images are stored and set theOutput folder:
to your desired location. - Select Apply and BIMP will crop and convert all of the images.
TFMV Method
- Select the model and class in TFMV and hit Loadout to HLMV
- Some painted variants will require custom materials. For example if you wanted scout's head and his headset you would need to that place the
scout_head+hat+headset_materials
in your custom folder. These materials can be found on the rotations page. - Once the model is loaded and the correct materials are setup you need to select "Paints Chart Tool" in the Tools section in the right side of TFMV
- Now that the Paints Chart Tool is selected make sure that the Screenshot refresh delay is set to an apporiate number. This entirely varies depending on your PC's hardware. If the paints don't change between screenshots increase the delay by a few seconds and try running it again.
- Hit start in the Paints Chart Tool and then Go! TFMV will cycle through the different colored paints one at a time, taking screenshots for each one.
- TFMV will change the cosmetic from red to blu for the appropriate paint however it will not change the color of the class model. You will need to change the class model manually as it cycles through the different color. If you don't do this things The easiest way to do this is to click on the skin drop down in the Model menu and press the down arrow on your keyboard whenever you need the blu class model.
- Once the images have been captured open GIMP and select
File > Batch Image Manipulation...
- Where it says Manipulation set click
Add > Load set
and open theAuto-Crop.bimp
set which can be found here. - Click
Add images > Add folders...
and open the folder where the images are stored and set theOutput folder:
to your desired location. - Select Apply and BIMP will crop and convert all of the images.
Upload the images
- Upload a new version of the existing files on the Wiki. Use
{{subst:pid}}
in the upload summary box when uploading painted item images, and use{{subst:isd}}
when uploading unpainted item images, such as default team color images. These templates will automatically add licensing and proper categories (this saves you from typing out categories or manually selecting a license in the drop down box).
Adding the painted variants table to an article
To include the Painted variant table to an article, add this section below the main summary for the page:
== Painted variants == {{Painted variants}}
For documentation as to what parameters this template accepts, such as the inclusion of different Styles, see Template:Painted variants/doc.
In rare situations, single color paint cans may have different visuals between teams on certain cosmetics, examples include the Frenchman's Beret and Defiant Spartan. On cases like these, add this section to the page:
== Painted variants == {{Painted variants full}}
The documentation for this template includes the same parameters as the previous one.
See also
- There is an experimental automation toolset for the VMT method, found here.