Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/OrxoBlox_FS19/src/modules/OrxoBlox/OrxoBlox.cc @ 12335

Last change on this file since 12335 was 12335, checked in by ahuwyler, 5 years ago

Random Walls are created

File size: 6.5 KB
RevLine 
[12210]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 *      Fabian 'x3n' Landau
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29/**
[12212]30    @file OrxoBlox.cc
31    @brief Implementation of the OrxoBlox class.
[12210]32*/
33
[12212]34#include "OrxoBlox.h"
[12308]35#include "Highscore.h"
[12210]36
37#include "core/CoreIncludes.h"
38#include "core/EventIncludes.h"
39#include "core/command/Executor.h"
40
[12308]41
42#include "core/config/ConfigValueIncludes.h"//Remove??
43
[12210]44#include "gamestates/GSLevel.h"
45
[12308]46
47#include "chat/ChatManager.h"//Remove?
48
[12212]49#include "OrxoBloxCenterpoint.h"
50#include "OrxoBloxBall.h"
[12331]51//#include "OrxoBloxBot.h"//Remove??
[12268]52#include "OrxoBloxStones.h"
[12288]53#include "OrxoBloxWall.h"
[12314]54#include "OrxoBloxShip.h"
[12260]55
[12210]56namespace orxonox
57{
[12308]58   
[12210]59
[12212]60    RegisterUnloadableClass(OrxoBlox);
[12210]61
62    /**
63    @brief
64        Constructor. Registers and initializes the object.
65    */
[12212]66    OrxoBlox::OrxoBlox(Context* context) : Deathmatch(context)
[12210]67    {
[12212]68        RegisterObject(OrxoBlox);
[12210]69
70        this->center_ = nullptr;
71        this->ball_ = nullptr;
[12280]72        this->futureWall_ = nullptr;
[12307]73        this->player_ = nullptr;
[12331]74        level_ = 0;
[12210]75
[12307]76        this->setHUDTemplate("OrxoBloxHUD");
[12277]77        //Error when specified
[12210]78
79        // Pre-set the timer, but don't start it yet.
[12212]80        this->starttimer_.setTimer(1.0, false, createExecutor(createFunctor(&OrxoBlox::startBall, this)));
[12210]81        this->starttimer_.stopTimer();
82
[12307]83       
[12210]84
85    }
86
87    /**
88    @brief
89        Destructor. Cleans up, if initialized.
90    */
[12212]91    OrxoBlox::~OrxoBlox()
[12210]92    {
93        if (this->isInitialized())
94            this->cleanup();
95    }
96
97    /**
98    @brief
99        Cleans up the Gametype by destroying the ball and the bats.
100    */
[12212]101    void OrxoBlox::cleanup()
[12210]102    {
103        if (this->ball_ != nullptr) // Destroy the ball, if present.
104        {
105            this->ball_->destroy();
106            this->ball_ = nullptr;
107        }
108
[12307]109        if (this->futureWall_)
110            {
111                this->futureWall_->destroy();
112                this->futureWall_ = nullptr;
113            }
114
115        // Destroy 6 bWalls, if present.
116        for (size_t i = 0; i < 6; ++i)
[12210]117        {
[12307]118            if (this->activeWalls_[0] != nullptr)
[12210]119            {
[12307]120                this->activeWalls_[0]->destroy();
121                this->activeWalls_[0] = nullptr;
[12210]122            }
[12307]123           
[12210]124        }
125
126    }
127
128    /**
[12307]129    @brieftt   
[12212]130        Starts the OrxoBlox minigame.
[12210]131    */
[12212]132    void OrxoBlox::start()
[12210]133    {
[12212]134        if (this->center_ != nullptr) // There needs to be a OrxoBloxCenterpoint, i.e. the area the game takes place.
[12210]135        {
136            if (this->ball_ == nullptr) // If there is no ball, create a new ball.
137            {
[12212]138                this->ball_ = new OrxoBloxBall(this->center_->getContext());
[12210]139                // Apply the template for the ball specified by the centerpoint.
140                this->ball_->addTemplate(this->center_->getBalltemplate());
141            }
142
143            // Attach the ball to the centerpoint and set the parameters as specified in the centerpoint, the ball is attached to.
144            this->center_->attach(this->ball_);
[12307]145            this->ball_->setPosition(0, 0, 50);
[12210]146            this->ball_->setFieldDimension(this->center_->getFieldDimension());
147            this->ball_->setSpeed(0);
148            this->ball_->setAccelerationFactor(this->center_->getBallAccelerationFactor());
149            this->ball_->setBatLength(this->center_->getBatLength());
150
[12331]151            level_=1;
[12307]152
153            // Create the first Wall.
154            this->createWall();
155
[12210]156        }
157        else // If no centerpoint was specified, an error is thrown and the level is exited.
158        {
[12212]159            orxout(internal_error) << "OrxoBlox: No Centerpoint specified." << endl;
[12210]160            GSLevel::startMainMenu();
161            return;
162        }
163
164        // Start the timer. After it has expired the ball is started.
165        this->starttimer_.startTimer();
166
167        // Set variable to temporarily force the player to spawn.
[12329]168        this->bForceSpawn_ = false;
[12210]169
170        // Call start for the parent class.
171        Deathmatch::start();
172
173    }
174
175    /**
176    @brief
[12212]177        Ends the OrxoBlox minigame.
[12210]178    */
[12212]179    void OrxoBlox::end()
[12210]180    {
[12268]181        ChatManager::message("You suck!!");
[12210]182        this->cleanup();
183
184        // Call end for the parent class.
185        Deathmatch::end();
186    }
187
188    /**
189    @brief
190        Spawns the input player.
191    @param player
192        The player to be spawned.
193    */
[12212]194    void OrxoBlox::spawnPlayer(PlayerInfo* player)
[12210]195    {
[12307]196         assert(player);
[12210]197
[12307]198        if(this->player_ == nullptr)
[12210]199        {
[12307]200            this->player_ = player;
[12210]201            this->players_[player].state_ = PlayerState::Alive;
202        }
203    }
204
[12314]205    OrxoBloxShip* OrxoBlox::getPlayer()
206    {
207        for (OrxoBloxShip* ship : ObjectList<OrxoBloxShip>())
208        {
209            return ship;
210        }
211        return nullptr;
212    }
213
[12307]214    //void startWall(void);
215   
[12331]216    void OrxoBlox::LevelUp(){
217        level_++;
218        //When levelup? wo wird es ausgeloest?
219        //new location of ship
220        //new amount of balls
221        //create balls
222        //insert new wall
223    }
[12210]224
[12307]225    void OrxoBlox::createWall(void){
226        this->futureWall_ = new OrxoBloxWall(this->center_->getContext());
227        // Apply the stone template to the stone.
228        this->futureWall_->addTemplate(this->center_->getWallTemplate());
[12210]229
[12307]230        // Attach the brick to the Centerpoint and set the position of the brick to be at the left side.
231        this->center_->attach(this->futureWall_);
232       
233       
[12335]234        this->futureWall_->setPosition(0, 0, 0.0f);
[12307]235        this->futureWall_->setGame(this);
[12210]236    }
237
[12278]238
[12210]239    /**
240    @brief
241        Starts the ball with some default speed.
242    */
[12212]243    void OrxoBlox::startBall()
[12210]244    {
245        if (this->ball_ != nullptr && this->center_ != nullptr)
246            this->ball_->setSpeed(this->center_->getBallSpeed());
247    }
248
[12260]249   
[12307]250   
[12210]251}
Note: See TracBrowser for help on using the repository browser.