Dod control point: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 Note:This entity works in conjunction with dod_capture_area or dod_bomb_target. It can also be used on its own with the non-FGD SetOwner input, to create custom gamemodes.
Note:This entity works in conjunction with dod_capture_area or dod_bomb_target. It can also be used on its own with the non-FGD SetOwner input, to create custom gamemodes.
 Note:A maximum of 8 control points can be in a single map.
Note:A maximum of 8 control points can be in a single map.
 Note: See Model entity/Generic Keyvalues, Inputs and Outputs for keyvalues and inputs that affect model rendering.
Note: See Model entity/Generic Keyvalues, Inputs and Outputs for keyvalues and inputs that affect model rendering. 
Note that the following keyvalues are unavailable due to being overridden by game code:
model, body, playbackrate, cycle
It may still be possible to use their associated inputs or AddOutput them.
 Important:Avoid changing the Axis/Allies/Reset models and bodygroups from Valve's defaults (
Important:Avoid changing the Axis/Allies/Reset models and bodygroups from Valve's defaults ( 
 
 Note:The !activator and !caller for all the following outputs is identical to !self.
Note:The !activator and !caller for all the following outputs is identical to !self.
		
	
| SirYodaJedi (talk | contribs)  | |||
| (91 intermediate revisions by 16 users not shown) | |||
| Line 1: | Line 1: | ||
| {{ | {{tabs|dod_control_point|goldsrc = 1|source = 1|main = source}} | ||
| {{CD|CControlPoint|file1=dod/dod_control_point.h|base=CBaseAnimating}} | |||
| {{this is a|model entity|name=dod_control_point|game=Day of Defeat: Source}} | |||
| This entity is usually represented visually by a flag (but this is not required). In turn, it represents a capturable location within the map. | |||
| {{Note|This entity works in conjunction with {{ent|dod_capture_area}} or {{ent|dod_bomb_target}}. It can also be used on its own with the [[non-FGD features|non-FGD]] {{mono|SetOwner}} input, to create custom gamemodes.}} | |||
| {{Note|A maximum of 8 control points can be in a single map.}} | |||
| == Keyvalues == | |||
| {{studio rendering note|model, body, playbackrate, cycle}} | |||
| {{KV Targetname}} | |||
| {{KV Angles}} | |||
| {{KV StartDisabled}} | |||
| {{KV|LOCALIZED name to print on the hud|intn=point_printname|string|Location name; acts like {{ent|dod_location}}, and also displays on the Hud when captured. Despite what the SmartEdit name implies, this can be a regular string, not only a reference to a localization string.<br>Unlike {{ent|dod_location}}, this does not have a 63-character limit.}} | |||
| {{KV|Time based point value for Allies|intn=point_timedpoints_allies|integer|Points given to allies as they own this flag over time.}} | |||
| {{KV|Time based point value for Axis|intn=point_timedpoints_axis|integer|Points given to axis as they own this flag over time.}} | |||
| {{KV|Default Owner of the control point|intn=point_default_owner|integer choices|The default owner of this control point at round start.}} | |||
| :{| class=standard-table | |||
| ! Literal Value || Description | |||
| |- | |||
| | 0 || Neutral | |||
| |- | |||
| | 2 || Allies | |||
| |- | |||
| | 3 || Axis | |||
| |} | |||
| {{KV|Sound Made when Axis captures|intn=point_axis_capsound|sound|Sound made when axis captures. The official maps use {{code|Voice.German_FlagCapture}}.}} | |||
| {{KV|Sound Made when Allies captures|intn=point_allies_capsound|sound|Sound made when allies captures. The official maps use {{code|Voice.US_FlagCapture}}.}} | |||
| {{KV|Sound Made when point resets|intn=point_resetsound|sound|Sound made when point resets.}} | |||
| == | {{minititle|Display model}} | ||
| {{modernImportant|Avoid changing the Axis/Allies/Reset models and bodygroups from Valve's defaults ({{file|models/mapmodels/flags|mdl}}) unless you know what you are doing; players rely upon these to know who owns a control point!}}  | |||
| {{KV|Allies Model|intn=point_allies_model|studio|Model when allies own point.}} | |||
| {{KV|Allies model bodygroup|intn=point_allies_model_bodygroup|integer|Allies model bodygroup. Default value used by Valve is "1".}} | |||
| {{KV|Axis Model|intn=point_axis_model|studio|Model when axis own point.}} | |||
| {{KV|Axis model bodygroup|intn=point_axis_model_bodygroup|integer|Axis model bodygroup. Default value used by Valve is "0".}} | |||
| {{KV|Reset Model|intn=point_reset_model|studio|Reset model when point resets or nobody owns the point.}} | |||
| {{KV|Reset model bodygroup|intn=point_reset_model_bodygroup|integer|Reset model bodygroup. Default value used by Valve is "3".}} | |||
| :{{note|Due to limitations in {{Hammer|2}}'s FGD syntax, the default FGD will always show this entity as an Axis flag, regardless of what is set here; see [[#Enhanced FGD entry|Enhanced FGD entry]] for a workaround (requires {{hammer++|2}}).}} | |||
| {{KV|Group Index|intn=point_group|integer|}} | |||
| :  | :{{confirm|What is this for? Most maps leave it as "0".}} | ||
| {{KV|Index of this point (unique)|intn=point_index|integer|The unique number of this control point to refer {{ent|Dod_capture_area}}.}} | |||
| {{KV|Hud icon material when nobody owns point|intn=point_hud_icon_neutral|material|The [[material]] to show on the Hud when nobody owns the point.}} | |||
| {{KV|Hud icon material when Axis owns point|intn=point_hud_icon_axis|material|The [[material]] to show on the Hud when Axis owns the point.}} | |||
| {{KV|Hud icon material when Allies owns point|intn=point_hud_icon_allies|material|The [[material]] to show on the Hud when Allies owns the point.}} | |||
| {{KV|Hud icon - Bomb planted|intn=point_hud_icon_timercap|material|The [[material]] to show on the Hud when a bomb is planted.}} | |||
| {{KV|Hud icon - Point destroyed|intn=point_hud_icon_bombed|material|The [[material]] to show on the Hud when the point is destroyed.}} | |||
| {{KV|Number of Bombs required to destroy|intn=point_num_bombs|integer|The number of [[dod_bomb_target|bombs]] required to destroy the point, if used as a bomb objective. Leave at zero if using [[dod_capture_area|a capture area]] instead.}} | |||
| :{{confirm|Limit seems to be at least 8, if not higher, even though FGD limit is 3.}} | |||
| == Flags == | |||
| {{Fl|1|Hide Control Point on HUD|If un-ticked an icon will be shown on the HUD, in the top left hand side of the display giving the status of the control point, to all the players in the game.}} | |||
| {{Fl|2|Start with model hidden|Applies [[EF_NODRAW]] when the entity spawns at the start of each round.}} | |||
| {{Fl|4|Give tick points for bombs remaining}} | |||
| == Inputs == | |||
| {{I|SetOwner|param=integer choices|nofgd=1|Set the current owner of the point. Use this if using a custom objective instead of [[dod_capture_area]] or [[dod_bomb_target]].}} | |||
| :{| class=standard-table | |||
| ! Literal Value || Description | |||
| :{| | |||
| ! | |||
| |- | |- | ||
| | 0 ||  | | 0 || Neutral | ||
| |- | |- | ||
| | 2 || Allies | | 2 || Allies | ||
| Line 42: | Line 66: | ||
| | 3 || Axis | | 3 || Axis | ||
| |} | |} | ||
| :{{bug|hidetested=1|Capper as sent to the {{codelink|Day of Defeat: Source/Scripting/Game Events#dod_point_captured|alt=dod_point_captured}} game_event is the index of the [[!caller]], not the [[!activator]]. }} | |||
| {{I|HideModel|param=void|Hide the control point model (adds [[EF_NODRAW]])}} | |||
| {{I|ShowModel|param=void|Unhide the control point model (removes [[EF_NODRAW]])}} | |||
| == Outputs == | |||
| {{note|The [[!activator]] and [[!caller]] for all the following outputs is identical to [[!self]].}} | |||
| {{O|OnAlliesCap|param=void|Trigger when owner is changed to allies}} | |||
| {{O|OnAxisCap|param=void|Trigger when owner is changed to axis}} | |||
| {{O|OnCapReset|param=void|Trigger when owner is changed to neutral}} | |||
| {{O|AlliesCapturePoint|param=void|Trigger when Allies capture this point (not triggered on round resets)}} | |||
| {{O|AxisCapturePoint|param=void|Trigger when Allies capture this point (not triggered on round resets)}} | |||
| == Enhanced FGD entry == | |||
| : < | [[Category:Custom FGDs]] | ||
| Replace the FGD entry with this to add the ability to preview custom flag models in {{hammer++|2}}, automatically set default capture sounds, add missing {{code|SetOwner}} input, and provide additional SmartEdit descriptions. | |||
| {{expand|1=<source lang=cpp> | |||
| @PointClass base(EnableDisable,Targetname,Angles) studio() = dod_control_point :  | |||
| 	"A Control Point, representing a capturable objective; there can be up to 8 of these in a map.\n\nCan be the visual representation of the control point, or the model can be disabled and a prop_dynamic be used via this entity's outputs instead." | |||
| [	 | |||
| 	spawnflags(flags) = | |||
| 	[ | |||
| 		1: "Hide Control Point on HUD" : 0 | |||
| 		2: "Start with model hidden" : 0 | |||
| 		4: "Give tick points for bombs remaining" : 0 | |||
| 	] | |||
| == | 	point_printname(string) : "Location name" : "TODO: Set Name" : "The control point name displayed on the Hud when captured. Can be either a regular string or a reference to a localization string." | ||
| 	point_timedpoints_axis(integer) : "Time based point value for Axis" : 0 : "Points given to Axis as they own this flag over time." | |||
| 	point_timedpoints_allies(integer) : "Time based point value for Allies" : 0 : "Points given to Allies as they own this flag over time." | |||
| 	point_default_owner(choices) : "Default owner of the control point" : 0 = | |||
| 	[ | |||
| 		0 : "Neutral" | |||
| 		2 : "Allies" | |||
| 		3 : "Axis" | |||
| 	] | |||
| 	point_axis_capsound(sound) : "Axis capture sound" : "Voice.German_FlagCapture" : "Sound made when Axis capture this point" | |||
| 	point_allies_capsound(sound) : "Allies capture sound" : "Voice.US_FlagCapture" : "Sound made when Allies capture this point" | |||
| 	point_resetsound(sound) : "Sound made when point resets" : "" | |||
| 	// first, we define some KVs that are used by Hammer++, but ignored by the game, to get around some editor hardcoding | |||
| 	model(studio) : "Editor model" : "models/mapmodels/flags.mdl" : "Model to display in the map editor (no effect in-game). This should match the model used by the default owner." | |||
| 	body(choices) : "Editor model bodygroup" : : "Bodygroup to use for the editor model (no effect in-game). This should match the bodygroup used by the default owner (descriptions given are for models/mapmodels/flags.mdl)." = | |||
| 	[ | |||
| 		0 : "0 (Vanilla is German)" | |||
| 		1 : "1 (Vanilla is American)" | |||
| 		2 : "2 (Vanilla is British)" | |||
| 		3 : "3 (Vanilla is Neutral)" | |||
| 	] | |||
| 	// Then, the actual KVs used in-game | |||
| 	point_axis_model(studio) 	: "Axis model" : "models/mapmodels/flags.mdl" : "Model when Axis own the point" | |||
| 	point_axis_model_bodygroup(integer) : "Axis model bodygroup" : 0 | |||
| 	point_allies_model(studio) 	: "Allies model" : "models/mapmodels/flags.mdl" : "Model to use when Allies own the point" | |||
| :  | 	point_allies_model_bodygroup(integer) : "Allies model bodygroup" : 1 | ||
| 	point_reset_model(studio) 	: "Neutral model" : "models/mapmodels/flags.mdl" : "Model when neither team owns the point" | |||
| :  | 	point_reset_model_bodygroup(integer) : "Neutral model bodygroup" : 3 | ||
| 	output OnAxisCap(void) : "Send when owner is changed to Axis (including round resets)" | |||
| :  | 	output OnAlliesCap(void) : "Send when owner is changed to Allies (including round resets)" | ||
| 	output OnCapReset(void) : "Send when owner is changed to Neutral (including round resets)" | |||
| 	output AxisCapturePoint(void) : "Send when Axis capture this point (not triggered on round resets)" | |||
| 	output AlliesCapturePoint(void) : "Send when Allies capture this point (not triggered on round resets)" | |||
| 	point_group(integer) : "Group Index" : 0 | |||
| 	point_index(integer) : "Index of this point (unique)" : 0 : "Unique identifier; used with dod_capture_area" | |||
| :  | |||
| 	point_hud_icon_neutral(material)	: "Hud icon - Neutral" : "sprites/obj_icons/icon_obj_neutral" | |||
| :  | 	point_hud_icon_axis(material)	: "Hud icon - Axis" : "sprites/obj_icons/icon_obj_axis" | ||
| 	point_hud_icon_allies(material)	: "Hud icon - Allies" : "sprites/obj_icons/icon_obj_allies" | |||
| 	point_hud_icon_timercap(material) : "Hud icon - bomb planted" : "sprites/obj_icons/icon_obj_neutral" | |||
| 	point_hud_icon_bombed(material) : "Hud icon - point destroyed" : "sprites/obj_icons/icon_obj_neutral" | |||
| 	input HideModel(void) : "Hide the control point model" | |||
| 	input ShowModel(void) : "Show the control point model" | |||
| 	input SetOwner(integer) : "Set the current owner of this point (0=Neutral,2=Allies,3=Axis)" | |||
| 	point_num_bombs(choices) : "Number of Bombs required to destroy" : 0 : "The number of bomb required to destroy the point, if used as a bomb objective. Ignore if used as a flag." = | |||
| 	[ | |||
| 		0 : "0" | |||
| 		1 : "1" | |||
| 		2 : "2" | |||
| 		3 : "3" | |||
| 	] | |||
| 	// ===== CBaseAnimating KVs and I/O that aren't overridden by dod_control_point ===== | |||
| 	solid(choices) : "Collisions" : 0 : "Note that the default model lacks a collision mesh, so VPhysics will be unavailable." = | |||
| 	[ | |||
| 		0 : "Not Solid" | |||
| 		2 : "Use Bounding Box" | |||
| 		6 : "Use VPhysics" | |||
| 	] | |||
| 	skin(integer) : "Skin" : : "Some models have multiple versions of their textures, called skins. Set this to a number other than 0 to use that skin instead of the default.\n\nUse the `skin` input with the `OnAxisCap`, `OnAlliesCap`, and `OnCapReset` outputs if you need to use different skin indices per faction." | |||
| 	modelscale(float) : "Model Scale" : : "A multiplier for the size of the model." | |||
| 	sequence(integer) : "Animation Sequence" : : "Default animation sequence for the model to be playing after spawning. (Default 0)" | |||
| 	lightingorigin(target_destination) : "Lighting Origin" : : "Name of entity (not info_lighting!) from which to sample lighting instead of this entity's $illumposition." | |||
| == | 	disableshadows(choices) : "Disable Shadows" : "" : "Used to disable dynamic shadows on this entity." = | ||
| 	[ | |||
| 		"" : "No" | |||
| 		1 : "Yes" | |||
| 	] | |||
| 	disablereceiveshadows(choices) : "Disable Receiving Shadows" : "" : "Prevent the entity from receiving dynamic shadows on itself."= | |||
| 	[ | |||
| 		"" : "No" | |||
| 		1 : "Yes" | |||
| 	] | |||
| 	shadowcastdist(integer) : "Shadow Cast Distance" : : "Sets how far the entity casts dynamic shadows. 0 means default distance from the shadow_control entity." | |||
| 	// Inputs | |||
| 	input skin(integer) : "Changes the model skin to the specified number." | |||
| 	input DisableShadow(void) : "Turn shadow off." | |||
| 	input EnableShadow(void) : "Turn shadow on." | |||
| 	input AlternativeSorting(bool) : "Used to attempt to fix sorting problems when rendering. True activates, false deactivates" | |||
| 	input SetModelScale(string) : "Takes two values separated by a space. The first is the target model scale. The second value is the number of seconds the change in scale will be spread over." | |||
| 	// Outputs | |||
| 	output OnIgnite(void) : "Fired when this object catches fire." | |||
| ] | |||
| </source> | |||
| }} | |||
Latest revision as of 07:36, 23 July 2025
|  Class hierarchy | 
|---|
| CControlPoint | 
|  dod/dod_control_point.h | 
dod_control_point  is a   model entity  available in  Day of Defeat: Source.
 Day of Defeat: Source.
This entity is usually represented visually by a flag (but this is not required). In turn, it represents a capturable location within the map.
 Note:This entity works in conjunction with dod_capture_area or dod_bomb_target. It can also be used on its own with the non-FGD SetOwner input, to create custom gamemodes.
Note:This entity works in conjunction with dod_capture_area or dod_bomb_target. It can also be used on its own with the non-FGD SetOwner input, to create custom gamemodes. Note:A maximum of 8 control points can be in a single map.
Note:A maximum of 8 control points can be in a single map.Keyvalues
 Note: See Model entity/Generic Keyvalues, Inputs and Outputs for keyvalues and inputs that affect model rendering.
Note: See Model entity/Generic Keyvalues, Inputs and Outputs for keyvalues and inputs that affect model rendering. Note that the following keyvalues are unavailable due to being overridden by game code:
model, body, playbackrate, cycle
It may still be possible to use their associated inputs or AddOutput them.
- Name (targetname) <string>[ Edit ]
- The name that other entities refer to this entity by, via Inputs/Outputs or other keyvalues (e.g. parentnameortarget).
 Also displayed in Hammer's 2D views and Entity Report.See also: Generic Keyvalues, Inputs and Outputs available to all entities
- Pitch Yaw Roll (Y Z X) (angles) <QAngle>
- This entity's orientation in the world. Pitch is rotation around the Y axis, yaw is the rotation around the Z axis, roll is the rotation around the X axis.
- Start Disabled (StartDisabled) <boolean>
- Stay dormant until activated (with theEnableinput).
- LOCALIZED name to print on the hud (point_printname) <string>
- Location name; acts like dod_location, and also displays on the Hud when captured. Despite what the SmartEdit name implies, this can be a regular string, not only a reference to a localization string.
 Unlike dod_location, this does not have a 63-character limit.
- Time based point value for Allies (point_timedpoints_allies) <integer>
- Points given to allies as they own this flag over time.
- Time based point value for Axis (point_timedpoints_axis) <integer>
- Points given to axis as they own this flag over time.
- Default Owner of the control point (point_default_owner) <integer choices>
- The default owner of this control point at round start.
- Literal Value - Description - 0 - Neutral - 2 - Allies - 3 - Axis 
- Sound Made when Axis captures (point_axis_capsound) <sound>
- Sound made when axis captures. The official maps use Voice.German_FlagCapture.
- Sound Made when Allies captures (point_allies_capsound) <sound>
- Sound made when allies captures. The official maps use Voice.US_FlagCapture.
- Sound Made when point resets (point_resetsound) <sound>
- Sound made when point resets.
Display model:
 Important:Avoid changing the Axis/Allies/Reset models and bodygroups from Valve's defaults (
Important:Avoid changing the Axis/Allies/Reset models and bodygroups from Valve's defaults (
models/mapmodels/flags.mdl) unless you know what you are doing; players rely upon these to know who owns a control point!- Allies Model (point_allies_model) <model path>
- Model when allies own point.
- Allies model bodygroup (point_allies_model_bodygroup) <integer>
- Allies model bodygroup. Default value used by Valve is "1".
- Axis Model (point_axis_model) <model path>
- Model when axis own point.
- Axis model bodygroup (point_axis_model_bodygroup) <integer>
- Axis model bodygroup. Default value used by Valve is "0".
- Reset Model (point_reset_model) <model path>
- Reset model when point resets or nobody owns the point.
- Reset model bodygroup (point_reset_model_bodygroup) <integer>
- Reset model bodygroup. Default value used by Valve is "3".
 Note:Due to limitations in Note:Due to limitations in Hammer's FGD syntax, the default FGD will always show this entity as an Axis flag, regardless of what is set here; see Enhanced FGD entry for a workaround (requires Hammer's FGD syntax, the default FGD will always show this entity as an Axis flag, regardless of what is set here; see Enhanced FGD entry for a workaround (requires Hammer++). Hammer++).
- Group Index (point_group) <integer>
 Confirm:What is this for? Most maps leave it as "0". Confirm:What is this for? Most maps leave it as "0".
- Index of this point (unique) (point_index) <integer>
- The unique number of this control point to refer Dod_capture_area.
- Hud icon material when nobody owns point (point_hud_icon_neutral) <material>
- The material to show on the Hud when nobody owns the point.
- Hud icon material when Axis owns point (point_hud_icon_axis) <material>
- The material to show on the Hud when Axis owns the point.
- Hud icon material when Allies owns point (point_hud_icon_allies) <material>
- The material to show on the Hud when Allies owns the point.
- Hud icon - Bomb planted (point_hud_icon_timercap) <material>
- The material to show on the Hud when a bomb is planted.
- Hud icon - Point destroyed (point_hud_icon_bombed) <material>
- The material to show on the Hud when the point is destroyed.
- Number of Bombs required to destroy (point_num_bombs) <integer>
- The number of bombs required to destroy the point, if used as a bomb objective. Leave at zero if using a capture area instead.
 Confirm:Limit seems to be at least 8, if not higher, even though FGD limit is 3. Confirm:Limit seems to be at least 8, if not higher, even though FGD limit is 3.
Flags
- Hide Control Point on HUD : [1]
- If un-ticked an icon will be shown on the HUD, in the top left hand side of the display giving the status of the control point, to all the players in the game.
- Start with model hidden : [2]
- Applies EF_NODRAW when the entity spawns at the start of each round.
- Give tick points for bombs remaining : [4]
Inputs
- SetOwner <integer choices> !FGD
- Set the current owner of the point. Use this if using a custom objective instead of dod_capture_area or dod_bomb_target.
- Literal Value - Description - 0 - Neutral - 2 - Allies - 3 - Axis 
 Bug:Capper as sent to the dod_point_captured game_event is the index of the !caller, not the !activator. Bug:Capper as sent to the dod_point_captured game_event is the index of the !caller, not the !activator.
- HideModel <void>
- Hide the control point model (adds EF_NODRAW)
- ShowModel <void>
- Unhide the control point model (removes EF_NODRAW)
Outputs
 Note:The !activator and !caller for all the following outputs is identical to !self.
Note:The !activator and !caller for all the following outputs is identical to !self.- OnAlliesCap <void>
- Trigger when owner is changed to allies
- OnAxisCap <void>
- Trigger when owner is changed to axis
- OnCapReset <void>
- Trigger when owner is changed to neutral
- AlliesCapturePoint <void>
- Trigger when Allies capture this point (not triggered on round resets)
- AxisCapturePoint <void>
- Trigger when Allies capture this point (not triggered on round resets)
Enhanced FGD entry
Replace the FGD entry with this to add the ability to preview custom flag models in  Hammer++, automatically set default capture sounds, add missing
 Hammer++, automatically set default capture sounds, add missing SetOwner input, and provide additional SmartEdit descriptions.
| @PointClass base(EnableDisable,Targetname,Angles) studio() = dod_control_point : 
	"A Control Point, representing a capturable objective; there can be up to 8 of these in a map.\n\nCan be the visual representation of the control point, or the model can be disabled and a prop_dynamic be used via this entity's outputs instead."
[	
	spawnflags(flags) =
	[
		1: "Hide Control Point on HUD" : 0
		2: "Start with model hidden" : 0
		4: "Give tick points for bombs remaining" : 0
	]
	point_printname(string) : "Location name" : "TODO: Set Name" : "The control point name displayed on the Hud when captured. Can be either a regular string or a reference to a localization string."
	
	point_timedpoints_axis(integer) : "Time based point value for Axis" : 0 : "Points given to Axis as they own this flag over time."
	point_timedpoints_allies(integer) : "Time based point value for Allies" : 0 : "Points given to Allies as they own this flag over time."
	
	point_default_owner(choices) : "Default owner of the control point" : 0 =
	[
		0 : "Neutral"
		2 : "Allies"
		3 : "Axis"
	]
	point_axis_capsound(sound) : "Axis capture sound" : "Voice.German_FlagCapture" : "Sound made when Axis capture this point"
	point_allies_capsound(sound) : "Allies capture sound" : "Voice.US_FlagCapture" : "Sound made when Allies capture this point"
	point_resetsound(sound) : "Sound made when point resets" : ""
	
	// first, we define some KVs that are used by Hammer++, but ignored by the game, to get around some editor hardcoding
	model(studio) : "Editor model" : "models/mapmodels/flags.mdl" : "Model to display in the map editor (no effect in-game). This should match the model used by the default owner."
	body(choices) : "Editor model bodygroup" : : "Bodygroup to use for the editor model (no effect in-game). This should match the bodygroup used by the default owner (descriptions given are for models/mapmodels/flags.mdl)." =
	[
		0 : "0 (Vanilla is German)"
		1 : "1 (Vanilla is American)"
		2 : "2 (Vanilla is British)"
		3 : "3 (Vanilla is Neutral)"
	]
	
	// Then, the actual KVs used in-game
	point_axis_model(studio) 	: "Axis model" : "models/mapmodels/flags.mdl" : "Model when Axis own the point"
	point_axis_model_bodygroup(integer) : "Axis model bodygroup" : 0
	point_allies_model(studio) 	: "Allies model" : "models/mapmodels/flags.mdl" : "Model to use when Allies own the point"
	point_allies_model_bodygroup(integer) : "Allies model bodygroup" : 1
	point_reset_model(studio) 	: "Neutral model" : "models/mapmodels/flags.mdl" : "Model when neither team owns the point"
	point_reset_model_bodygroup(integer) : "Neutral model bodygroup" : 3
	output OnAxisCap(void) : "Send when owner is changed to Axis (including round resets)"
	output OnAlliesCap(void) : "Send when owner is changed to Allies (including round resets)"
	output OnCapReset(void) : "Send when owner is changed to Neutral (including round resets)"
	
	output AxisCapturePoint(void) : "Send when Axis capture this point (not triggered on round resets)"
	output AlliesCapturePoint(void) : "Send when Allies capture this point (not triggered on round resets)"
	point_group(integer) : "Group Index" : 0
	point_index(integer) : "Index of this point (unique)" : 0 : "Unique identifier; used with dod_capture_area"
	point_hud_icon_neutral(material)	: "Hud icon - Neutral" : "sprites/obj_icons/icon_obj_neutral"
	point_hud_icon_axis(material)	: "Hud icon - Axis" : "sprites/obj_icons/icon_obj_axis"
	point_hud_icon_allies(material)	: "Hud icon - Allies" : "sprites/obj_icons/icon_obj_allies"
	point_hud_icon_timercap(material) : "Hud icon - bomb planted" : "sprites/obj_icons/icon_obj_neutral"
	point_hud_icon_bombed(material) : "Hud icon - point destroyed" : "sprites/obj_icons/icon_obj_neutral"
	
	input HideModel(void) : "Hide the control point model"
	input ShowModel(void) : "Show the control point model"
	input SetOwner(integer) : "Set the current owner of this point (0=Neutral,2=Allies,3=Axis)"
	
	point_num_bombs(choices) : "Number of Bombs required to destroy" : 0 : "The number of bomb required to destroy the point, if used as a bomb objective. Ignore if used as a flag." =
	[
		0 : "0"
		1 : "1"
		2 : "2"
		3 : "3"
	]
	
	// ===== CBaseAnimating KVs and I/O that aren't overridden by dod_control_point =====
	solid(choices) : "Collisions" : 0 : "Note that the default model lacks a collision mesh, so VPhysics will be unavailable." =
	[
		0 : "Not Solid"
		2 : "Use Bounding Box"
		6 : "Use VPhysics"
	]
	skin(integer) : "Skin" : : "Some models have multiple versions of their textures, called skins. Set this to a number other than 0 to use that skin instead of the default.\n\nUse the `skin` input with the `OnAxisCap`, `OnAlliesCap`, and `OnCapReset` outputs if you need to use different skin indices per faction."
	modelscale(float) : "Model Scale" : : "A multiplier for the size of the model."
	sequence(integer) : "Animation Sequence" : : "Default animation sequence for the model to be playing after spawning. (Default 0)"
	lightingorigin(target_destination) : "Lighting Origin" : : "Name of entity (not info_lighting!) from which to sample lighting instead of this entity's $illumposition."
	disableshadows(choices) : "Disable Shadows" : "" : "Used to disable dynamic shadows on this entity." =
	[
		"" : "No"
		1 : "Yes"
	]
	disablereceiveshadows(choices) : "Disable Receiving Shadows" : "" : "Prevent the entity from receiving dynamic shadows on itself."=
	[
		"" : "No"
		1 : "Yes"
	]
	shadowcastdist(integer) : "Shadow Cast Distance" : : "Sets how far the entity casts dynamic shadows. 0 means default distance from the shadow_control entity."
	// Inputs
	input skin(integer) : "Changes the model skin to the specified number."
	input DisableShadow(void) : "Turn shadow off."
	input EnableShadow(void) : "Turn shadow on."
	input AlternativeSorting(bool) : "Used to attempt to fix sorting problems when rendering. True activates, false deactivates"
	input SetModelScale(string) : "Takes two values separated by a space. The first is the target model scale. The second value is the number of seconds the change in scale will be spread over."
	// Outputs
	output OnIgnite(void) : "Fired when this object catches fire."
]
 |