VMT: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
m (Setting bug notice hidetested=1 param on page where the bug might not need tested in param specified)
 
(44 intermediate revisions by 23 users not shown)
Line 1: Line 1:
{{otherlang2
{{LanguageBar}}
| de = Material:de
| fr = Material:fr
| jp = Material:jp
}}


'''Материал''' представлен в игре в формате <code>.vmt</code> ("Valve Material Type"), текстовый файл, который определяет основные свойства поверхности. Он включает все необходимые данные для Source движка, чтобы правильно отображать поверхность, правильно "озвучивать", а так же, чтобы правильно работала физика.
{{todo|Move engine-agnostic stuff to [[material]].}}
A '''VMT''' ("Valve Material") file defines the [[material]] used by a two-dimensional surface. It contains all of the information needed for {{src|4}} to simulate the surface visually, aurally, and physically.<br>If a material is missing, it will produce the infamous Source pink and black checkered pattern. A white wireframe is not a missing material, but instead a missing [[shader]].


Тип материала может совпасть с одной или всеми из следующих категорий:
__TOC__


# Имя [http://developer.valvesoftware.com/wiki/Texture Тестуры]  
 
# [[$surfaceprop|Физические типы поверхности]](Прим. переводчика: я не уверен. На английском: Physical surface types)
The contents of a material will fall into some or all of these categories:
# [[:Category:List of Shader Parameters|Параметры]] [http://developer.valvesoftware.com/wiki/Shader Шейдеров]
 
# [[Texture]] names
# [[$surfaceprop|Physical surface]] [[Material surface properties|types]]
# [[:Category:Shaders|Shader]] [[:Category:List of Shader Parameters|parameters]]
# [[Material Map Compile Flags|Special compile properties]]
# [[Material optimization|Fallbacks]]
# [[Material optimization|Fallbacks]]
# [[Material Proxy|Прокси]]
# [[Material Proxy|Proxies]]
 
== A simple example ==
{{CodeBlock|<nowiki>LightmappedGeneric
{
$basetexture "coast/shingle_01"
$surfaceprop gravel
}</nowiki>}}
''This is a very basic [[Wikipedia:Shingle beach|shingle beach]] material.''
 
#The <code>[[LightmappedGeneric]]</code> shader is used, which means that the material is for use on surfaces with [[lightmap]]s (i.e. [[brush]]es).
#''The opening curly brace ({{Code|<nowiki>{</nowiki>}}) opens a set of parameters''
#The <code>[[$basetexture]]</code> parameter is given with <code>coast\shingle_01</code>, which is the location of a texture. This is what will be drawn on the screen.
#<code>[[$surfaceprop]]</code> gives the material the physical properties of gravel.
#''The closing curly brace ({{Code|<nowiki>}</nowiki>}}) character closes a set of parameters''


== Простой пример ==
It's important to remember that this material can only be used on brushes. If it needed to be used on [[model]]s, for instance, another version would need to be created using the {{code|[[VertexLitGeneric]]}} shader.


LightmappedGeneric
Most of the time switching materials from one shader to another is as simple as changing their first line, since a great number of parameters are shared between them. Some params only work with certain shaders, like [[Phong]] effects, which are only available with {{code|[[VertexLitGeneric]]}}, but unfortunately you won't encounter any critical errors if a param isn't understood by the shader. It just won't have any effect.
{
$basetexture coast\shingle_01
$surfaceprop gravel
}


Это самый базовый [[Wikipedia:Shingle beach|shingle beach]] материал.
{{tip|If you ever need to use a space, tab, or curly brace character in a parameter value, you must wrap the whole value with "quote marks". You'll often see absolutely everything wrapped like this - save yourself some typing, as that's unnecessary.}}
{{bug|hidetested=1|Sometimes{{when}}, the first parameter defined in the VMT will fail to load. If this happens, a dummy parameter such as {{code|$bug}} can be used.}}


#The <code>[[LightmappedGeneric]]</code> shader использован, что означает, что данный материал используется на поверхностях с [[lightmap]]s (Например, [http://developer.valvesoftware.com/wiki/Brush Кисти]).
== Finding materials ==
#''Этот символ  '''{''' означает, что дальше идёт набор определённый параметров.''
#<code>[[$basetexture]]</code> параметр со значением <code>coast\shingle_01</code>, означает расположение текстуры. Это то, что будет нарисовано на экране.
#<code>[[$surfaceprop]]</code> этот параметр дает материалу физические свойства гравия.
#''Этот символ '''}''' означает закрытие набора параметров''


