func_pushable (Half-Life) Last edited 6 years ago2018-09-05 03:20:13 UTC

You are viewing an older revision of this wiki page. The current revision may be more detailed and up-to-date. Click here to see the current revision of this page.

This article was converted from a previous version of TWHL and may need to be reviewed

  1. The formatting may be incorrect due to differences in the WikiCode processing engine, it needs to be revised and reformatted
  2. Some information may be out of date
  3. After the article is re-formatted and updated, remove this notice and the Review Required category.
  4. Some older articles are no longer useful, or they duplicate information from other pages. In this case, delete the page after merging any relevant information into other pages. Contact an admin to delete a page.
Brush Entity

Func_pushable entities can be pushed and pulled around by the player. Func_pushables can also optionally be breakable.

Attributes

Name (targetname) - Property used to identify entities.
Material Type (material) - The type of material that a func_breakable or func_pushable should act as. Options are: Spawn on Break (spawnobject) - Used by func_breakable and func_pushable. Determines what item is spawned when the entity is broken. Options are: Render FX (renderfx) - Gives objects special render effects. Think of it as modifying whatever the Render Mode puts out. The options are as follows: Render Mode (rendermode) - Controls the type of rendering that is used for an object. Options are: Global Entity Name (globalname)
Target on break (target) - If breakable, this event will be activated when broken.
Strength (health) - If breakable, this is the amount of damage to be taken before breaking.
Gibs Direction (explosion) - Direction the gibs will go when the brush is broken. Values: 0 = Random, 1 = Relative to attack.
Delay before fire (delay) - Delay before Target on Break is triggered after being broken.
Gib Model (gibmodel) - Specify a gib model to use. This overrides the default specified by Material Type.
Explode Magnitude (explodemagnitude) - A non-zero value here creates an explosion when the object breaks.
FX Amount (renderamt)
FX Color (rendercolor)
ZHLT Lightflags (zhlt_lightflags)
Light Origin Target (light_origin)
Hull size (size) - Values: 0 = point sized, 1 = player sized, 2 = big size, 3 = player duck.
Friction (friction) - This determines the amount of resistance the brush will give when the player pushes it. Range is 0 to 400, where 400 is the most resistance.
Bouyancy (bouyancy) - Determines how well the brush floats on water.
Minimum Light level (_minlight)

Flags

Notes

5 Comments

Commented 14 years ago2010-02-28 12:16:47 UTC Comment #101135
Well, what's the point of Hull Size? I find it doesn't affect the bounding box of the object.
Commented 10 years ago2014-11-23 14:54:48 UTC Comment #101136
@^: The Hull Size setting determines the pev->size value, which I'm not sure what it's used for.
Commented 9 months ago2024-03-12 10:22:08 UTC Comment #106062
Just to answer that age-old question that has been left unanswered for so long here:

The Hull Size (size) determines which of the three cliphulls to test its own collisions against.
This is why a big pushable using HULL1 or HULL3 might be clipping into world geometry when pushed around.
("Am I colliding with the world?" from the pushable's perspective).

This isn't the same sort of collisions as when a player is touching/climbing the pushable, in which case it's the player testing collisions against the pushable's own cliphulls, which are similar to its shape regardless of size.
("Am I colliding with the pushable?" from the player's perspective).
Commented 6 days ago2025-01-04 02:16:09 UTC Comment #106597
Based on testing, pushable collision with the world seems to be fixed to 32x32 OR 64x64 regardless of hull choices.
If the entity is smaller than 32x32 it will act like it's 32x32.
If the entity is larger than 32x32 it will act like it's 64x64.
In both cases the effective size is aligned to the bottom left corner of the entity.

Yes, it's all counter to what we read in code. I have no explanation why.
Commented 4 days ago2025-01-06 10:33:37 UTC Comment #106603
@kimilil I had created a thread exactly about this some months ago, maybe you'll find it useful:

https://twhl.info/thread/view/20806

Could never get the engine to use the pointhull for entity-world collisions. Will try to implement it myself someday when I get some free time.

You must log in to post a comment. You can login or register a new account.

Shoutbox

Log in to add shouts of your own