Phys hinge: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
 Note:Helper must be used to make hinge work or you will get an error. (ERROR: phys_hinge bad data)
Note:Helper must be used to make hinge work or you will get an error. (ERROR: phys_hinge bad data)
		
	
| PersonMeetup (talk | contribs) m (Updated the intro paragraph so that information on the Helper page was on it, and redirected where the helper link brings users.) | m (Add internal names of keyvalue keys) | ||
| Line 9: | Line 9: | ||
| == Keyvalues == | == Keyvalues == | ||
| {{KV|Friction|float|Resistance/friction in the hinge.}}{{note|This is not a percentage, but rather 1000 HL Units. 100 is a good starting value.}} | {{KV|Friction|intn=hingefriction|float|Resistance/friction in the hinge.}}{{note|This is not a percentage, but rather 1000 HL Units. 100 is a good starting value.}} | ||
| {{KV|Hinge Axis|vecline|Define the axis of the hinge by dragging the entity helper in Hammer's 2D views.}} | {{KV|Hinge Axis|intn=hingeaxis|vecline|Define the axis of the hinge by dragging the entity helper in Hammer's 2D views.}} | ||
| {{KV|Load Scale|float|Scale of the load connected to this hinge (1{{=}}just the objects directly connected. {{todo|What does this do? It doesn't seem to increase precision when heavy objects are attached.}})}} | {{KV|Load Scale|intn=SystemLoadScale|float|Scale of the load connected to this hinge (1{{=}}just the objects directly connected. {{todo|What does this do? It doesn't seem to increase precision when heavy objects are attached.}})}} | ||
| {{KV|Minimum Sound Velocity|float|When travelling below this many units/sec, will not play any sound.}} | {{KV|Minimum Sound Velocity|intn=minSoundThreshold|float|When travelling below this many units/sec, will not play any sound.}} | ||
| {{KV|Full Sound Velocity|float|When travelling at this speed or above, will play sound at full volume.}} | {{KV|Full Sound Velocity|intn=maxSoundThreshold|float|When travelling at this speed or above, will play sound at full volume.}} | ||
| {{KV|Travel sound (forward)|sound|Play this sound when travelling forward on helper axis}} | {{KV|Travel sound (forward)|intn=slidesoundfwd|sound|Play this sound when travelling forward on helper axis}} | ||
| {{KV|Travel sound (backward)|sound|Play this sound when travelling backward on helper axis}} | {{KV|Travel sound (backward)|intn=slidesoundback|sound|Play this sound when travelling backward on helper axis}} | ||
| {{KV|Reversal sound threshold (small)|float|When accelerating by more than this many units/sec^2 opposite to direction of travel, play the small reversal sound.}} | {{KV|Reversal sound threshold (small)|intn=reversalsoundthresholdSmall|float|When accelerating by more than this many units/sec^2 opposite to direction of travel, play the small reversal sound.}} | ||
| {{KV|Reversal sound threshold (medium)|float|When accelerating by more than this many units/sec^2 opposite to direction of travel, play the medium reversal sound.}} | {{KV|Reversal sound threshold (medium)|intn=reversalsoundthresholdMedium|float|When accelerating by more than this many units/sec^2 opposite to direction of travel, play the medium reversal sound.}} | ||
| {{KV|Reversal sound threshold (large)|float|When accelerating by more than this many units/sec^2 opposite to direction of travel, play the large reversal sound.}} | {{KV|Reversal sound threshold (large)|intn=reversalsoundthresholdLarge|float|When accelerating by more than this many units/sec^2 opposite to direction of travel, play the large reversal sound.}} | ||
| {{KV|Reversal sound (small)|sound|Play this sound when making a hard reverse over the small threshold but less than medium}} | {{KV|Reversal sound (small)|intn=reversalsoundSmall|sound|Play this sound when making a hard reverse over the small threshold but less than medium}} | ||
| {{KV|Reversal sound (medium)|sound|Play this sound when making a hard reverse over the medium threshold but less than large}} | {{KV|Reversal sound (medium)|intn=reversalsoundMedium|sound|Play this sound when making a hard reverse over the medium threshold but less than large}} | ||
| {{KV|Reversal sound (large)|sound|Play this sound when making a hard reverse over the large threshold}} | {{KV|Reversal sound (large)|intn=reversalsoundLarge|sound|Play this sound when making a hard reverse over the large threshold}} | ||
| {{KV TwoObjectPhysics}} | {{KV TwoObjectPhysics}} | ||
Revision as of 05:16, 17 March 2021
Template:Base point A hinge constraint which restricts rotation of its attached entities to a given axis. The axis is a line between the hinge's origin and the location of its Hammer helper.
 Note:Helper must be used to make hinge work or you will get an error. (ERROR: phys_hinge bad data)
