Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: code/branches/radarDreiD/src/modules/overlays/hud/HUDRadar.cc @ 9796

Last change on this file since 9796 was 9796, checked in by wroennin, 10 years ago

added Co Autor

  • Property svn:eol-style set to native
File size: 9.0 KB
RevLine 
[1505]1/*
2 *   ORXONOX - the hottest 3D action shooter ever to exist
3 *                    > www.orxonox.net <
[1502]4 *
[1505]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 *
[1502]22 *   Author:
23 *      Yuning Chai
[1614]24 *      Felix Schulthess
[1502]25 *   Co-authors:
[1614]26 *      Reto Grieder
[9796]27 *      Wolfgang Roenninger
[1502]28 *
29 */
[1283]30
[1604]31#include "HUDRadar.h"
[1283]32
[1502]33#include <OgreOverlayManager.h>
[1614]34#include <OgrePanelOverlayElement.h>
[1502]35
[1614]36#include "util/Math.h"
[3280]37#include "util/StringUtils.h"
[1616]38#include "core/CoreIncludes.h"
39#include "core/XMLPort.h"
[3196]40#include "tools/TextureGenerator.h"
[7880]41#include "worldentities/ControllableEntity.h"
[7163]42#include "Scene.h"
43#include "Radar.h"
[1502]44
[1283]45namespace orxonox
46{
[9667]47    RegisterClass(HUDRadar);
[1604]48
[9667]49    HUDRadar::HUDRadar(Context* context)
50        : OrxonoxOverlay(context)
[1604]51    {
52        RegisterObject(HUDRadar);
[2087]53
[2662]54        this->marker_ = static_cast<Ogre::PanelOverlayElement*>(Ogre::OverlayManager::getSingleton()
[2087]55            .createOverlayElement("Panel", "HUDRadar_marker_" + getUniqueNumberString()));
[2662]56        this->marker_->setMaterialName("Orxonox/RadarMarker");
57        this->overlay_->add2D(this->marker_);
58        this->marker_->hide();
[2087]59
[2662]60        this->setRadarSensitivity(1.0f);
61        this->setHalfDotSizeDistance(3000.0f);
62        this->setMaximumDotSize(0.1f);
[2087]63
[7368]64        this->shapeMaterials_[RadarViewable::Dot]      = "RadarDot.png";
65        this->shapeMaterials_[RadarViewable::Triangle] = "RadarTriangle.png";
66        this->shapeMaterials_[RadarViewable::Square]   = "RadarSquare.png";
[9742]67        this->setDetectionLimit( 10000.0f );
[2662]68        this->owner_ = 0;
[1302]69    }
[1283]70
[1604]71    HUDRadar::~HUDRadar()
72    {
[2087]73        if (this->isInitialized())
74        {
[1615]75            Ogre::OverlayManager::getSingleton().destroyOverlayElement(this->marker_);
[7163]76            for (std::map<RadarViewable*,Ogre::PanelOverlayElement*>::iterator it = this->radarObjects_.begin();
77                it != this->radarObjects_.end(); ++it)
[2087]78            {
[7163]79                Ogre::OverlayManager::getSingleton().destroyOverlayElement(it->second);
[2087]80            }
[1604]81        }
[1302]82    }
[1283]83
[7401]84    void HUDRadar::XMLPort(Element& xmlelement, XMLPort::Mode mode)
[1604]85    {
[7401]86        SUPER(HUDRadar, XMLPort, xmlelement, mode);
[1283]87
[7401]88        XMLPortParam(HUDRadar, "sensitivity", setRadarSensitivity, getRadarSensitivity, xmlelement, mode);
89        XMLPortParam(HUDRadar, "halfDotSizeDistance", setHalfDotSizeDistance, getHalfDotSizeDistance, xmlelement, mode);
90        XMLPortParam(HUDRadar, "maximumDotSize", setMaximumDotSize, getMaximumDotSize, xmlelement, mode);
[1609]91    }
[1302]92
[7163]93    void HUDRadar::addObject(RadarViewable* object)
[1604]94    {
[9348]95        if (object == orxonox_cast<RadarViewable*>(this->owner_))
[2662]96            return;
[8891]97        if( showObject(object) == false ) //do not show objects that are "invisible" or "radar invisible"
98            return;
[2662]99
[7163]100        // Make sure the object hasn't been added yet
101        assert( this->radarObjects_.find(object) == this->radarObjects_.end() );
[1604]102
[7163]103        // Create everything needed to display the object on the radar and add it to the map
104        Ogre::PanelOverlayElement* panel;
105        panel = static_cast<Ogre::PanelOverlayElement*>(
106            Ogre::OverlayManager::getSingleton().createOverlayElement("Panel", "RadarDot" + getUniqueNumberString()));
107        this->overlay_->add2D(panel);
108        // get right material
109        panel->setMaterialName(TextureGenerator::getMaterialName(
110            shapeMaterials_[object->getRadarObjectShape()], object->getRadarObjectColour()));
[8738]111        panel->hide();
[7163]112        this->radarObjects_[object] = panel;
113    }
114
115    void HUDRadar::removeObject(RadarViewable* object)
116    {
117        // If object was added at all then remove it
118        std::map<RadarViewable*,Ogre::PanelOverlayElement*>::iterator it;
119        it = this->radarObjects_.find( object );
120        if( it != this->radarObjects_.end() )
[1609]121        {
[7163]122            Ogre::OverlayManager::getSingleton().destroyOverlayElement(it->second);
123            this->radarObjects_.erase(it);
[1609]124        }
[7163]125    }
[2662]126
[7163]127    void HUDRadar::objectChanged( RadarViewable* rv )
[8891]128    {// The new implementation behaves more precisely, since inactive RadarViewables are not displayed anymore.
129        this->removeObject(rv);
130        this->addObject(rv);
[7163]131    }
132
133    void HUDRadar::gatherObjects()
134    {
135        const std::set<RadarViewable*>& objectSet = this->getCreator()->getScene()->getRadar()->getRadarObjects();
136        std::set<RadarViewable*>::const_iterator it;
137        for( it=objectSet.begin(); it!=objectSet.end(); ++it )
138            this->addObject(*it);
[8737]139        this->radarTick(0);
[7163]140    }
141
142    void HUDRadar::radarTick(float dt)
143    {
144        // Make sure the owner of the radar was defined
145        if( !this->owner_ )
[7880]146            return;
[7163]147
148        this->marker_->hide();      // in case that no object is in focus
149        // get the focus object
150        Radar* radar = this->getOwner()->getScene()->getRadar();
151        const RadarViewable* focusObject = radar->getFocus();
152
153        // update the distances for all objects
154        std::map<RadarViewable*,Ogre::PanelOverlayElement*>::iterator it;
155        for( it = this->radarObjects_.begin(); it != this->radarObjects_.end(); ++it )
[1614]156        {
[7163]157            // Make sure the object really is a WorldEntity
158            const WorldEntity* wePointer = it->first->getWorldEntity();
159            if( !wePointer )
160            {
[8858]161                orxout(internal_error) << "Cannot display a non-WorldEntitiy on the radar" << endl;
[7163]162                assert(0);
163            }
164            bool isFocus = (it->first == focusObject);
165            // set size to fit distance...
166            float distance = (wePointer->getWorldPosition() - this->owner_->getPosition()).length();
167            // calculate the size with 1/distance dependency for simplicity (instead of exp(-distance * lambda)
[8738]168            float size = maximumDotSize_ * halfDotSizeDistance_ / (halfDotSizeDistance_ + distance) * it->first->getRadarObjectScale();
[9792]169
170
[7163]171            it->second->setDimensions(size, size);
[2662]172
[7163]173            // calc position on radar...
[9719]174            //Vector2 coord = get2DViewcoordinates(this->owner_->getPosition(), this->owner_->getOrientation() * WorldEntity::FRONT, this->owner_->getOrientation() * WorldEntity::UP, wePointer->getWorldPosition());
[9740]175            Vector2 coord = get3DProjection(this->owner_->getPosition(), this->owner_->getOrientation() * WorldEntity::FRONT, this->owner_->getOrientation() * WorldEntity::UP, wePointer->getWorldPosition(), 0.6435011, detectionLimit_);
[9787]176
[9792]177            // set zOrder on screen
178            bool overXZPlain = isObjectHigherThanShipOnMap(this->owner_->getPosition(), this->owner_->getOrientation() * WorldEntity::FRONT, this->owner_->getOrientation() * WorldEntity::UP, wePointer->getWorldPosition(), 0.6435011);
179
180            if(overXZPlain == false && (it->second->getZOrder() >  100 * this->overlay_->getZOrder())) // it appears that zOrder of attached Overlayelements is 100 times the zOrder of the Overlay
181                it->second->_notifyZOrder(this->overlay_->getZOrder() * 100 - 1);
182            if(overXZPlain == true && (it->second->getZOrder() <= 100 * this->overlay_->getZOrder()))
183                it->second->_notifyZOrder(this->overlay_->getZOrder() * 100 + 1);
184
185
186
[7184]187            coord *= math::pi / 3.5f; // small adjustment to make it fit the texture
[7163]188            it->second->setPosition((1.0f + coord.x - size) * 0.5f, (1.0f - coord.y - size) * 0.5f);
[9779]189
[8891]190            if( distance < detectionLimit_ || detectionLimit_ < 0 )
191                it->second->show();
192            else
193                it->second->hide();
[1613]194
[7163]195            // if this object is in focus, then set the focus marker
196            if (isFocus)
197            {
198                this->marker_->setDimensions(size * 1.5f, size * 1.5f);
199                this->marker_->setPosition((1.0f + coord.x - size * 1.5f) * 0.5f, (1.0f - coord.y - size * 1.5f) * 0.5f);
200                this->marker_->show();
201            }
[1613]202        }
[1604]203    }
204
[8891]205    bool HUDRadar::showObject(RadarViewable* rv)
206    {
[9348]207        if ( rv == orxonox_cast<RadarViewable*> ( this->getOwner() ) )
[8891]208            return false;
209        assert( rv->getWorldEntity() );
210        if ( rv->getWorldEntity()->isVisible()==false || rv->getRadarVisibility()==false )
211            return false;
212        return true;
213    }
214
215
[2662]216    void HUDRadar::changedOwner()
217    {
[7880]218        SUPER(HUDRadar, changedOwner);
[2662]219
[7880]220        this->owner_ = orxonox_cast<ControllableEntity*>(this->getOwner());
221        assert(this->radarObjects_.size() == 0);
222        this->gatherObjects();
223    }
[1283]224}
Note: See TracBrowser for help on using the repository browser.