Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/modules/pickup/items/SpeedPickup.h @ 7456

Last change on this file since 7456 was 7456, checked in by dafrick, 14 years ago

Reviewing documentation fo Questsystem, moving documentation fully into doxygen.
Added some files to modules they belong to.

  • Property svn:eol-style set to native
File size: 3.3 KB
Line 
1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
4 *
5 *
6 *   License notice:
7 *
8 *   This program is free software; you can redistribute it and/or
9 *   modify it under the terms of the GNU General Public License
10 *   as published by the Free Software Foundation; either version 2
11 *   of the License, or (at your option) any later version.
12 *
13 *   This program is distributed in the hope that it will be useful,
14 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
15 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16 *   GNU General Public License for more details.
17 *
18 *   You should have received a copy of the GNU General Public License
19 *   along with this program; if not, write to the Free Software
20 *   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
21 *
22 *   Author:
23 *      Eric Beier
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
30    @file SpeedPickup.h
31    @brief Declaration of the SpeedPickup class.
32    @ingroup PickupItems
33*/
34
35#ifndef _SpeedPickup_H__
36#define _SpeedPickup_H__
37
38#include "pickup/PickupPrereqs.h"
39
40#include <string>
41#include "worldentities/pawns/Pawn.h"
42#include "worldentities/StaticEntity.h"
43
44#include "pickup/Pickup.h"
45
46namespace orxonox {
47
48    /**
49    @brief
50        A Pickup which can manipulate the Speed of a Pawn.
51
52        1) The speed multiplier:
53           The additional (forward) speed:
54        2) The activation type: 'immediate' or 'onUse'. defines if the item is used when it's picked up or only after the player chooses to use it.
55        4) The duration: the activation time of the pickup.
56
57    @author
58        Eric Beier
59    */
60    class _PickupExport SpeedPickup : public Pickup
61    {
62        public:
63
64            SpeedPickup(BaseObject* creator); //!< Constructor.
65            virtual ~SpeedPickup(); //!< Destructor.
66
67            virtual void XMLPort(Element& xmlelement, orxonox::XMLPort::Mode mode); //!< Method for creating a HealthPickup object through XML.
68
69            virtual void changedUsed(void); //!< Is called when the pickup has transited from used to unused or the other way around.
70            virtual void clone(OrxonoxClass*& item); //!< Creates a duplicate of the input OrxonoxClass.
71
72            inline float getDuration(void)
73                { return this->duration_; }
74            inline float getSpeedAdd(void)
75                { return this->speedAdd_; }
76            inline float getSpeedMultiply(void)
77                { return this->speedMultiply_; }
78
79        protected:
80            void initializeIdentifier(void); //!< Initializes the PickupIdentifier of this pickup.
81
82            void pickupTimerCallback(void); //!< Function that gets called when timer ends.
83
84            void setDuration(float duration);
85            void setSpeedAdd(float speedAdd);
86            void setSpeedMultiply(float speedMultiply);
87
88        private:
89            void initialize(void); //!< Initializes the member variables.
90            Engine* carrierToEngineHelper(void); //!< Helper to transform the PickupCarrier to a Pawn, and throw an error message if the conversion fails.
91
92            Timer durationTimer_; //!< Timer.
93
94            float duration_; //!< The health that is transferred to the Pawn.
95            float speedAdd_;
96            float speedMultiply_;
97    };
98}
99
100#endif // _SpeedPickup_H__
Note: See TracBrowser for help on using the repository browser.