Difference between revisions of "Tracing"
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| Outerbeast (talk | contribs) m (→TraceResult) | Outerbeast (talk | contribs)  m (→Trace methods) | ||
| (5 intermediate revisions by the same user not shown) | |||
| Line 42: | Line 42: | ||
| == Trace methods == | == Trace methods == | ||
| Supported trace operations are listed below and are accessible via the [[CUtility#Tracing_methods|CUtility]] class. | Supported trace operations are listed below and are accessible via the [[CUtility#Tracing_methods|CUtility]] class. | ||
| − | |||
| A global instance exists: | A global instance exists: | ||
| <code>CUtility g_Utility;</code> | <code>CUtility g_Utility;</code> | ||
| + | |||
| + | Note: The method <code>TankTrace</code> belongs to the CBaseTank class. | ||
| There are a number of traces that can be performed: | There are a number of traces that can be performed: | ||
| Line 55: | Line 56: | ||
| |- | |- | ||
| | <code>void TraceLine(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, edict_t@ pEntIgnore, TraceResult& out ptr)</code> | | <code>void TraceLine(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, edict_t@ pEntIgnore, TraceResult& out ptr)</code> | ||
| − | | Calculates a trace along the given line, storing the results in ptr. If igmon is ignore_monsters, entities with a solid setting other than SOLID_BSP and a movetype other than MOVETYPE_PUSHSTEP (pushables) are ignored. If pEntIgnore is set, the entity will not be considered in traceline calculations. | + | | Calculates a trace along the given line, storing the results in ptr. If <code>igmon</code> is ignore_monsters, entities with a solid setting other than SOLID_BSP and a movetype other than MOVETYPE_PUSHSTEP (pushables) are ignored. If <code>pEntIgnore</code> is set, the entity will not be considered in traceline calculations. | 
| | Uses point based bounds (zeroed out mins and maxs) | | Uses point based bounds (zeroed out mins and maxs) | ||
| |- | |- | ||
| | <code>void TraceLine(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, IGNORE_GLASS ignoreGlass, edict_t@ pEntIgnore, TraceResult& out ptr)</code> | | <code>void TraceLine(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, IGNORE_GLASS ignoreGlass, edict_t@ pEntIgnore, TraceResult& out ptr)</code> | ||
| − | | Same as the above function, but also allows you to specify whether or not to ignore glass. If ignore_glass is specified, brush entities with a render mode other than normal and that don't have the FL_WORLDBRUSH flag set are ignored. | + | | Same as the above function, but also allows you to specify whether or not to ignore glass. If ignore_glass is specified, brush entities with a render mode other than normal and that don't have the <code>FL_WORLDBRUSH</code> flag set are ignored. | 
| | Uses point based bounds (zeroed out mins and maxs) | | Uses point based bounds (zeroed out mins and maxs) | ||
| |- | |- | ||
| Line 85: | Line 86: | ||
| | style="vertical-align:middle;" | Finds the hull intersection from a traceline in a given set of bounds.<br />The given entity is the entity performing the traceline. | | style="vertical-align:middle;" | Finds the hull intersection from a traceline in a given set of bounds.<br />The given entity is the entity performing the traceline. | ||
| | The bounds are relative to the input traceline's endpoint. | | The bounds are relative to the input traceline's endpoint. | ||
| + | |- | ||
| + | | <code>void TankTrace(const Vector& in vecStart, const Vector& in vecForward, const Vector& in vecSpread, TraceResult& out tr)</code> | ||
| + | | style="vertical-align:middle;" | Performs a traceline using a random spread based on the given spread amount.<br>This is a CBaseTank method. | ||
| + | | Uses point based bounds (zeroed out mins and maxs) | ||
| |- | |- | ||
| |} | |} | ||
| Line 93: | Line 98: | ||
| |- style="font-weight:bold; text-align:center;" | |- style="font-weight:bold; text-align:center;" | ||
| ! Constant | ! Constant | ||
| − | !  | + | ! Purpose | 
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| |- | |- | ||
| − | |  | + | | dont_ignore_monsters | 
| − | |  | + | | Don't ignore monsters. | 
| − | |||
| − | |||
| − | |||
| |- | |- | ||
| − | |  | + | | ignore_monsters | 
| − | |  | + | | Ignore monsters. | 
| − | |||
| − | |||
| − | |||
| |- | |- | ||
| − | |  | + | | missile | 
| − | + | | The trace bounds are set to mins -15, -15, -15 and maxs 15, 15, 15. Otherwise, the bounds are specified by the traceline operation. | |
| − | | - | ||
| − | |||
| − | |||
| |} | |} | ||
Latest revision as of 14:45, 11 June 2025
Traces are used to perform hit detection, which is handled by the engine. It is one of the primary means of handling navigation and hit detection in the game.
1 TraceResult
The TraceResult class stores trace results that are performed by trace methods. Passing in a TraceResult object into a given trace method will modify the object, and so the results from the trace method can be accessed. Not all trace operations require the use of a TraceResult object.
| Variable | Description | 
|---|---|
| int fAllSolid
 | Flag telling whether the trace started and ended in a solid area. If true, the plane is not valid. | 
| int fStartSolid
 | Flag telling whether the trace started in a solid area. | 
| int fInOpen
 | Flag telling whether the trace ended in empty space. | 
| int fInWater
 | Flag telling whether the trace ended in water. | 
| float flFraction
 | How much of the trace's total distance was covered. 1.0 means it didn't hit anything. | 
| Vector vecEndPos
 | End position. If flFraction is 1.0, this is invalid. | 
