Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/trunk/src/modules/pickup/items/InvisiblePickup.cc @ 7942

Last change on this file since 7942 was 7548, checked in by dafrick, 15 years ago

Resolving some TODO's.

  • Property svn:eol-style set to native
File size: 6.7 KB
RevLine 
[6641]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 *      Benedict Simlinger
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
30    @file InvisiblePickup.cc
31    @brief Implementation of the InvisiblePickup class.
32*/
33
34#include "InvisiblePickup.h"
35
[7163]36#include <sstream>
[7547]37//#include <OgreEntity.h>
38//#include <OgreAnimationState.h>
[6641]39#include "core/CoreIncludes.h"
40#include "core/XMLPort.h"
41
[7547]42#include "pickup/PickupIdentifier.h"
[6641]43#include "worldentities/pawns/Pawn.h"
44
45namespace orxonox
46{
[6684]47
[6641]48    CreateFactory(InvisiblePickup);
[7163]49
[6641]50    /**
51    @brief
52        Constructor. Registers the object and initializes the member variables.
53    */
54    InvisiblePickup::InvisiblePickup(BaseObject* creator) : Pickup(creator)
55    {
56        RegisterObject(InvisiblePickup);
[7163]57        this->initialize();
[6641]58    }
[7163]59
[6641]60    /**
61    @brief
62        Destructor.
63    */
64    InvisiblePickup::~InvisiblePickup()
[7163]65    {
[6641]66    }
[7163]67
[6641]68    /**
69    @brief
70    Initializes the member variables.
71    */
72    void InvisiblePickup::initialize(void)
73    {
[6708]74        this->duration_ = 0.0f;
[7541]75        // Defines who is allowed to pick up the pickup.
[6708]76        this->addTarget(ClassIdentifier<Pawn>::getIdentifier());
[6641]77    }
78
79    /**
80    @brief
[7547]81        Initializes the PickupIdentifier of this pickup.
82    */
83    void InvisiblePickup::initializeIdentifier(void)
84    {
85        std::stringstream stream;
86        stream << this->getDuration();
87        std::string type1 = "duration";
88        std::string val1 = stream.str();
89        this->pickupIdentifier_->addParameter(type1, val1);
90    }
91
92    /**
93    @brief
[6641]94        Method for creating a HealthPickup object through XML.
95    */
96    void InvisiblePickup::XMLPort(Element& xmlelement, orxonox::XMLPort::Mode mode)
97    {
[7163]98        SUPER(InvisiblePickup, XMLPort, xmlelement, mode);
[6708]99        XMLPortParam(InvisiblePickup, "duration", setDuration, getDuration, xmlelement, mode);
[7163]100
[6708]101        this->initializeIdentifier();
[6641]102    }
[7163]103
[6641]104    /**
105    @brief
106        Is called when the pickup has transited from used to unused or the other way around.
107    */
108    void InvisiblePickup::changedUsed(void)
109    {
110        SUPER(InvisiblePickup, changedUsed);
[7163]111
[7547]112        // If the pickup has transited to used.
[6708]113        if (this->isUsed())
114        {
[7547]115            // If its durationType is continuous, we set a Timer to be reminded, when the time has run out.
[7544]116            if(this->isContinuous())
[6755]117            {
[7541]118                if(!this->durationTimer_.isActive() && this->durationTimer_.getRemainingTime() > 0.0f)
119                {
120                    this->durationTimer_.unpauseTimer();
121                }
122                else
123                {
124                    this->durationTimer_.setTimer(this->getDuration(), false, createExecutor(createFunctor(&InvisiblePickup::pickupTimerCallback, this)));
125                }
[6755]126            }
[7163]127
[6708]128            this->setInvisible(true);
[7163]129
[6708]130        }
131        else
132        {
133            this->setInvisible(false);
[7163]134
[7547]135            // We destroy the pickup if either, the pickup has activationType immediate and durationType once or it has durationType continuous and the duration was exceeded.
[7546]136            if((!this->isContinuous() && this->isImmediate()) || (this->isContinuous() && !this->durationTimer_.isActive() && this->durationTimer_.getRemainingTime() == this->getDuration()))
[6755]137            {
[7163]138                this->Pickupable::destroy();
[6755]139            }
[7547]140            // We pause the Timer if the pickup is continuous and the duration is not yet exceeded,
[7546]141            else if(this->isContinuous() && this->durationTimer_.isActive())
[6755]142            {
[7208]143                this->durationTimer_.pauseTimer();
[6755]144            }
[6708]145        }
[6641]146    }
[7163]147
[6641]148    /**
149    @brief
150        Creates a duplicate of the input OrxonoxClass.
151    @param item
152        A pointer to the Orxonox class.
153    */
154    void InvisiblePickup::clone(OrxonoxClass*& item)
155    {
156        if(item == NULL)
157            item = new InvisiblePickup(this);
[7163]158
[6641]159        SUPER(InvisiblePickup, clone, item);
[7163]160
[6708]161        InvisiblePickup* pickup = dynamic_cast<InvisiblePickup*>(item);
162        pickup->setDuration(this->getDuration());
163        pickup->initializeIdentifier();
[6641]164    }
[7163]165
[6641]166    /**
167    @brief
168        Sets the invisibility.
[6708]169    @param invisibility
[6641]170        The invisibility.
171    */
172    bool InvisiblePickup::setInvisible(bool invisibility)
173    {
[6708]174        Pawn* pawn = this->carrierToPawnHelper();
175        if(pawn == NULL)
176            return false;
[7163]177
[6708]178        pawn->setVisible(!invisibility);
[7163]179        pawn->setRadarVisibility(!invisibility);
180
181// Test to change Material at runtime!
182
183//      Ogre::MaterialPtr mat = this->mesh_.getEntity()->getSubEntity(0)->getMaterial();
184//      mat->setDiffuse(0.4, 0.3, 0.1, 0.1);
185//      mat->setAmbient(0.3, 0.7, 0.8);
186//      mat->setSpecular(0.5, 0.5, 0.5, 0.1);
187//      Ogre::SceneBlendType sbt = Ogre::SBT_ADD;
188//
189//      mat->setSceneBlending(sbt);
190
[6708]191        return true;
[6641]192    }
[7163]193
[6641]194    /**
195    @brief
[7547]196        Helper to transform the PickupCarrier to a Pawn, and throw an error message if the conversion fails.
197    @return
198        A pointer to the Pawn, or NULL if the conversion failed.
199    */
200    Pawn* InvisiblePickup::carrierToPawnHelper(void)
201    {
202        PickupCarrier* carrier = this->getCarrier();
203        Pawn* pawn = dynamic_cast<Pawn*>(carrier);
204
205        if(pawn == NULL)
206        {
207            COUT(1) << "Invalid PickupCarrier in InvisiblePickup." << std::endl;
208        }
209        return pawn;
210    }
211
212    /**
213    @brief
[7544]214        Sets the time the InvisibilityPickup will last.
[6641]215    @param duration
[7544]216        The duration in seconds.
[6641]217    */
218    void InvisiblePickup::setDuration(float duration)
219    {
[6708]220        if(duration >= 0.0f)
221        {
222            this->duration_ = duration;
223        }
224        else
225        {
226            COUT(1) << "Invalid duration in InvisiblePickup." << std::endl;
227            this->duration_ = 0.0f;
228        }
[6641]229    }
[7163]230
[7544]231    /**
232    @brief
233        Helper method. Is called by the Timer as soon as it expires.
234    */
[6708]235    void InvisiblePickup::pickupTimerCallback(void)
[6684]236    {
[6708]237        this->setUsed(false);
[6641]238    }
239
240}
Note: See TracBrowser for help on using the repository browser.