Instance: Difference between revisions

From Valve Developer Community
Jump to navigation Jump to search
No edit summary
No edit summary
 
(38 intermediate revisions by 19 users not shown)
Line 1: Line 1:
{{stub}}
{{LanguageBar|Instance}}
An '''instance''' is a [[VMF|map (.vmf) file]] referenced inside another map through a [[func_instance]], possibly aided by a [[func_instance_parms]] and/or [[func_instance_io_proxy]].
An '''instance''' is a [[VMF|map file]] (<code>.vmf</code>) referenced inside another map through a {{ent|func_instance}}, possibly aided by a {{ent|func_instance_parms}} and/or {{ent|func_instance_io_proxy}}.


{{note|While working inside [[Hammer]] for all Source games, instances are currently only supported by the map compilers for [[Left 4 Dead 2]], [[Alien Swarm]], [[Portal 2]] and [[Counter-Strike: Global Offensive]], and will therefore not work for any other games. How to use them in unsupported games, see [[Instance#Workaround for any Source game|Workaround for any Source game]]}}
{{note|In order for instances to be compiled into maps, a <code>GameData</code> key must be present in {{ent|gameinfo.txt}} pointing to the game's [[FGD]] file. Only {{l4d2|4}} and later, along with {{tf2|4}}, include this by default. Instances can be enabled in other games by adding this. A precompiler can also be used, as described below, but this can be more [[expensive]] if the instance is rotated at a non-orthogonal angle.}}
 
{{note|In pre-{{l4d2|2}} branches, instances have some broken or missing functionality: instance I/O system is unsupported, instances cannot be nested, displacements within an instance may not compile properly, and any {{ent|env_cubemap}}s inside of an instance will not be compiled into the final map.}}
 
{{note|Referencing an instance in your map will make the compiled map's <code>mapversion</code> keyvalue be taken from one of the instances instead.}}


Instances are helpful in many ways:
Instances are helpful in many ways:
Line 8: Line 12:
* They provide a more dynamic alternative to [[prefabs]], as any changes to the instanced map will be reflected in all instances of it.
* They provide a more dynamic alternative to [[prefabs]], as any changes to the instanced map will be reflected in all instances of it.
* They provide an alternative to [[visgroups]], as they can be used to divide a large, unwieldy map into several smaller, manageable ones (that can even be worked on by multiple authors simultaneously).
* They provide an alternative to [[visgroups]], as they can be used to divide a large, unwieldy map into several smaller, manageable ones (that can even be worked on by multiple authors simultaneously).
* They provide a simple way to edit portions of a map that needs to be at a non-orthogonal angle. (Build the map on-grid inside a separate map, and then instance it into another map through a [[func_instance]] rotated at the correct angle.
* They provide a simple way to edit portions of a map that needs to be at a non-orthogonal angle. (Build the map on-grid inside a separate map, and then instance it into another map through a <code>func_instance</code> rotated at the correct angle). '''This is also [[cheap]]er than compiling the map with the rotated geometry directly in the base VMF''', as it produces fewer [[BSP (Source)#Brush and brushside|brushsides]] (although this can subtly break [[QPhysics]], such as making [[surf]]ing impossible).
* They provide a way for maps to work on multiple platforms, such as [[Left 4 Dead]] and [[Left 4 Dead 2]] versions of the same map.
* They provide a way for maps to work on multiple platforms, such as {{l4d|2}} and {{l4d2|2}} versions of the same map.
 
== Instance I/O ==
 
=== With func_instance_io_proxy ===
In {{l4d2|2}} and later, instances can send and receive inputs and outputs. To use this functionality, a {{ent|func_instance_io_proxy}} entity named <code>proxy</code> must be present and properly configured in the instance. To send an input to an entity within the instance, the following output would be used:
::{| class=standard-table
!  || My Output || Target Entity || Target Input || Parameter || Delay || Only Once
|-
| [[File:Io11.png]] || <output> || <instance> || instance:<entity>;<input> || <none> || 0.00 || No
|}
 
To receive an output from an entity in the instance, this output would be used on the {{ent|func_instance}}:


==How to==
In portal 2 to give input to an entity within a instance use this:
::{| class=standard-table
::{| class=standard-table
!  || My Output || Target Entity || Target Input || Parameter || Delay || Only Once
!  || My Output || Target Entity || Target Input || Parameter || Delay || Only Once
|-
|-
| [[Image:Io11.png]] || <Output> || <Instance> || instance:<entity>;<input> || <none> || 0.00 || No
| [[File:Io11.png]] || instance:<entity>;<output> || <other entity> || <input> || <none> || 0.00 || No
|}
|}


Or, alternatively, you can do this:
{{note|Hammer should auto-complete these inputs and outputs. They may also appear as invalid, but will work fine in-game.}}
 
=== Without func_instance_io_proxy ===
Games before Left 4 Dead 2 do not have I/O proxies, so in those games (or if I/O proxies need to be avoided for another reason) instance I/O must be done manually. For inputs, the fixed up entity name can be referenced directly.
 
::{| class=standard-table
::{| class=standard-table
!  || My Output || Target Entity || Target Input || Parameter || Delay || Only Once
!  || My Output || Target Entity || Target Input || Parameter || Delay || Only Once
|-
|-
| [[Image:Io11.png]] || <Output> || <Instance>-<entity> || <input> || <none> || 0.00 || No
| [[File:Io11.png]] || <output> || <fixupname>-<entity> || <input> || <none> || 0.00 || No
|}
|}
For outputs, a {{ent|logic_auto}} can use [[AddOutput]] to add the outputs to an entity within the instance.
::{| class=standard-table
!  || My Output || Target Entity || Target Input || Parameter || Delay || Only Once
|-
| [[File:Io11.png]] || OnMapSpawn || <fixupname>-<entity> || AddOutput || <output> <target_ent>:<target_input>::0:-1 || 0.00 || No
|}
{{note|If you are using [[TeamSpen's Hammer Addons|HammerAddons]], the <code>comp_kv_setter</code> entity should be used instead so the outputs are added at compile time instead of at runtime.}}
{{note|Hammer will not auto-complete these inputs and will display them as invalid, but they will work in-game. If the instance's Entity Name Fix Up is set to Postfix, the fix up name and entity name should be swapped.}}


== Manifests ==
== Manifests ==
{{todo|}}
Instances can be taken a step further with '''manifests'''. A manifest splits all of the contents of a map into special instances known as "sub-maps". Unlike regular instances, Hammer can seamlessly switch between sub-maps without having to open the VMFs separately. Sub-maps are treated as extensions of the map itself and cannot use name fixup or have any offset, although sub-maps are capable of being used in multiple manifests simultaneously.


== Workaround for any Source game ==
Manifests can be helpful in many ways:
* They allow multiple people to work on a map at the same time.
* They help protect a map against corruption, as problems with a VMF are limited to a single sub-map.
* They can be used to assign user-friendly names to different areas of a map.
* They can make a map's source files easier to track in version control software like Git.


To use instances in unsupported Engine versions [http://steamcommunity.com/id/robert64 Metapyziks] wrote a program that merges used instances with the main VMF.
A manifest can be created in the "Instancing" menu.
 
{{note|Manifests are not supported under {{hammerpp|2}}. Instead, the instance tools have been expanded to be more feature complete with manifests. <code>Tools -> Convert Instance to Selection</code> can be used to convert selections to instances. Middle clicking an instance in 3D view or clicking <code>Edit Instance (preview)</code> in object properties will allow editing the instance with the main map shown relative in the views.}}
 
{{warning|Manifests should be mostly functional in any{{confirm}} version of Hammer, but in most games, [[VBSP]]'s support for manifests is unfinished and cannot compile them properly. [https://tf2maps.net/downloads/vmmc.3660/ VMMC] can collapse manifests into a single VMF before compilation, which fixes many of these issues.}}
{{fix|For {{src13|1}} mods, many of VBSP's issues can be fixed with code modifications. [https://github.com/DeathByNukes/source-sdk-2013 This fork by DeathByNukes] includes several overall manifest fixes. [https://github.com/mapbase-source/source-sdk-2013 Mapbase's repository] modifies these fixes to work in {{hl2|1}} mapping and also incorporates instancing fixes intended for manifests.|code}}
 
== Precompiler ==
 
[http://steamcommunity.com/id/metapyziks Metapyziks] wrote a program that merges instances into the main VMF before each compile. This was originally created to enable instance support in older engine branches, but the <code>GameData</code> method has since rendered it mostly obsolete. However, it would theoretically be possible for someone to fork the program to add additional functionality, such as instance I/O support or the ability to toggle [[VisGroups]] with a fixup variable.
* [https://github.com/Metapyziks/VMFInstanceInserter Set up tutorial and source code]
* [https://github.com/Metapyziks/VMFInstanceInserter Set up tutorial and source code]
* [https://github.com/downloads/Metapyziks/VMFInstanceInserter/vmfii_0_9.zip VMFII 0.9]
* [https://github.com/Metapyziks/VMFInstanceInserter/releases VMFII releases]
 


== Also see ==
== See also ==
* [[L4D2 Level Design/VMF Instances]] - A Valve tutorial on how to use instances in Left 4 Dead 2.
* [[L4D2 Level Design/VMF Instances]] - A Valve tutorial on how to use instances in {{l4d2|2}}.
* [[Working with instances]] - A tutorial on how to use instances in Portal 2.
* [[Working with instances]] - A tutorial on how to use instances in {{Portal2|2}}.


== External links ==
== External links ==
* [http://www.youtube.com/watch?v=YvSZ2NEX1Y0 Source SDK Tutorial - Manifest Tool (YouTube)]
* [http://www.youtube.com/watch?v=YvSZ2NEX1Y0 Source SDK Tutorial - Manifest Tool (YouTube)]
* [http://tf2maps.net/threads/mapping-collaboration-or-using-manifest-and-version-control.24787/ Manifests and Version Control Tutorial (TF2Maps.net)]
* [https://tf2maps.net/downloads/vmmc.3660/ Valve Map Manifest Collapser (VMMC)]


[[Category:Glossary]]
[[Category:Glossary]]

Latest revision as of 23:47, 23 September 2025

English (en)Русский (ru)中文 (zh)Translate (Translate)

An instance is a map file (.vmf) referenced inside another map through a func_instance, possibly aided by a func_instance_parms and/or func_instance_io_proxy.

Note.pngNote:In order for instances to be compiled into maps, a GameData key must be present in gameinfo.txt pointing to the game's FGD file. Only Left 4 Dead 2 Left 4 Dead 2 and later, along with Team Fortress 2 Team Fortress 2, include this by default. Instances can be enabled in other games by adding this. A precompiler can also be used, as described below, but this can be more expensive if the instance is rotated at a non-orthogonal angle.
Note.pngNote:In pre-Left 4 Dead 2 Left 4 Dead 2 branches, instances have some broken or missing functionality: instance I/O system is unsupported, instances cannot be nested, displacements within an instance may not compile properly, and any env_cubemaps inside of an instance will not be compiled into the final map.
Note.pngNote:Referencing an instance in your map will make the compiled map's mapversion keyvalue be taken from one of the instances instead.

Instances are helpful in many ways:

  • They provide a more dynamic alternative to prefabs, as any changes to the instanced map will be reflected in all instances of it.
  • They provide an alternative to visgroups, as they can be used to divide a large, unwieldy map into several smaller, manageable ones (that can even be worked on by multiple authors simultaneously).
  • They provide a simple way to edit portions of a map that needs to be at a non-orthogonal angle. (Build the map on-grid inside a separate map, and then instance it into another map through a func_instance rotated at the correct angle). This is also cheaper than compiling the map with the rotated geometry directly in the base VMF, as it produces fewer brushsides (although this can subtly break QPhysics, such as making surfing impossible).
  • They provide a way for maps to work on multiple platforms, such as Left 4 Dead Left 4 Dead and Left 4 Dead 2 Left 4 Dead 2 versions of the same map.

Instance I/O

With func_instance_io_proxy

In Left 4 Dead 2 Left 4 Dead 2 and later, instances can send and receive inputs and outputs. To use this functionality, a func_instance_io_proxy entity named proxy must be present and properly configured in the instance. To send an input to an entity within the instance, the following output would be used:

My Output Target Entity Target Input Parameter Delay Only Once
Io11.png <output> <instance> instance:<entity>;<input> <none> 0.00 No

To receive an output from an entity in the instance, this output would be used on the func_instance:

My Output Target Entity Target Input Parameter Delay Only Once
Io11.png instance:<entity>;<output> <other entity> <input> <none> 0.00 No
Note.pngNote:Hammer should auto-complete these inputs and outputs. They may also appear as invalid, but will work fine in-game.

Without func_instance_io_proxy

Games before Left 4 Dead 2 do not have I/O proxies, so in those games (or if I/O proxies need to be avoided for another reason) instance I/O must be done manually. For inputs, the fixed up entity name can be referenced directly.

My Output Target Entity Target Input Parameter Delay Only Once
Io11.png <output> <fixupname>-<entity> <input> <none> 0.00 No

For outputs, a logic_auto can use AddOutput to add the outputs to an entity within the instance.

My Output Target Entity Target Input Parameter Delay Only Once
Io11.png OnMapSpawn <fixupname>-<entity> AddOutput <output> <target_ent>:<target_input>::0:-1 0.00 No
Note.pngNote:If you are using HammerAddons, the comp_kv_setter entity should be used instead so the outputs are added at compile time instead of at runtime.
Note.pngNote:Hammer will not auto-complete these inputs and will display them as invalid, but they will work in-game. If the instance's Entity Name Fix Up is set to Postfix, the fix up name and entity name should be swapped.

Manifests

Instances can be taken a step further with manifests. A manifest splits all of the contents of a map into special instances known as "sub-maps". Unlike regular instances, Hammer can seamlessly switch between sub-maps without having to open the VMFs separately. Sub-maps are treated as extensions of the map itself and cannot use name fixup or have any offset, although sub-maps are capable of being used in multiple manifests simultaneously.

Manifests can be helpful in many ways:

  • They allow multiple people to work on a map at the same time.
  • They help protect a map against corruption, as problems with a VMF are limited to a single sub-map.
  • They can be used to assign user-friendly names to different areas of a map.
  • They can make a map's source files easier to track in version control software like Git.

A manifest can be created in the "Instancing" menu.

Note.pngNote:Manifests are not supported under Hammer++ Hammer++. Instead, the instance tools have been expanded to be more feature complete with manifests. Tools -> Convert Instance to Selection can be used to convert selections to instances. Middle clicking an instance in 3D view or clicking Edit Instance (preview) in object properties will allow editing the instance with the main map shown relative in the views.
Warning.pngWarning:Manifests should be mostly functional in any[confirm] version of Hammer, but in most games, VBSP's support for manifests is unfinished and cannot compile them properly. VMMC can collapse manifests into a single VMF before compilation, which fixes many of these issues.
Cpp.pngCode Fix:For Source 2013 mods, many of VBSP's issues can be fixed with code modifications. This fork by DeathByNukes includes several overall manifest fixes. Mapbase's repository modifies these fixes to work in Half-Life 2 mapping and also incorporates instancing fixes intended for manifests.

Precompiler

Metapyziks wrote a program that merges instances into the main VMF before each compile. This was originally created to enable instance support in older engine branches, but the GameData method has since rendered it mostly obsolete. However, it would theoretically be possible for someone to fork the program to add additional functionality, such as instance I/O support or the ability to toggle VisGroups with a fixup variable.

See also

External links