Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/tutorial6/src/modules/pickup/items/ShieldPickup.cc @ 12411

Last change on this file since 12411 was 11071, checked in by landauf, 9 years ago

merged branch cpp11_v3 back to trunk

  • Property svn:eol-style set to native
File size: 6.5 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 ShieldPickup.cc
31    @brief Implementation of the ShieldPickup class.
32*/
33
34#include "ShieldPickup.h"
35
36#include <sstream>
37#include "core/CoreIncludes.h"
38#include "core/XMLPort.h"
39
40#include "worldentities/pawns/Pawn.h"
41
42namespace orxonox
43{
44    RegisterClass(ShieldPickup);
45
46    /**
47    @brief
48        Constructor. Registers the object and initializes the member variables.
49    */
50    ShieldPickup::ShieldPickup(Context* context) : Pickup(context)
51    {
52        RegisterObject(ShieldPickup);
53
54        this->initialize();
55    }
56
57    /**
58    @brief
59        Destructor.
60    */
61    ShieldPickup::~ShieldPickup()
62    {
63
64    }
65
66    /**
67    @brief
68        Initializes the member variables.
69    */
70    void ShieldPickup::initialize(void)
71    {
72        this->duration_ = 0.0f;
73        this->shieldAbsorption_ = 0.0f;
74        this->shieldHealth_ = 0.0f;
75
76        this->addTarget(ClassIdentifier<Pawn>::getIdentifier());
77    }
78
79    /**
80    @brief
81        Method for creating a ShieldPickup object through XML.
82    */
83    void ShieldPickup::XMLPort(Element& xmlelement, orxonox::XMLPort::Mode mode)
84    {
85        SUPER(ShieldPickup, XMLPort, xmlelement, mode);
86
87        XMLPortParam(ShieldPickup, "shieldhealth", setShieldHealth, getShieldHealth, xmlelement, mode);
88        XMLPortParam(ShieldPickup, "shieldabsorption", setShieldAbsorption, getShieldAbsorption, xmlelement, mode);
89        XMLPortParam(ShieldPickup, "duration", setDuration, getDuration, xmlelement, mode);
90    }
91
92    /**
93    @brief
94        Is called when the pickup has transited from used to unused or the other way around.
95    */
96    void ShieldPickup::changedUsed(void)
97    {
98        SUPER(ShieldPickup, changedUsed);
99
100        Pawn* pawn = this->carrierToPawnHelper();
101        if(pawn == nullptr)
102            this->Pickupable::destroy();
103
104        // If the pickup has transited to used.
105        if(this->isUsed())
106        {
107            // If its durationType is continuous, we set a Timer to be reminded, when the time has run out.
108            if(this->isContinuous())
109            {
110                if(!this->durationTimer_.isActive() && this->durationTimer_.getRemainingTime() > 0.0f)
111                {
112                    this->durationTimer_.unpauseTimer();
113                }
114                else
115                {
116                    this->durationTimer_.setTimer(this->getDuration(), false, createExecutor(createFunctor(&ShieldPickup::pickupTimerCallback, this)));
117                }
118            }
119            pawn->setShieldAbsorption(this->getShieldAbsorption());
120            pawn->setShieldHealth(this->getShieldHealth());
121        }
122        else
123        {
124            pawn->setShieldAbsorption(0.0f);
125            this->setShieldHealth(pawn->getShieldHealth());
126            pawn->setShieldHealth(0.0f);
127
128            // We destroy the pickup if either, the pickup has activationType immediate and durationType once or it has durationType continuous and the duration was exceeded.
129            if((!this->isContinuous() && this->isImmediate()) || (this->isContinuous() && !this->durationTimer_.isActive() && this->durationTimer_.getRemainingTime() == this->getDuration()))
130            {
131                this->Pickupable::destroy();
132            }
133            // We pause the Timer if the pickup is continuous and the duration is not yet exceeded,
134            else if(this->isContinuous() && this->durationTimer_.isActive())
135            {
136                this->durationTimer_.pauseTimer();
137            }
138        }
139    }
140
141    /**
142    @brief
143    Helper to transform the PickupCarrier to a Pawn, and throw an error message if the conversion fails.
144    @return
145    A pointer to the Pawn, or nullptr if the conversion failed.
146    */
147    Pawn* ShieldPickup::carrierToPawnHelper(void)
148    {
149        PickupCarrier* carrier = this->getCarrier();
150        Pawn* pawn = orxonox_cast<Pawn*>(carrier);
151
152        if(pawn == nullptr)
153        {
154            orxout(internal_error, context::pickups) << "Invalid PickupCarrier in ShieldPickup." << endl;
155        }
156        return pawn;
157    }
158
159    /**
160    @brief
161        Sets the duration.
162    @param duration
163        The duration in seconds.
164    */
165    void ShieldPickup::setDuration(float duration)
166    {
167        if(duration >= 0.0f)
168        {
169            this->duration_ = duration;
170        }
171        else
172        {
173            orxout(internal_error, context::pickups) << "Invalid duration in ShieldPickup." << endl;
174            this->duration_ = 0.0f;
175        }
176    }
177
178    /**
179    @brief
180        Sets the health of the shield.
181    @param shieldHealth
182        The shieldHealth.
183    */
184    void ShieldPickup::setShieldHealth(float shieldHealth)
185    {
186        if (shieldHealth>=0)
187        {
188            this->shieldHealth_=shieldHealth;
189        }
190        else
191        {
192            orxout(internal_error, context::pickups) << "Invalid Shieldhealth in ShieldPickup." << endl;
193            this->shieldHealth_=0;
194        }
195    }
196
197    /**
198    @brief
199        Sets the percentage the shield absorbs of the dealt damage.
200    @param shieldAbsorption
201        The shieldAbsorption. Has to be between 0 and 1.
202    */
203    void ShieldPickup::setShieldAbsorption(float shieldAbsorption)
204    {
205        if (shieldAbsorption>=0 && shieldAbsorption<=1)
206        {
207            this->shieldAbsorption_=shieldAbsorption;
208        }
209        else
210        {
211            orxout(internal_error, context::pickups) << "Invalid Absorption in ShieldPickup." << endl;
212            this->shieldAbsorption_=0;
213        }
214    }
215
216    /**
217    @brief
218        Helper method. Is called by the Timer as soon as it expires.
219    */
220    void ShieldPickup::pickupTimerCallback(void)
221    {
222        this->setUsed(false);
223    }
224}
Note: See TracBrowser for help on using the repository browser.