2016-03-01 15:47:10 +00:00
/*
* * p_trace . h
* *
* * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
* * Copyright 1998 - 2006 Randy Heit
* * All rights reserved .
* *
* * Redistribution and use in source and binary forms , with or without
* * modification , are permitted provided that the following conditions
* * are met :
* *
* * 1. Redistributions of source code must retain the above copyright
* * notice , this list of conditions and the following disclaimer .
* * 2. Redistributions in binary form must reproduce the above copyright
* * notice , this list of conditions and the following disclaimer in the
* * documentation and / or other materials provided with the distribution .
* * 3. The name of the author may not be used to endorse or promote products
* * derived from this software without specific prior written permission .
* *
* * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ` ` AS IS ' ' AND ANY EXPRESS OR
* * IMPLIED WARRANTIES , INCLUDING , BUT NOT LIMITED TO , THE IMPLIED WARRANTIES
* * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED .
* * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT , INDIRECT ,
* * INCIDENTAL , SPECIAL , EXEMPLARY , OR CONSEQUENTIAL DAMAGES ( INCLUDING , BUT
* * NOT LIMITED TO , PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES ; LOSS OF USE ,
* * DATA , OR PROFITS ; OR BUSINESS INTERRUPTION ) HOWEVER CAUSED AND ON ANY
* * THEORY OF LIABILITY , WHETHER IN CONTRACT , STRICT LIABILITY , OR TORT
* * ( INCLUDING NEGLIGENCE OR OTHERWISE ) ARISING IN ANY WAY OUT OF THE USE OF
* * THIS SOFTWARE , EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE .
* * - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
* *
*/
# ifndef __P_TRACE_H__
# define __P_TRACE_H__
# include <stddef.h>
# include "actor.h"
2016-03-06 01:07:04 +00:00
# include "cmdlib.h"
2016-03-01 15:47:10 +00:00
# include "textures/textures.h"
struct sector_t ;
struct line_t ;
class AActor ;
struct F3DFloor ;
enum ETraceResult
{
TRACE_HitNone ,
TRACE_HitFloor ,
TRACE_HitCeiling ,
TRACE_HitWall ,
2016-04-09 10:09:06 +00:00
TRACE_HitActor ,
TRACE_CrossingPortal ,
2018-11-02 05:14:02 +00:00
TRACE_HasHitSky ,
2016-03-01 15:47:10 +00:00
} ;
enum
{
TIER_Middle ,
TIER_Upper ,
TIER_Lower ,
TIER_FFloor ,
} ;
struct FTraceResults
{
sector_t * Sector ;
FTextureID HitTexture ;
2016-03-23 17:07:04 +00:00
DVector3 HitPos ;
DVector3 HitVector ;
DVector3 SrcFromTarget ;
DAngle SrcAngleFromTarget ;
2016-03-04 00:12:38 +00:00
2016-03-23 17:07:04 +00:00
double Distance ;
double Fraction ;
2016-03-06 01:07:04 +00:00
2016-03-01 15:47:10 +00:00
AActor * Actor ; // valid if hit an actor
line_t * Line ; // valid if hit a line
2017-03-08 14:20:00 +00:00
uint8_t Side ;
uint8_t Tier ;
2016-03-06 00:04:19 +00:00
bool unlinked ; // passed through a portal without static offset.
2016-03-01 15:47:10 +00:00
ETraceResult HitType ;
2016-03-06 01:07:04 +00:00
F3DFloor * ffloor ;
2016-03-01 15:47:10 +00:00
sector_t * CrossedWater ; // For Boom-style, Transfer_Heights-based deep water
2016-03-23 17:07:04 +00:00
DVector3 CrossedWaterPos ; // remember the position so that we can use it for spawning the splash
2016-03-01 15:47:10 +00:00
F3DFloor * Crossed3DWater ; // For 3D floor-based deep water
2016-03-23 17:07:04 +00:00
DVector3 Crossed3DWaterPos ;
2016-03-01 15:47:10 +00:00
} ;
2016-03-06 01:07:04 +00:00
2016-03-01 15:47:10 +00:00
enum
{
2018-04-25 16:24:37 +00:00
TRACE_NoSky = 0x0001 , // Hitting the sky returns TRACE_HitNone
TRACE_PCross = 0x0002 , // Trigger SPAC_PCROSS lines
TRACE_Impact = 0x0004 , // Trigger SPAC_IMPACT lines
TRACE_PortalRestrict = 0x0008 , // Cannot go through portals without a static link offset.
TRACE_ReportPortals = 0x0010 , // Report any portal crossing to the TraceCallback
TRACE_3DCallback = 0x0020 , // [ZZ] use TraceCallback to determine whether we need to go through a line to do 3D floor check, or not. without this, only line flag mask is used
2018-11-02 05:14:02 +00:00
TRACE_HitSky = 0x0040 , // Hitting the sky returns TRACE_HasHitSky
2016-03-01 15:47:10 +00:00
} ;
// return values from callback
enum ETraceStatus
{
TRACE_Stop , // stop the trace, returning this hit
TRACE_Continue , // continue the trace, returning this hit if there are none further along
TRACE_Skip , // continue the trace; do not return this hit
TRACE_Abort , // stop the trace, returning no hits
} ;
2016-03-30 14:30:22 +00:00
bool Trace ( const DVector3 & start , sector_t * sector , const DVector3 & direction , double maxDist ,
2017-03-08 14:20:00 +00:00
ActorFlags ActorMask , uint32_t WallMask , AActor * ignore , FTraceResults & res , uint32_t traceFlags = 0 ,
2016-03-30 14:30:22 +00:00
ETraceStatus ( * callback ) ( FTraceResults & res , void * ) = NULL , void * callbackdata = NULL ) ;
2016-03-24 00:46:11 +00:00
2018-01-20 13:37:03 +00:00
// [ZZ] this is the object that's used for ZScript
2018-01-27 08:32:26 +00:00
class DLineTracer : public DObject
2018-01-20 13:37:03 +00:00
{
2018-01-27 08:32:26 +00:00
DECLARE_CLASS ( DLineTracer , DObject )
2018-01-20 13:37:03 +00:00
public :
FTraceResults Results ;
static ETraceStatus TraceCallback ( FTraceResults & res , void * pthis ) ;
ETraceStatus CallZScriptCallback ( ) ;
} ;
2016-03-01 15:47:10 +00:00
# endif //__P_TRACE_H__