2022-03-17 23:20:34 +01:00
|
|
|
#ifndef BT_VEHICLE_RAYCASTER_H
|
|
|
|
#define BT_VEHICLE_RAYCASTER_H
|
2022-03-15 13:29:32 +01:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2005 Erwin Coumans http://bulletphysics.org
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, distribute and sell this software
|
|
|
|
* and its documentation for any purpose is hereby granted without fee,
|
|
|
|
* provided that the above copyright notice appear in all copies.
|
|
|
|
* Erwin Coumans makes no representations about the suitability
|
|
|
|
* of this software for any purpose.
|
|
|
|
* It is provided "as is" without express or implied warranty.
|
|
|
|
*/
|
2022-03-17 23:20:34 +01:00
|
|
|
|
|
|
|
|
2022-03-15 13:29:32 +01:00
|
|
|
|
|
|
|
#include "LinearMath/btVector3.h"
|
|
|
|
|
|
|
|
/// btVehicleRaycaster is provides interface for between vehicle simulation and raycasting
|
|
|
|
struct btVehicleRaycaster
|
|
|
|
{
|
|
|
|
virtual ~btVehicleRaycaster()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
struct btVehicleRaycasterResult
|
|
|
|
{
|
|
|
|
btVehicleRaycasterResult() : m_distFraction(btScalar(-1.)){};
|
|
|
|
btVector3 m_hitPointInWorld;
|
|
|
|
btVector3 m_hitNormalInWorld;
|
|
|
|
btScalar m_distFraction;
|
|
|
|
};
|
|
|
|
|
|
|
|
virtual void* castRay(const btVector3& from, const btVector3& to, btVehicleRaycasterResult& result) = 0;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif //BT_VEHICLE_RAYCASTER_H
|