Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/network/src/orxonox/hud/RadarOverlayElement.cc @ 1454

Last change on this file since 1454 was 1454, checked in by landauf, 16 years ago

fixed tcl initialisation bug

File size: 4.8 KB
RevLine 
[1454]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 *      Yuning Chai
24 *   Co-authors:
25 *      Felix Schulthess
26 *
27 */
[1283]28
[1373]29#include "OrxonoxStableHeaders.h"
[1283]30#include "RadarOverlayElement.h"
31
[1410]32#include <string>
[1406]33#include <OgreOverlayManager.h>
34#include <OgreStringConverter.h>
35
36#include "GraphicsEngine.h"
37#include "core/Tickable.h"
38#include "core/ConsoleCommand.h"
39#include "objects/SpaceShip.h"
[1410]40#include "RadarObject.h"
[1406]41#include "HUD.h"
42
[1283]43namespace orxonox
44{
[1302]45    using namespace Ogre;
[1283]46
[1406]47    RadarOverlayElement::RadarOverlayElement(const String& name):PanelOverlayElement(name){
[1302]48    }
[1283]49
[1302]50    RadarOverlayElement::~RadarOverlayElement(){
51    }
[1283]52
[1406]53    void RadarOverlayElement::init(Real leftRel, Real topRel, Real dimRel, OverlayContainer* container){
[1339]54        // some initial data
[1410]55        om = &OverlayManager::getSingleton();
[1314]56        dimRel_ = dimRel;
57        leftRel_ = leftRel;
58        topRel_ = topRel;
[1302]59        container_ = container;
[1283]60
[1406]61        setMetricsMode(GMM_PIXELS);
[1310]62        setMaterialName("Orxonox/Radar");
[1314]63        resize();
[1339]64
[1335]65        container_->addChild(this);
[1283]66    }
[1302]67
[1314]68    void RadarOverlayElement::resize() {
69        // if window is resized, we must adapt these...
70        windowW_ = GraphicsEngine::getSingleton().getWindowWidth();
71        windowH_ = GraphicsEngine::getSingleton().getWindowHeight();
[1342]72        dim_ = (int) (dimRel_*windowH_);
73        left_ = (int) (leftRel_*windowW_-dim_/2);
74        top_ = (int) (topRel_*windowH_-dim_/2);
[1314]75        setPosition(left_, top_);
76        setDimensions(dim_,dim_);
77    }
78
[1302]79    void RadarOverlayElement::update() {
[1384]80        shipPos_ = SpaceShip::getLocalShip()->getPosition();
[1406]81        currentDir_ = SpaceShip::getLocalShip()->getDir();
[1410]82        currentOrth_ = SpaceShip::getLocalShip()->getOrth();
[1406]83        RadarObject* ro = HUD::getSingleton().getFirstRadarObject();
[1339]84        // iterate through all RadarObjects
[1410]85        while(ro != NULL){
86        // calc position on radar...
[1406]87            float radius = calcRadius(shipPos_, currentDir_, currentOrth_, ro);
88            float phi = calcPhi(shipPos_, currentDir_, currentOrth_, ro);
89            bool right = calcRight(shipPos_, currentDir_, currentOrth_, ro);
[1346]90
91            // set size to fit distance...
[1450]92            float d = (ro->getPosition()-shipPos_).length();
[1346]93            if(d<4000) ro->panel_->setDimensions(4,4);
94            else if(d<8000) ro->panel_->setDimensions(3,3);
[1354]95            else if(d<16000) ro->panel_->setDimensions(2,2);
[1346]96            else ro->panel_->setDimensions(1,1);
97
[1406]98            if (right){
99                ro->panel_->setPosition(sin(phi)*radius/
100                    3.5*dim_/2+dim_/2+left_-2,-cos(phi)*radius/3.5*dim_/2+dim_/2+top_-2);
[1339]101            }
102            else {
[1406]103                ro->panel_->setPosition(-sin(phi)*radius/
104                    3.5*dim_/2+dim_/2+left_-2,-cos(phi)*radius/3.5*dim_/2+dim_/2+top_-2);
[1339]105            }
106            ro = ro->next;
[1410]107        }
[1339]108    }
[1310]109
[1410]110    void RadarOverlayElement::listObjects(){
111        int i = 0;
112        RadarObject* ro = HUD::getSingleton().getFirstRadarObject();
113        COUT(3) << "List of RadarObjects:\n";
114        // iterate through all Radar Objects
115        while(ro != NULL) {
[1450]116            COUT(3) << i++ << ": " << ro->getPosition() << std::endl;
[1410]117            ro = ro->next;
118        }
119    }
[1339]120
[1410]121    float RadarOverlayElement::calcRadius(Vector3 pos, Vector3 dir, Vector3 orth, RadarObject* obj){
[1450]122        return(acos((dir.dotProduct(obj->getPosition() - pos))/
123        ((obj->getPosition() - pos).length()*dir.length())));
[1410]124    }
[1356]125
[1410]126    float RadarOverlayElement::calcPhi(Vector3 pos, Vector3 dir, Vector3 orth, RadarObject* obj){
127        // project difference vector on our plane...
[1450]128        Vector3 proj = Plane(dir, pos).projectVector(obj->getPosition() - pos);
[1410]129        // ...and find out the angle
130        return(acos((orth.dotProduct(proj))/
131              (orth.length()*proj.length())));
132    }
[1339]133
[1410]134    bool RadarOverlayElement::calcRight(Vector3 pos, Vector3 dir, Vector3 orth, RadarObject* obj){
[1450]135        if((dir.crossProduct(orth)).dotProduct(obj->getPosition() - pos) > 0)
[1410]136            return true;
[1339]137        else return false;
[1410]138    }
[1283]139}
Note: See TracBrowser for help on using the repository browser.