fix for bug #18898: GE perspective 3D View not working properly (missing LENS)
[blender.git] / source / gameengine / Ketsji / KX_BulletPhysicsController.h
1 #ifndef KX_BULLET2PHYSICS_CONTROLLER
2 #define KX_BULLET2PHYSICS_CONTROLLER
3
4
5 #include "KX_IPhysicsController.h"
6 #include "CcdPhysicsController.h"
7
8 class KX_BulletPhysicsController : public KX_IPhysicsController ,public CcdPhysicsController
9 {
10 private:
11         int m_savedCollisionFlags;
12         int m_savedActivationState;
13         short int m_savedCollisionFilterGroup;
14         short int m_savedCollisionFilterMask;
15         MT_Scalar m_savedMass;
16         bool m_savedDyna;
17         bool m_suspended;
18         btCollisionShape* m_bulletChildShape;
19
20 public:
21
22         KX_BulletPhysicsController (const CcdConstructionInfo& ci, bool dyna, bool sensor, bool compound);
23         virtual ~KX_BulletPhysicsController ();
24
25         ///////////////////////////////////
26         //      KX_IPhysicsController interface
27         ////////////////////////////////////
28
29         virtual void    applyImpulse(const MT_Point3& attach, const MT_Vector3& impulse);
30         virtual void    SetObject (SG_IObject* object);
31         virtual void    setMargin (float collisionMargin);
32         virtual void    RelativeTranslate(const MT_Vector3& dloc,bool local);
33         virtual void    RelativeRotate(const MT_Matrix3x3& drot,bool local);
34         virtual void    ApplyTorque(const MT_Vector3& torque,bool local);
35         virtual void    ApplyForce(const MT_Vector3& force,bool local);
36         virtual MT_Vector3 GetLinearVelocity();
37         virtual MT_Vector3 GetAngularVelocity();
38         virtual MT_Vector3 GetVelocity(const MT_Point3& pos);
39         virtual void    SetAngularVelocity(const MT_Vector3& ang_vel,bool local);
40         virtual void    SetLinearVelocity(const MT_Vector3& lin_vel,bool local);
41         virtual void    getOrientation(MT_Quaternion& orn);
42         virtual void setOrientation(const MT_Matrix3x3& orn);
43         virtual void setPosition(const MT_Point3& pos);
44         virtual void setScaling(const MT_Vector3& scaling);
45         virtual void SetTransform();
46         virtual MT_Scalar       GetMass();
47         virtual void    SetMass(MT_Scalar newmass);
48         virtual MT_Vector3      GetLocalInertia();
49         virtual MT_Vector3      getReactionForce();
50         virtual void    setRigidBody(bool rigid);
51         virtual void    AddCompoundChild(KX_IPhysicsController* child);
52         virtual void    RemoveCompoundChild(KX_IPhysicsController* child);
53
54         virtual void    resolveCombinedVelocities(float linvelX,float linvelY,float linvelZ,float angVelX,float angVelY,float angVelZ);
55
56         virtual void    SuspendDynamics(bool ghost);
57         virtual void    RestoreDynamics();
58
59         virtual SG_Controller*  GetReplica(class SG_Node* destnode);
60
61         virtual MT_Scalar GetRadius();
62         
63         virtual float GetLinVelocityMin();
64         virtual void  SetLinVelocityMin(float val);
65         virtual float GetLinVelocityMax();
66         virtual void  SetLinVelocityMax(float val);
67
68         virtual void    SetSumoTransform(bool nondynaonly);
69         // todo: remove next line !
70         virtual void    SetSimulatedTime(double time);
71         
72         // call from scene graph to update
73         virtual bool Update(double time);
74         void*   GetUserData() { return m_userdata;}
75         
76         void
77         SetOption(
78                 int option,
79                 int value
80         ){
81                 // intentionally empty
82         };
83
84 };
85
86 #endif //KX_BULLET2PHYSICS_CONTROLLER
87