Note:Helper must be used to make hinge work or you will get an error. (ERROR: phys_hinge bad data)The hinge can be given a friction component, which causes it to come to rest more quickly like an old rusty hinge might.
Example map: sourcesdk_content\hl2\mapsrc\sdk_phys_hinge.vmf
Keyvalues
- Friction (hingefriction) <float>
- Resistance/friction in the hinge. Note:This is not a percentage, but rather 1000 HL Units. 100 is a good starting value. Note:This is not a percentage, but rather 1000 HL Units. 100 is a good starting value.
- Hinge Axis (hingeaxis) <vector>
- Define the axis of the hinge by dragging the entity helper in Hammer's 2D views.
- Load Scale (SystemLoadScale) <float>
- Scale of the load connected to this hinge (1=just the objects directly connected. Todo: What does this do? It doesn't seem to increase precision when heavy objects are attached.)
- Minimum Sound Velocity (minSoundThreshold) <float>
- When travelling below this many units/sec, will not play any sound.
- Full Sound Velocity (maxSoundThreshold) <float>
- When travelling at this speed or above, will play sound at full volume.
- Travel sound (forward) (slidesoundfwd) <sound>
- Play this sound when travelling forward on helper axis
- Travel sound (backward) (slidesoundback) <sound>
- Play this sound when travelling backward on helper axis
- Reversal sound threshold (small) (reversalsoundthresholdSmall) <float>
- When accelerating by more than this many units/sec^2 opposite to direction of travel, play the small reversal sound.
- Reversal sound threshold (medium) (reversalsoundthresholdMedium) <float>
- When accelerating by more than this many units/sec^2 opposite to direction of travel, play the medium reversal sound.
- Reversal sound threshold (large) (reversalsoundthresholdLarge) <float>
- When accelerating by more than this many units/sec^2 opposite to direction of travel, play the large reversal sound.
- Reversal sound (small) (reversalsoundSmall) <sound>
- Play this sound when making a hard reverse over the small threshold but less than medium
- Reversal sound (medium) (reversalsoundMedium) <sound>
- Play this sound when making a hard reverse over the medium threshold but less than large
- Reversal sound (large) (reversalsoundLarge) <sound>
- Play this sound when making a hard reverse over the large threshold
TwoObjectPhysics:
- Entity 1 (attach1) <targetname>
- Entity 2 (attach2) <targetname>
- The entities to constrain. Leave one or the other field blank to constrain to the world.  Note:Only one entity will be constrained, even if several share the given targetname. Note:Only one entity will be constrained, even if several share the given targetname.
- Constraint System Manager (constraintsystem) <targetname>
- A phys_constraintsystem that this constraint should be a part of. This avoids the "jiggling" caused by constraints applied to the same set of entities fighting with each other.
- Force Limit to Break (forcelimit) <float>
- Impact force required to break the constraint, in pounds. 0 means infinite. A way of calculating this is to set it to the weight of an object that would break the constraint if it were resting on its objects.
- Torque Limit to Break (torquelimit) <float>
- Torque required to break the constraint, in pounds*inches. 0 means infinite. A way of calculating this is to multiply any reference mass by the resting distance (from the center of mass of the object) needed to break the constraint.
- Play Sound on Break (breaksound) <string>
- A sound played when the constraint is broken.
- Follow teleport distance (teleportfollowdistance) <float>
- If one constrained object teleports more than this many units away, the other will teleport with it.
Flags
- No Collision until break : [1]
- Start inactive : [4]
- Change mass to keep stable attachment to world : [8]
- Do not connect entities until turned on : [16]
Inputs
- SetAngularVelocity <float>
- Set angular velocity around the hinge (motor) in deg/sec
TwoObjectPhysics:
- Break
- Force the constraint to break.
- TurnOn
- Enable the constraint; do this if the constrained objects don't exist when it spawns. Note that broken constraints cannot be turned back on as they have been deleted.
- TurnOff
- Disable the constraint.
Outputs
TwoObjectPhysics:
- OnBreak
- Fired when the constraint breaks.