| float flPlaneDist
 | Brush plane distance. This appears to be the dot product between the first plane point and the normal. Its purpose is unknown, and there are no known uses. If flFraction is 1.0, this is invalid. If the hit object is not a brush, this is invalid. | 
| Vector vecPlaneNormal
 | Brush plane normal. If flFraction is 1.0, this is invalid. If the hit object is not a brush, this is invalid. | 
| edict_t@ pHit
 | Hit entity. If flFraction is 1.0, this is null. | 
| int iHitgroup
 | Studio model hit group. if flFraction is 1.0, this is invalid. If the hit object is not a studio model, this is invalid. | 
2 Trace methods
Supported trace operations are listed below and are accessible via the CUtility class.
A global instance exists:
CUtility g_Utility;
Note: The method TankTrace belongs to the CBaseTank class.
There are a number of traces that can be performed:
| Method | Description | Bounds | 
|---|---|---|
| void TraceLine(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, edict_t@ pEntIgnore, TraceResult& out ptr) | Calculates a trace along the given line, storing the results in ptr. If igmonis ignore_monsters, entities with a solid setting other than SOLID_BSP and a movetype other than MOVETYPE_PUSHSTEP (pushables) are ignored. IfpEntIgnoreis set, the entity will not be considered in traceline calculations. | Uses point based bounds (zeroed out mins and maxs) | 
| void TraceLine(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, IGNORE_GLASS ignoreGlass, edict_t@ pEntIgnore, TraceResult& out ptr) | Same as the above function, but also allows you to specify whether or not to ignore glass. If ignore_glass is specified, brush entities with a render mode other than normal and that don't have the FL_WORLDBRUSHflag set are ignored. | Uses point based bounds (zeroed out mins and maxs) | 
| void TraceHull(const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, HULL_NUMBER hullNumber, edict_t@ pEntIgnore, TraceResult& out ptr) | Similar to TraceLine, but will use the specified hull's bounds instead of point based bounds. | Uses the specified hull's bounds. Maps can specify these bounds in newer compilers, so avoid assuming a particular value is in use. | 
| void TraceToss(edict_t@ pEntity, edict_t@ pEntityToIgnore, TraceResult& out traceResult) | Traces a toss. This simulates tossing the entity using its current origin, velocity, angular velocity, angles and gravity. Note that this does not use the same code as MOVETYPE_TOSS, and may return different results. | Uses the given entity's bounds. | 
| bool TraceMonsterHull(edict_t@ pEntity, const Vector& in vecStart, const Vector& in vecEnd, IGNORE_MONSTERS igmon, edict_t@ pEntityToIgnore, TraceResult& out ptr) | Performs a trace using the given entity's mins and maxs. This can be any entity, not just monsters. Returns true if the trace was entirely in a solid object, or if it hit something. | Uses the given entity's bounds. | 
| void TraceModel(const Vector& in vecStart, const Vector& in vecEnd, int iHullNumber, edict_t@ pEntityToIgnore, TraceResult& out ptr) | Similar to TraceHull, but will instead perform a trace in the given world hull using the given entity's model's hulls. For studio models this will use the model's hitboxes. | If the given entity's model is a studio model, uses its hitboxes. If it's a brush model, the brush model's hull for the given hull number is used (this may differ if custom brush hull sizes are in use). Otherwise, the entity bounds are converted into a hull. | 
| string TraceTexture(edict_t@ pEntity, const Vector& in vecStart, const Vector& in vecEnd) | Used to get the name of a texture. The given entity must have a brush model set. If the traceline intersects the model, the name of the texture of the surface it intersected is returned. Otherwise, returns an empty string. | Uses point based bounds (zeroed out mins and maxs). CUtility::GetGlobalTrace() can be used to obtain this trace. | 
| void FindHullIntersection(const Vector& in vecSrc, TraceResult& in inTr, TraceResult& out outTr, const Vector& in vecMins, const Vector& in vecMaxs, edict_t@ pEntity, float flDistance = 1e6f) | Finds the hull intersection from a traceline in a given set of bounds. The given entity is the entity performing the traceline. | The bounds are relative to the input traceline's endpoint. | 
| void TankTrace(const Vector& in vecStart, const Vector& in vecForward, const Vector& in vecSpread, TraceResult& out tr) | Performs a traceline using a random spread based on the given spread amount. This is a CBaseTank method. | Uses point based bounds (zeroed out mins and maxs) | 
3 Enums
3.1 IGNORE_MONSTERS
| Constant | Purpose | 
|---|---|
| dont_ignore_monsters | Don't ignore monsters. | 
| ignore_monsters | Ignore monsters. | 
| missile | The trace bounds are set to mins -15, -15, -15 and maxs 15, 15, 15. Otherwise, the bounds are specified by the traceline operation. | 
3.2 IGNORE_GLASS
| Constant | Purpose | 
|---|---|
| dont_ignore_glass | Don't ignore glass. | 
| ignore_glass | Ignore glass. | 
3.3 HULL_NUMBER
| Constant | Hull # | Default Mins | Default Maxs | Default Size | 
|---|---|---|---|---|
| point_hull | 0 | 0, 0, 0 | 0, 0, 0 | 0x0x0 | 
| human_hull | 1 | -16, -16, -36 | 16, 16, 36 | 32x32x72 | 
| large_hull | 2 | -32, -32, -32 | 32, 32, 32 | 64x64x64 | 
| head_hull | 3 | -16, -16, -18 | 16, 16, 18 | 32x32x36 |