Limited support
This feature is only present in Portal 2: Community Edition and Portal: Revolution.

POINT npc_template_maker

An entity that creates NPCs. The NPCs it creates are clones of a template NPC. NPCs are spawned around this maker's origin, or at specified destination points.

KeyValues

spawnflags <flags>

No description provided.

Possible Flags:

Name Value Default
Always use radius spawn 256
Don't preload template models 512

Name of template NPC <target_destination>

Template NPC that this maker should be creating clones of.

Radius <float> = 256

Radius around this maker within which NPCs are to be placed. Spawned NPCs will try and find empty space within this radius to spawn.

Name of Destination Group <target_destination>

If you'd like spawned NPCs to be created at an info_npc_spawn_destination entity, enter the name of that entity here. If you have more than one destination entity by that name, the Destination Criteria will be used to select one from the group.

Dest. Criterion: Visible to player? <choices> = Don't Care (2)

Should the NPC try to spawn at a destination that the player can see? Only applicable if a Destination Group is being used.

Possible Values:

Name Value
Yes 0
No 1
Don't Care 2

Dest. Criterion: Distance to player? <choices> = Don't Care (2)

Should the NPC try to spawn nearest to or farthest from the player's current location? Only applicable if a Destination Group is being used.

Possible Values:

Name Value
Nearest 0
Farthest 1
Don't Care 2

Minimum spawn distance from player <integer> = 0

The spawn destination node distance to the player will have to be further or equal than this value.

Inherited from BaseNPCMaker

Start Disabled <boolean> = No

No description provided.

Num. of NPCs <integer> = 1

Number of NPCs that will spawn before this spawner is exhausted.

Frequency <string> = 5

How often (in seconds) a new NPC will be spawned. If set to -1, a new NPC will be made when the last NPC dies.

Max Live NPCs <integer> = 5

Maximum number of live children allowed at any one time (new ones will not be made until one dies). If set to -1, no limit is applied.

Hull Check Mode <choices> = Default (0)

How NPC's hull should be checked at spawn destination?

Possible Values:

Name Value
Default 0
No hull check 1

Inherited from BaseEntityPoint

Name <target_source>

The name that other entities refer to this entity by.

Global Entity Name <string>

Name by which this entity is linked to another entity in a different map. When the player transitions to a new map, entities in the new map with globalnames matching entities in the previous map will have the previous map's state copied over their state.

Pitch Yaw Roll (X Y Z) <angle> = 0 0 0

This entity's orientation in the world. Roll is the rotation around the X axis, pitch is rotation around the Y axis and yaw is the rotation around the Z axis.

Parent <target_destination>

The name of this entity's parent in the movement hierarchy. Entities with parents move with their parent. Set an attachment point via 'parentname,attachment'.

Inputs

SpawnNPCInRadius <void>

Spawn an NPC somewhere within the maker's radius.

SpawnNPCInLine <void>

Spawn an NPC somewhere within a line behind the maker.

SpawnMultiple <integer>

Spawn multiple NPCs (uses destination group, else radius).

ChangeDestinationGroup <target_destination>

Switch to a different set of Destination entities.

SetMinimumSpawnDistance <integer>

Set the minimum spawn distance from player to destination node.

Inherited from BaseNPCMaker

Spawn <void>

Spawns an NPC.

Toggle <void>

Toggles the spawner enabled/disabled state.

Enable <void>

Enables the spawner.

Disable <void>

Disables the spawner.

AddMaxChildren <integer>

Adds to the number of NPCs that can spawn before the spawner is exhausted. If an exhausted spawner is given some children to spawn, it still won't begin spawning until it is re-enabled with the Enable input.

SetMaxChildren <integer>

Sets the number of NPCs that can spawn before the spawner is exhausted. If an exhausted spawner is given some children to spawn, it still won't begin spawning until it is re-enabled with the Enable input.

SetMaxLiveChildren <integer>

Sets the maximum number of NPCs that can be alive at any one time from this spawner.

SetSpawnFrequency <float>

Sets how often (in seconds) a new NPC will be spawned.

Inherited from BaseEntityPoint

Kill <void>

Removes this entity from the world.

KillHierarchy <void>

Removes this entity and all its children from the world.

SetParent <target_destination>

Changes the entity's parent in the movement hierarchy.

SetParentAttachment <string>

Change this entity to attach to a specific attachment point on its parent. Entities must be parented before being sent this input. The parameter passed in should be the name of the attachment.

SetParentAttachmentMaintainOffset <string>

Change this entity to attach to a specific attachment point on it's parent. Entities must be parented before being sent this input. The parameter passed in should be the name of the attachment. The entity will maintain it's position relative to the parent at the time it is attached.

ClearParent <void>

Removes this entity from the the movement hierarchy, leaving it free to move independently.

SetLocalAngles <vector>

Sets the rotation of the entity relative to the parent's rotation.

SetLocalOrigin <vector>

Sets the position of the entity relative to its parent if one exists. Otherwise relative to the world.

SetAbsAngles <vector>

Set this entity's angles, always relative to the world origin.

