Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/branches/2d-recalc/src/world_entities/weapons/projectile.h @ 5901

Last change on this file since 5901 was 5039, checked in by bensch, 19 years ago

orxonox/trunk: useless stuff :)

File size: 2.2 KB
Line 
1/*!
2 * @file projectile.h
3  *  a projectile, that is been shooted by a weapon
4
5    You can use this class to make some shoots, but this isn't the real idea. If you want to just test, if the
6    shooting funcions work, use the Projectile class. But if you want to implement your own shoots its
7    different:<br>
8    Make a new class and derive it from Projectile. To have a weapon work well, reimplement the functions
9    - void tick()
10    - void draw()
11    - void hit() (only if you have working collision detection)
12    When you have implemented these functions you have just to add the projectiles to your weapon. You ll want
13    to make this by looking into the function
14    - Weapon::fire()
15    there you just change the line:
16    Projectile* pj = new Projectile();    TO     Projectile* pj = new MyOwnProjectileClass();
17    and schwups it works... :)
18*/
19
20#ifndef _PROJECTILE_H
21#define _PROJECTILE_H
22
23#include "world_entity.h"
24#include "vector.h"
25
26class Projectile : public WorldEntity
27{
28  public:
29    Projectile ();
30    virtual ~Projectile ();
31
32    void setFlightDirection(const Quaternion& flightDirection);
33    void setVelocity(const Vector &velocity);
34    void setLifeSpan(float lifeSpan);
35
36
37    void setEnergies(float energyMin, float energyMax);
38    /** @returns the minimal charched energy */
39    inline float getEnergyMin() { return this->energyMin; };
40    /** @returns the maximal charched energy */
41    inline float getEnergyMax() { return this->energyMax; };
42    /** @returns if the Projectile can be charged */
43    inline bool isChageable() { return this->bChargeable; };
44
45
46
47    virtual void destroy ();
48
49    virtual void tick (float time);
50    virtual void draw ();
51
52  protected:
53    // energy
54    float                 energyMin;
55    float                 energyMax;
56    bool                  bChargeable;               //!< if the Projectile is Charegeable
57
58    float                 lifeCycle;                 //!< The percentage of the Lifetime done [0-1]
59    float                 lifeSpan;                  //!< The entire lifespan of the Shoot. in seconds
60
61    Vector                flightDirection;           //!< DOF direction in which the shoot flighs
62
63    Vector                velocity;                  //!< velocity of the projectile.
64};
65
66#endif /* _PROJECTILE_H */
Note: See TracBrowser for help on using the repository browser.