Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/campaignHS15/src/orxonox/controllers/WingmanController.cc @ 10953

Last change on this file since 10953 was 10953, checked in by gania, 8 years ago

converted hack to a legal class

File size: 7.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 *      Gani Aliguzhinov
24 *   Co-authors:
25 *      ...
26 *
27 */
28
29#include "WingmanController.h"
30
31
32namespace orxonox
33{
34
35    RegisterClass(WingmanController);
36   
37    //ActionpointController contains all common functionality of AI Controllers
38    WingmanController::WingmanController(Context* context) : ActionpointController(context)
39    {
40        RegisterObject(WingmanController);
41        this->myLeader_ = 0;
42        this->bFirstAction_ = true;
43
44    }
45
46    WingmanController::~WingmanController()
47    {
48        for (size_t i = 0; i < this->actionpoints_.size(); ++i)
49        {
50            if(this->actionpoints_[i])
51                this->actionpoints_[i]->destroy();
52        }
53        this->parsedActionpoints_.clear();
54        this->actionpoints_.clear();
55    }
56 
57    void WingmanController::XMLPort(Element& xmlelement, XMLPort::Mode mode)
58    {
59        SUPER(WingmanController, XMLPort, xmlelement, mode);
60    }
61   
62    //----in tick, move (or look) and shoot----
63    void WingmanController::tick(float dt)
64    {   
65        if (!this->isActive())
66            return; 
67       
68        SUPER(WingmanController, tick, dt);
69
70    }
71   
72    //----action for hard calculations----
73    void WingmanController::action()
74    {
75        if (!this || !this->getControllableEntity() || !this->isActive())
76            return;
77        //----If no leader, find one----
78        if (!this->myLeader_)
79        {
80            ActionpointController* newLeader = (findNewLeader());
81            if (!this || !this->getControllableEntity())
82                return;
83
84            this->myLeader_ = newLeader;
85            if (this->myLeader_)
86            {
87               
88            }
89        }
90        //----If have leader, he will deal with logic----
91        else
92        {
93
94        }
95        if (!this->myLeader_)
96        {
97            ActionpointController::action();
98        }
99        else if (this->myLeader_)
100        {
101            if (this->myLeader_->bKeepFormation_ || !(this->myLeader_->getAction() == Action::FIGHT || this->myLeader_->getAction() == Action::FIGHTALL
102                || this->myLeader_->getAction() == Action::ATTACK))
103            {
104                this->keepFormation();
105            }
106            else if (!this->myLeader_->bKeepFormation_)
107            {
108                if (!this || !this->getControllableEntity())
109                    return;
110
111                if (!this->hasTarget())
112                {
113                    this->setTarget(this->myLeader_->getTarget());
114                }
115               
116            }
117        }
118    }
119     
120   
121    Vector3 WingmanController::getFormationPosition ()
122    {
123
124
125        this->setFormationMode( this->myLeader_->getFormationMode() );
126        Vector3* targetRelativePosition;
127        this->spread_ = this->myLeader_->getSpread();
128        if (this->myLeader_->getIdentifier()->getName() == "DivisionController")
129        {
130            switch (this->formationMode_){
131                case FormationMode::WALL:
132                {
133                    targetRelativePosition = new Vector3 (2*this->spread_, 0, 0 - this->tolerance_); 
134                    break;
135                }
136                case FormationMode::FINGER4: 
137                {
138                    targetRelativePosition = new Vector3 (2*this->spread_, 0, this->spread_ - this->tolerance_); 
139                    break;
140                }
141                case FormationMode::DIAMOND: 
142                {
143                    targetRelativePosition = new Vector3 (2*this->spread_, 0, this->spread_ - this->tolerance_);                 
144                    break;
145                }
146            }
147        }
148        else
149        {
150
151            switch (this->formationMode_){
152                case FormationMode::WALL:
153                {
154                    targetRelativePosition = new Vector3 (-2*this->spread_, 0, 0 - this->tolerance_); 
155                    break;
156                }
157                case FormationMode::FINGER4: 
158                {
159                    targetRelativePosition = new Vector3 (-2*this->spread_, 0, this->spread_ - this->tolerance_); 
160                    break;
161                }
162                case FormationMode::DIAMOND: 
163                {
164                    targetRelativePosition = new Vector3 (2*this->spread_, -this->spread_, 0 - this->tolerance_);                 
165                    break;
166                }
167            }
168        }
169        Vector3 result = *targetRelativePosition;
170        delete targetRelativePosition;
171        return result;
172    }
173    void WingmanController::keepFormation()
174    {
175        this->bKeepFormation_ = true;
176        ControllableEntity* leaderEntity = this->myLeader_->getControllableEntity();
177        Vector3 targetRelativePosition = this->getFormationPosition();
178        if (!leaderEntity)
179            return;
180        FlyingController::keepFormation (leaderEntity, targetRelativePosition);
181    }
182    //----POST: closest leader that is ready to take a new wingman is returned----
183    ActionpointController* WingmanController::findNewLeader()
184    {
185
186        if (!this->getControllableEntity())
187            return 0;
188
189        //----vars for finding the closest leader----
190        ActionpointController* closestLeader = 0;
191        float minDistance =  std::numeric_limits<float>::infinity();
192        Gametype* gt = this->getGametype();
193
194        for (ObjectList<ActionpointController>::iterator it = ObjectList<ActionpointController>::begin(); it; ++it)
195        {
196            //----0ptr or not a leader or dead?----
197            if (!it || 
198                (it->getIdentifier()->getName() != "SectionController" && it->getIdentifier()->getName() != "DivisionController") || 
199                !(it->getControllableEntity()))
200                continue;
201           
202            //----same team?----
203            if ( !CommonController::sameTeam (this->getControllableEntity(), (it)->getControllableEntity(), gt) )
204                continue;
205           
206            //----check distance----
207            float distance = CommonController::distance (it->getControllableEntity(), this->getControllableEntity());
208            if (distance < minDistance && !(it->hasWingman()))
209            {
210                closestLeader = *it;
211                minDistance = distance;
212            }
213        }
214        if (closestLeader)
215        {
216            //----Racing conditions----
217            if (closestLeader->setWingman(orxonox_cast<ActionpointController*>(this)))
218            {
219                if (closestLeader->getIdentifier()->getName() == "SectionController")
220                {
221                    this->actionTime_ = 1.6f;
222                }
223                else
224                {
225                    this->actionTime_ = 2.0f;
226                }
227                return closestLeader;
228            }
229        }
230        return 0;
231    }
232
233}
Note: See TracBrowser for help on using the repository browser.