AddOutput <string>

Adds an entity I/O connection to this entity or changes keyvalues dynamically. Format: '<output name> <targetname>:<inputname>:<parameter>:<delay>:<max times to fire (-1 == infinite, 1 = only once)>' or 'keyvalue newval'. Very dangerous, use with care.

FireUser1 <void>

Causes this entity's OnUser1 output to be fired.

FireUser2 <void>

Causes this entity's OnUser2 output to be fired.

FireUser3 <void>

Causes this entity's OnUser3 output to be fired.

FireUser4 <void>

Causes this entity's OnUser4 output to be fired.

Use <void>

More or less replicates the player interacting with an entity. (+USE)

PassUser1 <string>

Causes this entity's OutUser1 output to be fired, passing along the parameter unchanged.

PassUser2 <string>

Causes this entity's OutUser2 output to be fired, passing along the parameter unchanged.

PassUser3 <string>

Causes this entity's OutUser3 output to be fired, passing along the parameter unchanged.

PassUser4 <string>

Causes this entity's OutUser4 output to be fired, passing along the parameter unchanged.

FireRandomUser <void>

Fires OnUser1, OnUser2, OnUser3, or OnUser4 with a 25% chance of each.

PassRandomUser <string>

Fires OutUser1, OutUser2, OutUser3, or OutUser4 with a 25% chance of each. The parameter is passed along unchanged.

KillIfNotVisible <void>

Removes this entity if it is not in a player's viewcone.

KillWhenNotVisible <void>

Removes this entity when it is not in a player's viewcone. You can pass a time for when this should start.

FireOutput <string>

Fires the named output on this entity. Format: '<output name>:<activator>:<caller>:<parameter>:<delay>' (OnDeath:hl3cardgame:gaben). Everything beyond the output name is optional.

RemoveOutput <string>

Removes all instances of the named output on this entity. Wildcards are supported, meaning you could just pass '*' to wipe all outputs from this entity.

AcceptInput <string>

Fires the named input on this entity. Format: '<input name>:<parameter>:<activator>:<caller>:<output ID>' (SetTarget:cheese). Everything beyond the input name is optional. Mind the fact this is arranged differently from FireOutput, having the parameter right after the input name.

CancelPending <void>

Cancels any events fired by this entity that are currently pending in the I/O event queue.

FreeChildren <void>

Unparents all direct children of this entity.

SetLocalVelocity <vector>

Sets this entity's current velocity.

SetLocalAngularVelocity <vector>

Sets this entity's current angular velocity.

AddSpawnFlags <integer>

Adds spawnflag(s) to this entity. Many spawnflags have their respective numbers suffixed in this FGD.

RemoveSpawnFlags <integer>

Removes spawnflag(s) to this entity. Many spawnflags have their respective numbers suffixed in this FGD.

AddSolidFlags <integer>

Adds solid flags to this entity.

RemoveSolidFlags <integer>

Removes solid flags from this entity.

ChangeVariable <string>

Similar to AddOutput, except it changes an internal variable similar to logic_datadesc_accessor instead. Very dangerous, use with care.

SetHealth <integer>

Sets this entity's health.

AddHealth <integer>

Adds to this entity's health.

RemoveHealth <integer>

Removes from this entity's health.

SetMaxHealth <integer>

Sets this entity's max health.

SetEntityName <target_destination>

Sets this entity's name that other entities should refer to it by.

SetTarget <target_destination>

Sets this entity's target. This is specific to certain entities, particularly logic entities that involve a target.

SetOwnerEntity <target_destination>

Sets this entity's owner entity. This has nothing to do with parenting and has more to do with collision and kill credits.

SetThinkNull <void>

Sets this entity's general think function to null. Behavior varies from entity to entity..

Touch <target_destination>

Simulates this entity touching the specified entity.

Outputs

Inherited from BaseNPCMaker

OnSpawnNPC <target_destination>

Fired when an NPC is spawned. The activator is the NPC, and the parameter is a pointer to the NPC.

OnAllSpawned <void>

Fired when the spawned is exhausted (all children have been spawned).

OnAllSpawnedDead <void>

Fired when the spawner is exhausted (all children have been spawned) and all spawned children have died.

OnAllLiveChildrenDead <void>

Fired when all spawned children have died. This does not mean the spawner is exhausted, so a new child may be spawned any time after this (unless the maker is disabled).

Inherited from BaseEntityPoint

OnUser1 <void>

Fired in response to FireUser1 input.

OnUser2 <void>

Fired in response to FireUser2 input.

OnUser3 <void>

Fired in response to FireUser3 input.

OnUser4 <void>

Fired in response to FireUser4 input.

OutUser1 <string>

Fires in response to PassUser1 input, with the parameter passed through unchanged.

OutUser2 <string>

Fires in response to PassUser2 input, with the parameter passed through unchanged.

OutUser3 <string>

Fires in response to PassUser3 input, with the parameter passed through unchanged.

OutUser4 <string>

Fires in response to PassUser4 input, with the parameter passed through unchanged.