Важно помнить, что данный материал может быть использован только в брашах. если необходимо использовать на  [http://developer.valvesoftware.com/wiki/Model  моделях], например, другая версия материала должна быть создана с использованием  <code>[[VertexLitGeneric]]</code> шейдеров.
=== SteamPipe ===


Большая часть времени переключения материалов  с одного шейдера на другой Так же просто, как переключение их первых линий(Прим. переводчика: Я не уверен. На английском:"Most of the time switching materials from one shader to another is as simple as changing their first line" ), т.к. большая часть параметров являются общими для всех. Некоторые параметры работают только с  определенными шейдерами, как [[Phong]] эффекты, которые доступны только с  <code>VertexLitGeneric</code>, но к счастью у вас не будет никаких критических  ошибок, если шейдер не понял параметр. просто не будет ни какого эффекта.
When Valve updated all {{src|4}} games to [[SteamPipe]], all materials were moved from [[GCF]] into [[VPK]] files. Third-party games (running on {{src04|1}} - {{src09|1}}) that previously used [[GCF]] files are also having it's materials moved to depot [[VPK]] files. VPK Files work with {{gcfscape|4}} and {{vpkedit|4}}.


{{Tip|Если вам понадобится использовать пробел или символ табуляции в значении параметра, вы должны заключить все значение в "кавычки". Вы часто будете видеть абсолютно все в кавычках - это позволяет сохранить пару нажатий на клавиши}}
More info on SteamPipe [https://support.steampowered.com/kb_article.php?ref=7388-QPFN-2491 here]


== Местонахождение материалов ==
=== Non-SteamPipe Games ===


Материалы расположены в  <code>materials\</code> директрия вашей игры. Лучший способ просматривать их с использованием [[Hammer]]'s texture selection screen.
In non [[SteamPipe]] {{src|4}} games, Materials are stored in the {{Path|materials\}} folder of your game or mod. The best way to browse them is from {{hammer|4}}'s texture selection screen.


Если вы хотите отредактировать или просмотреть код материалов Valve для начала вам нужно распаковать их из [[GCF]]архива с использованием [[GCFScape]]. Они, как правило, располагаются в  GCFs с припиской 'materials' в конце их имени.
If you want to edit or view the code of Valve's material files you will first need to extract them from their [[GCF]] package with {{gcfscape|4}}. They tend to be stored in GCFs with 'materials' in their name.


== Смотрите так же ==
== See also ==


* [http://developer.valvesoftware.com/wiki/Creating_a_Material Создание материала]
* [[Creating a Material]]
* [[Notepad++ VDF languages|Notepad++ syntax highlighting for materials]]
* [[Notepad++ VDF languages|Notepad++ syntax highlighting for materials]]
* [[Valve Texture Format]]
* [[Valve Texture Format]]
* [http://developer.valvesoftware.com/wiki/Category:List_of_Shaders Список Шейдеров]
* [[Shader]]
* [http://developer.valvesoftware.com/wiki/Category:List_of_Shader_Parameters Список параметров шейдеров]
* [[:Category:List of Shader Parameters|List of Shader Parameters]]
* [[Source VMT Editor]]
* [https://github.com/Xyphos/VMTGen VMTGen]
* [http://www.therazzerapp.de/tutorials/vmt_erstellen.html German Tutorial by TheRaZZeRApp]  


[[Category:Material System]]
[[Category:Material System]]
[[Category:Glossary]]
[[Category:Source]]
[[Category:File formats]]

Latest revision as of 07:07, 20 May 2025

English (en)Deutsch (de)Español (es)Français (fr)한국어 (ko)Русский (ru)Translate (Translate)
Todo: Move engine-agnostic stuff to material.

A VMT ("Valve Material") file defines the material used by a two-dimensional surface. It contains all of the information needed for Source Source to simulate the surface visually, aurally, and physically.
If a material is missing, it will produce the infamous Source pink and black checkered pattern. A white wireframe is not a missing material, but instead a missing shader.


The contents of a material will fall into some or all of these categories:

  1. Texture names
  2. Physical surface types
  3. Shader parameters
  4. Special compile properties
  5. Fallbacks
  6. Proxies

A simple example

LightmappedGeneric { $basetexture "coast/shingle_01" $surfaceprop gravel }

This is a very basic shingle beach material.

  1. The LightmappedGeneric shader is used, which means that the material is for use on surfaces with lightmaps (i.e. brushes).
  2. The opening curly brace ({) opens a set of parameters
  3. The $basetexture parameter is given with coast\shingle_01, which is the location of a texture. This is what will be drawn on the screen.
  4. $surfaceprop gives the material the physical properties of gravel.
  5. The closing curly brace (}) character closes a set of parameters

It's important to remember that this material can only be used on brushes. If it needed to be used on models, for instance, another version would need to be created using the VertexLitGeneric shader.

Most of the time switching materials from one shader to another is as simple as changing their first line, since a great number of parameters are shared between them. Some params only work with certain shaders, like Phong effects, which are only available with VertexLitGeneric, but unfortunately you won't encounter any critical errors if a param isn't understood by the shader. It just won't have any effect.

Tip.pngTip:If you ever need to use a space, tab, or curly brace character in a parameter value, you must wrap the whole value with "quote marks". You'll often see absolutely everything wrapped like this - save yourself some typing, as that's unnecessary.
Icon-Bug.pngBug:Sometimes[When?], the first parameter defined in the VMT will fail to load. If this happens, a dummy parameter such as $bug can be used.

Finding materials

SteamPipe

When Valve updated all Source Source games to SteamPipe, all materials were moved from GCF into VPK files. Third-party games (running on Source 2004 - Source 2009) that previously used GCF files are also having it's materials moved to depot VPK files. VPK Files work with GCFScape GCFScape and VPKEdit VPKEdit.

More info on SteamPipe here

Non-SteamPipe Games

In non SteamPipe Source Source games, Materials are stored in the 🖿materials\ folder of your game or mod. The best way to browse them is from Hammer Hammer's texture selection screen.

If you want to edit or view the code of Valve's material files you will first need to extract them from their GCF package with GCFScape GCFScape. They tend to be stored in GCFs with 'materials' in their name.

See also