Navigation Meshes (L4D)

From Valve Developer Community
Revision as of 05:16, 3 March 2021 by MrFunreal (talk | contribs) (Marking: Reformatted to use tables)
Jump to: navigation, search

Left 4 Dead uses the navigation mesh to spawn infected. The director uses the Navigation Mesh when deciding where to spawn infected as well as other factors such as light intensity and line of site. By altering the mesh, it is possible to change the type of infected spawning (such as hospital patients and so on) and the density of their spawn.

Tip.png Tip: The automatically generated navigation mesh looks for objects on a grid of 25 units. If object protrude into this grid it may not generate a navigation block at that location. An easy way to view the grid is to open the Hammer configuration. Under "2D Views" set the "Highlight every 'x' grid lines" to 25 units. Now you can place objects knowing exactly how the navigation grid will be generated around them.

NOTE: This article was written with experimental information and may not be 100% accurate. This article also assumes that you have read and understood the Navigation Meshes article.


Marking is as important in Left 4 Dead than it is in Counterstrike. While in counterstrike it affects how bots behave, in Left 4 Dead it both controls how they behave and how they spawn. By marking an area with certain attributes certain spawning behaviours can be created. Marking is the same as in Counterstrike, except with extra attributes, such as:

Available attributes for marking areas in Navigation Mesh editing mode.

Attribute Description
BATTLEFIELD Designates a region where a planned crescendo event will play out. Mobs will spawn and swarm dynamically inside this area. Should be a large region of the map, capable of containing a BATTLESTATION, and many spawn-friendly/mob-related areas within it. Survivors should be located inside this area at the time of the panic event - it is essential to the effect this attribute is intended to create. Do not use this attribute in gauntlet events, only holdout events.
BATTLESTATION Indicates a strong defensive area that contains supplies/weapons for use during a panic event. Survivor bots will consider this area as important, and will use or protect it as long as other survivors are nearby. It is intended to be used in carefully selected locations of BATTLEFIELD and FINALE regions.
BREAKABLEWALL Indicate to infected if a wall is breakable or not. The infected attack the wall until it breaks.
CHECKPOINT Designates the start/safe-room areas of the map. The round starts when a survivor leaves this area, and ends when the door is closed at the ending checkpoint with only the survivors inside. Infected are prohibited from spawning inside this area at all times.
CLIFF Doesn't do anything. Used only by the nav generation system to keep a note on nav square edges.
CROUCH Only has an effect in Counter-Strike: Source. In L4D, its only used for flow purposes; Bots take areas with CROUCH requiring more time to use when pathfinding. This is also not necessary for bots if it worked, as all bots crouch automatically by themselves while disregarding navigation meshes.
DONT_HIDE Marks areas that are not suitable hiding spots. Could be strictly a Counter-Strike: Source leftover.

To do: Does this still apply to L4D2?

DOOR Marks areas in which a door is located.
Note.png Note: Automatically added by the game during a nav_analyze. Rarely needs manual marking.
EMPTY Prevents wandering infected from being populated in this location. Useful for places outside the survivors playable area, or any other place you do not want wandering/sleeping infected to spawn (e.g. rooftops & surfaces infected fall off of).
Note.png Note: Does not affect mobs/special-infected.
ESCAPE_ROUTE Basic guideline path of map from start to finish by linking spawns/checkpoints to the ending checkpoint/finale. It should be found using the nav_analyze command, and may not work properly if drawn manually. This path helps the game/AI to make decisions based on routes and level progression.
FINALE Indicates a finale area, and controls the spawning of ALLinfected during a Finale Sequence. Once the sequence has been started, only areas marked with FINALE will spawn infected. Should be used extensively across your finale area, and contain a BATTLESTATION within it.
LYINGDOWN Causes zombies to lie down when not aroused by player. It can be found used in C2M1 (Dark Carnival) along the freeway ramp, the motel pool of dead bodies, and along the stream on the way to Whispering Oaks.
MOB_ONLY The name suggests it could be used to only allow mobs through the area. It is caused by switching the Breakable By property to All Infected on nearby props and breakables. This can't be set manually (at least under Left 4 Dead 1).
NOT_CLEARABLE Prevents an area from being cleared, and allows infected to spawn here indefinitely. Used in the outer-most areas survivors are able to attack or have line-of-sight to, but can't really see (e.g. through fog).

Potential area for mob spawns when not in the line-of-sight. If the only mob spawn areas available in a fully cleared map are constrained to an area marked with NOT_CLEARABLE that is within survivor LOS, the director for will wait for survivors to look away before a mob is spawned.

Use this attribute in conjunction with OBSCURED if a nav area is known to be obscured.
Note.png Note: Nav-squares are 'cleared' once survivors view and remove them of all infected. Cleared areas cannot spawn infected. NOT_CLEARABLE modifies such a rule.
NO_MERGE Disallows this navigation mesh being merged with other meshes. Also used during navigation mesh generation.
NO_MOBS Prevents infected mobs from spawning in this location. Commonly used to help mobs spawn further away from survivors and in more secluded areas of the map.

