logic_measure_movement is a point entity available in all Source games. This entity measures the movement of an entity relative to another entity and then applies that movement to a third entity.
logic_measure_movement's process can be described like this:
- The position of the Entity to Move is obtained. Let's say it's
[100 225 0].
- The position of the Measure Reference is obtained. Let's say it's
[50 300 0].
- The position of the Entity to Move is subtracted by the position of the Measure Reference, creating a "relative position" difference. In this case, it would be
[100 225 0]-
[50 300 0], which equates to
[50 -75 0].
- The position of the Movement Reference is obtained. Let's say it's
[150 50 100].
- The "relative difference" position is added onto the position of the Movement Reference. In this case, it would be
[50 -75 0]+
[150 50 100], which equates to
[200 -25 100].
- The Entity to Move is teleported to the sum of the "relative difference" position and the position of the Movement Reference, which in this case means the entity is teleported to
[200 -25 100].
logic_measure_movement is very flexible and can be used to make one entity mimic the movement of another from another room (e.g. a
point_camera in a script_intro). It can also be used to serve as an alternative to parenting, especially since it can simulate parenting on physics objects, which don't support parenting and would normally use
Warning: Does not properly update collision physics on the object being moved.
Teleportinstead updates entity interpolation correctly and may or may not solve the collision physics warning described above.
- Entity to Measure
- Entity whose movement you want to measure.
- Measure Reference
- The movement of Entity to Measure will be measured relative to this entity.
- Entity to Move
- This entity will be moved to mimic the motions of Entity to Measure.
- Movement Reference
- The Entity to Move will move relative to this entity.
- Movement scale
- A scale to divide the measured movements by, before applying those movements to the Entity to Move.
1 = target entity moves as much as the measured entity,
2 = target entity moves half as far as the measured entity, and
0.5 = target entity moves twice as far as the measured entity.
- Measurement Type
- What to measure.
- 0 : Position
- 1 : Eye position
- Entity Scripts
- Space delimited list of VScript files (without file extension) that are executed after all entities have spawned. The scripts are all executed in the same script scope, later ones overwriting any identical variables and functions.
- Script think function
- Name of a function in this entity's script which will be called automatically every 100 milliseconds (ten times a second) for the duration of the script. It can be used to create timers or to simulate autonomous behavior. The return value (if present) will set the time until the next call. Note:Try to avoid expensive operations in this function, as it may cause performance problems.
- Set the Entity to Measure, whose movement should be measured.
- Set the Measure Reference entity.
- Set the Entity to Move, which will be moved to mimic the measured entity.
- Set the Movement Reference entity.
- Set the scale to divide the measured movements by.
- Enable the logic_measure_movement.
- Disable the logic_measure_movement.
- Removes this entity from the world.
- Removes this entity and its children from the world. Note:Entities already remove orphaned children upon being removed, but this input removes all children on the same frame, being marginally faster than
- Adds a keyvalue/output to this entity. It can be potentially very dangerous, use with care.
<output name> <targetname>:<inputname>:<parameter>:<delay>:<max times to fire, -1 means infinite>
- Fire the
OnUseroutputs; see User Inputs and Outputs.
- Same as a player invoking +use; may not do anything depending on the entity. Can also be invoked by firing an output that does not specify an input.
- Execute a VScript file from disk, without file extension. The script contents are merged with the script scope of the receiving entity.
- Execute a string of VScript source code in the scope of the entity receiving the input. String quotation may be needed when fired via console. Bug: In , the code is executed in the script scope of the entity that fires the output, not the one receiving the input.Warning: Never try to pass string parameters to a script function with this input. It will corrupt the VMF structure because of the nested quotation marks, which then must be removed manually with a text editor.
- Execute a VScript function in the scope of the receiving entity.
- Send this entity to a spot in the map. If the entity is parented to something, it will be offset from the parent by this amount.
- Set this entity's angles.
- These outputs each fire in response to the firing of the like-numbered
FireUser4Input; see User Inputs and Outputs.
- This output fires when the entity is killed and removed from the game.