ObstacleGroupNode.cc 2.82 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
/*=====================================================================

QGroundControl Open Source Ground Control Station

(c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>

This file is part of the QGROUNDCONTROL project

    QGROUNDCONTROL is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    QGROUNDCONTROL is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.

======================================================================*/

/**
 * @file
 *   @brief Definition of the class ObstacleGroupNode.
 *
 *   @author Lionel Heng <hengli@inf.ethz.ch>
 *
 */

#include "ObstacleGroupNode.h"

34
#include <limits>
35 36 37
#include <osg/PositionAttitudeTransform>
#include <osg/ShapeDrawable>

38
#include "gpl.h"
39 40 41 42 43 44 45 46 47 48 49 50 51
#include "Imagery.h"

ObstacleGroupNode::ObstacleGroupNode()
{

}

void
ObstacleGroupNode::init(void)
{

}

52 53 54 55 56 57 58 59 60
void
ObstacleGroupNode::clear(void)
{
    if (getNumChildren() > 0)
    {
        removeChild(0, getNumChildren());
    }
}

61
void
62 63
ObstacleGroupNode::update(double robotX, double robotY, double robotZ,
                          const px::ObstacleList& obstacleList)
64
{
65
    clear();
66 67 68

    osg::ref_ptr<osg::Geode> geode = new osg::Geode;

69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87
    // find minimum and maximum height
    float zMin = std::numeric_limits<float>::max();
    float zMax = std::numeric_limits<float>::min();
    for (int i = 0; i < obstacleList.obstacles_size(); ++i)
    {
        const px::Obstacle& obs = obstacleList.obstacles(i);

        float z = robotZ - obs.z();

        if (zMin > z)
        {
            zMin = z;
        }
        if (zMax < z)
        {
            zMax = z;
        }
    }

88 89 90 91 92 93 94 95 96 97
    for (int i = 0; i < obstacleList.obstacles_size(); ++i)
    {
        const px::Obstacle& obs = obstacleList.obstacles(i);

        osg::Vec3d obsPos(obs.y() - robotY, obs.x() - robotX, robotZ - obs.z());

        osg::ref_ptr<osg::Box> box =
            new osg::Box(obsPos, obs.width(), obs.width(), obs.height());
        osg::ref_ptr<osg::ShapeDrawable> sd = new osg::ShapeDrawable(box);

98 99 100 101
        int idx = (obsPos.z() - zMin) / (zMax - zMin) * 127.0f;
        float r, g, b;
        qgc::colormap("jet", idx, r, g, b);

102
        sd->getOrCreateStateSet()->setMode(GL_BLEND, osg::StateAttribute::ON);
103
        sd->setColor(osg::Vec4(r, g, b, 1.0f));
104
        sd->setUseDisplayList(false);
105 106 107 108 109 110 111

        geode->addDrawable(sd);
    }

    addChild(geode);
}