Also used to keep sources of mobs from appearing unnatural or odd, such as spawning on rooftops of certain buildings. A clever example of NO_MOBS is in the "drainage" level of the Death Toll campaign. It is used in the long pipes so that infected must spawn in the upper areas and run at you down the lengths of the pipe, rather than just around the corners.

NOTHREAT It may be used to prohibit potential boss infected (tank & witch) spawns and possibly special infected. It is often seen alongside attributes EMPTY and NO_MOBS.

The combination may suggest nav areas that are desired for infected to be able to go to but not spawn there. It would allow common infected to navigate to that area when a pipe bomb or bile bomb is placed there. This can be seen in c1m1_hotel end-saferoom and the perimeter around the hotel where the only way to access that area is to fall from a deadly height. In c1m2_streets, NOTHREAT is added to nav areas such as ones through and near a doorway, under a walkway bridge passing, and near the scene where a cinematic explosion occurs.
To do: Properly document

OBSCURED Affects the amount and manner of which infected can spawn. This is a very important navigation attribute, use both wisely and with caution.

There are two primary uses: Indicates that the area is not viewable by survivors, and allows the director to spawn flowing, or large waves of mobs. It is often used in blocked alleyways and other areas that survivors cannot view. The director can still create effective mobs without the use of OBSCURED, but they will usually be further outside the survivor PVS.

Allows infected to spawn even when there is line-of-sight to a survivor. Useful in unreachable areas with heavy fog, or areas with props that don't block line-of-sight in the engine, but still obscure the survivors view on all sides (e.g. bushes & leafy trees). Bot line-of-sight is also blocked to prevent omniscient behavior.
Tip.png Tip: Props that have collisions disabled are always unable to block line-of-sight and will need the help of OBSCURED
OBSTACLE_TOP Some nav areas on top of props don't have this attribute but infected and survivor bots can still can climb over fine.

In c1m2_streets, nav areas with this attribute are seen on top of props that require infected to climb over, such as concrete road blocks and low-lying fences blocking the streets. It is not consistently marked for all the nav areas on top of those props.
To do: Properly document.

PLAYERCLIP Marks an area of the navmesh which has a Player clip texture on it. Survivors will not go to this area, but infected will still use it - great for creating zombie spawn closets or infected-only ladders.
PLAYER_START This attribute is used in the exact nav mesh area(s) that the players spawn in. This appears to only be used in the very first level of each campaign - likely because after the first level it cannot be guaranteed where a player will spawn into the game (since you load relative to the landmark).
PRECISE Used to mark narrow pathways such as the ticket counters and exposed support-beams in the subway/generator area of No Mercy.
RESCUE_CLOSET Marks off the location of rescue closets inside the level. Usually automatically added by the game during a nav_analyze.
RESCUE_VEHICLE Marks where survivors should go to during rescue. Used only in a Finale sequence and remains locked until "FinaleEscapeVehicleReadyForSurvivors" is fired. Area covered in RESCUE_VEHICLE should be the location of the rescue vehicle once it is in position. In some cases, a lead-in must be made to make the path onto the vehicle navigable (see 'No Mercy' finale).
STOP_SCAN Rarely used. Function unknown. Claimed by some to be helpful for bots around ladders and stair cases, but this is speculation.
To do: Properly document
STAIRS Lets the bots know that they are walking on stairs and walking towards ledges. May disallow infected from trying to slowly climb up stairs. Use nav_check_stairs to reupdate Stairs attributes.
TANK_ONLY This area seems to be exclusively reserved for the tank. Bots won't use it and the flow won't compute through them. It is caused by switching the Breakable By property to Tank only on nearby props and breakables. This can't be set manually (at least under Left 4 Dead 1).
THREAT Added automatically by the game during a nav_analyze. Boss Infected (tank & witch) should spawn in these areas.

Single nav areas along the escape route are marked with THREAT and are subsequently removed when that portion of the escape route has already been reached.
To do: Could it be that those are potential spots for boss infected to spawn along an escape_route?

UNDERWATER Obviously, this marking means that the area is under water. This property is automatically added by the engine during a nav_generate and/or nav_analyze. This can be found in every map that has water, including C5M3 (Left 4 Dead 2: The Parish) when going through the sewers, before the multiple alarm car area.

Obsolete Attributes, for legacy sake.

Attribute Description
AVOID Obsolete. Counter-Strike: Source leftover.
JUMP Obsolete. Counter-Strike: Source leftover.

Could be used for organization purposes. Notably, it may still prevent itself being used as a hiding spot. This is also not very needed for bots if it worked, as all bots jump automatically based on navigation mesh connections.

NO_HOSTAGES Obsolete. Counter-Strike: Source leftover.
NO_JUMP Obsolete. Counter-Strike: Source leftover.
RUN Obsolete. Counter-Strike: Source leftover.
STOP Obsolete. Counter-Strike: Source leftover.
STAND Obsolete. Counter-Strike: Source leftover.
TRANSIENT Obsolete. Counter-Strike: Source leftover.
WALK Obsolete. Counter-Strike: Source leftover.

Place names

See also