genesis-3d_engine/Engine/ExtIncludes/physX3/windows/vehicle/PxVehicleDriveTank.h

230 lines
7.9 KiB
C
Raw Permalink Normal View History

// This code contains NVIDIA Confidential Information and is disclosed to you
// under a form of NVIDIA software license agreement provided separately to you.
//
// Notice
// NVIDIA Corporation and its licensors retain all intellectual property and
// proprietary rights in and to this software and related documentation and
// any modifications thereto. Any use, reproduction, disclosure, or
// distribution of this software and related documentation without an express
// license agreement from NVIDIA Corporation is strictly prohibited.
//
// ALL NVIDIA DESIGN SPECIFICATIONS, CODE ARE PROVIDED "AS IS.". NVIDIA MAKES
// NO WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO
// THE MATERIALS, AND EXPRESSLY DISCLAIMS ALL IMPLIED WARRANTIES OF NONINFRINGEMENT,
// MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE.
//
// Information and code furnished is believed to be accurate and reliable.
// However, NVIDIA Corporation assumes no responsibility for the consequences of use of such
// information or for any infringement of patents or other rights of third parties that may
// result from its use. No license is granted by implication or otherwise under any patent
// or patent rights of NVIDIA Corporation. Details are subject to change without notice.
// This code supersedes and replaces all information previously supplied.
// NVIDIA Corporation products are not authorized for use as critical
// components in life support devices or systems without express written approval of
// NVIDIA Corporation.
//
// Copyright (c) 2008-2013 NVIDIA Corporation. All rights reserved.
// Copyright (c) 2004-2008 AGEIA Technologies, Inc. All rights reserved.
// Copyright (c) 2001-2004 NovodeX AG. All rights reserved.
#ifndef PX_VEHICLE_DRIVE_TANK_H
#define PX_VEHICLE_DRIVE_TANK_H
/** \addtogroup vehicle
@{
*/
#include "vehicle/PxVehicleDrive.h"
#include "vehicle/PxVehicleWheels.h"
#include "vehicle/PxVehicleComponents.h"
#ifndef PX_DOXYGEN
namespace physx
{
#endif
struct PxFilterData;
class PxGeometry;
class PxPhysics;
class PxBatchQuery;
struct PxRaycastQueryResult;
class PxVehicleDrivableSurfaceToTireFrictionPairs;
class PxShape;
class PxMaterial;
class PxRigidDynamic;
/**
\brief Data structure with instanced dynamics data and configuration data of a tank.
*/
class PxVehicleDriveTank : public PxVehicleDrive
{
public:
friend class PxVehicleUpdate;
/**
\brief The ordering of the driven wheels
*/
enum eWheelOrdering
{
eTANK_WHEEL_FRONT_LEFT=0,
eTANK_WHEEL_FRONT_RIGHT,
eTANK_WHEEL_1ST_FROM_FRONT_LEFT,
eTANK_WHEEL_1ST_FROM_FRONT_RIGHT,
eTANK_WHEEL_2ND_FROM_FRONT_LEFT,
eTANK_WHEEL_2ND_FROM_FRONT_RIGHT,
eTANK_WHEEL_3RD_FROM_FRONT_LEFT,
eTANK_WHEEL_3RD_FROM_FRONT_RIGHT,
eTANK_WHEEL_4TH_FROM_FRONT_LEFT,
eTANK_WHEEL_4TH_FROM_FRONT_RIGHT,
eTANK_WHEEL_5TH_FROM_FRONT_LEFT,
eTANK_WHEEL_5TH_FROM_FRONT_RIGHT,
eTANK_WHEEL_6TH_FROM_FRONT_LEFT,
eTANK_WHEEL_6TH_FROM_FRONT_RIGHT,
eTANK_WHEEL_7TH_FROM_FRONT_LEFT,
eTANK_WHEEL_7TH_FROM_FRONT_RIGHT,
eTANK_WHEEL_8TH_FROM_FRONT_LEFT,
eTANK_WHEEL_8TH_FROM_FRONT_RIGHT,
eTANK_WHEEL_9TH_FROM_FRONT_LEFT,
eTANK_WHEEL_9TH_FROM_FRONT_RIGHT
};
/**
@see PxVehicleDrive::setAnalogInput, PxVehicleDrive::getAnalogInput
*/
enum
{
eANALOG_INPUT_ACCEL=PxVehicleDriveDynData::eANALOG_INPUT_ACCEL,
eANALOG_INPUT_BRAKE_LEFT,
eANALOG_INPUT_BRAKE_RIGHT,
eANALOG_INPUT_THRUST_LEFT,
eANALOG_INPUT_THRUST_RIGHT,
eMAX_NUM_DRIVETANK_ANALOG_INPUTS
};
/**
\brief Two driving models supported
@see setDrivingModel
*/
enum eDriveModel
{
eDRIVE_MODEL_STANDARD=0,
eDRIVE_MODEL_SPECIAL
};
/**
\brief Allocate a PxVehicleTankDrive instance for a tank with numWheels
\brief It is assumed that all wheels are driven wheels.
@see free, setup
*/
static PxVehicleDriveTank* allocate(const PxU32 numWheels);
/**
\brief Deallocate a PxVehicleDriveTank instance.
@see allocate
*/
void free();
/**
\brief Set up a tank with
\brief (i) a PxPhysics instance - needed to setup special vehicle constraints maintained by the vehicle.
\brief (ii) a PxRigidDynamic instance - the rigid body representation of the tank in the physx sdk.
\brief (iii)a PxVehicleWheelsSimData instance describing the wheel/suspension/tires - the tank instance takes a copy of this input data.
\brief (iv) a PxVehicleDriveSimData instance describing the drive data - the tank instance takes a copy of this input data.
\brief (v) the number of driven wheels.
\brief (vi) it is assumed that the first numDrivenWheel shapes of vehActor correspond to the wheel shapes of the tank
\brief (vii)it is assumed that the even-numbered wheel shapes are the left-hand wheels ordered in sequence from front to back
\brief (viii)it is assumed that the odd-numbered wheel shapes are the right-hand wheels ordered in sequence from front to back
\brief (ix) it is assumed that the N non-driven wheel shapes are shapes 4 -> 4+N-1 of the actor.
\brief (x) it is assumed that the ordering of the wheel shapes in the actor matches the ordering in PxVehicleWheelsSimData.
\brief (xi) to break assumpgions (vi)-(x) see PxVehicleWheels::setWheelShapeMapping
@see allocate, free, setToRestState, eWheelOrdering
*/
void setup
(PxPhysics* physics, PxRigidDynamic* vehActor,
const PxVehicleWheelsSimData& wheelsData, const PxVehicleDriveSimData& driveData,
const PxU32 numDrivenWheels);
/**
\brief Create a tank with
\brief (i) a PxPhysics instance - needed to setup special vehicle constraints maintained by the vehicle.
\brief (ii) a PxRigidDynamic instance - the rigid body representation of the tank in the physx sdk.
\brief (iii)a PxVehicleWheelsSimData instance describing the wheel/suspension/tires - the tank instance takes a copy of this input data.
\brief (iv) a PxVehicleDriveSimData instance describing the drive data - the tank instance takes a copy of this input data.
\brief (v) the number of driven wheels (the number of tank wheels)
\brief (vi) it is assumed that the first numDrivenWheel shapes of vehActor correspond to the wheel shapes of the tank
\brief (vii)it is assumed that the even-numbered wheel shapes are the left-hand wheels ordered in sequence from front to back
\brief (viii)it is assumed that the odd-numbered wheel shapes are the right-hand wheels ordered in sequence from front to back
\brief (ix) it is assumed that the N non-driven wheel shapes are shapes 4 -> 4+N-1 of the actor.
\brief (x) it is assumed that the ordering of the wheel shapes in the actor matches the ordering in PxVehicleWheelsSimData.
\brief (xi) to break assumptions (vi)-(x) see PxVehicleWheels::setWheelShapeMapping
@see free, setToRestState, setup
*/
static PxVehicleDriveTank* create
(PxPhysics* physics, PxRigidDynamic* vehActor,
const PxVehicleWheelsSimData& wheelsData, const PxVehicleDriveSimData& driveData,
const PxU32 numDrivenWheels);
/**
\brief Set driving model
\brief eDRIVE_MODEL_STANDARD: turning achieved by braking on one side, accelerating on the other side.
\brief eDRIVE_MODEL_SPECIAL: turning achieved by accelerating forwards on one side, accelerating backwards on the other side.
\brief default value is eDRIVE_MODEL_STANDARD
*/
void setDriveModel(const eDriveModel driveModel)
{
mDriveModel=driveModel;
}
/**
\brief Return the driving model
*/
eDriveModel getDriveModel() const {return mDriveModel;}
/**
\brief Set a vehicle to its rest state.
\brief Call after setup
@see setup
*/
void setToRestState();
/**
\brief Simulation data that models vehicle components
@see setup
*/
PxVehicleDriveSimData mDriveSimData;
private:
PxVehicleDriveTank()
: mDriveModel(eDRIVE_MODEL_STANDARD)
{
}
~PxVehicleDriveTank()
{
}
/**
\brief Test if the instanced dynamics and configuration data has legal values.
*/
bool isValid() const;
/**
\brief Drive model
@see setDriveModel, eDriveModel
*/
eDriveModel mDriveModel;
PxU32 mPad[3];
};
PX_COMPILE_TIME_ASSERT(0==(sizeof(PxVehicleDriveTank) & 15));
#ifndef PX_DOXYGEN
} // namespace physx
#endif
/** @} */
#endif //PX_VEHICLE_DRIVE_TANK_H