LCOV - code coverage report
Current view: top level - src/foreign/rtree - LayeredRTree.h (source / functions) Hit Total Coverage
Test: lcov.info Lines: 21 21 100.0 %
Date: 2024-05-06 15:32:35 Functions: 5 6 83.3 %

          Line data    Source code
       1             : /****************************************************************************/
       2             : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
       3             : // Copyright (C) 2001-2024 German Aerospace Center (DLR) and others.
       4             : // This program and the accompanying materials are made available under the
       5             : // terms of the Eclipse Public License 2.0 which is available at
       6             : // https://www.eclipse.org/legal/epl-2.0/
       7             : // This Source Code may also be made available under the following Secondary
       8             : // Licenses when the conditions for such availability set forth in the Eclipse
       9             : // Public License 2.0 are satisfied: GNU General Public License, version 2
      10             : // or later which is available at
      11             : // https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
      12             : // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
      13             : /****************************************************************************/
      14             : /// @file    LayeredRTree.h
      15             : /// @author  Jakob Erdmann
      16             : /// @date    16.10.2012
      17             : ///
      18             : // A wrapper around RT-trees for for efficient storing of SUMO's GL-objects and
      19             : // accessing them ordered by their layer
      20             : // Note that we only need two layers at this time:
      21             : // 1 (GLO_LANE, GLO_VEHICLE, GLO_POI)
      22             : // 2 all the rest
      23             : // The search order returns layer 2 first because it must be drawn before layer
      24             : // 1 for alpha blending to work
      25             : /****************************************************************************/
      26             : #pragma once
      27             : #include <config.h>
      28             : 
      29             : #include <utils/gui/globjects/GUIGlObject.h>
      30             : #include <utils/gui/globjects/GUIGlObjectTypes.h>
      31             : #include <utils/gui/settings/GUIVisualizationSettings.h>
      32             : #include <utils/geom/Boundary.h>
      33             : 
      34             : #include "SUMORTree.h"
      35             : 
      36             : 
      37             : // ===========================================================================
      38             : // class definitions
      39             : // ===========================================================================
      40             : /** @class LayeredRTree
      41             :  * @brief A RT-tree for efficient storing of SUMO's GL-objects in layers
      42             :  *
      43             :  * This class maintains SUMORTrees for each layer (only 2 at the moment) but
      44             :  * provides the same interface as SUMORTree
      45             :  */
      46             : class LayeredRTree : public SUMORTree {
      47             : public:
      48             :     /// @brief Constructor
      49        7232 :     LayeredRTree() {
      50       14464 :         myLayers.push_back(new SUMORTree());
      51       14464 :         myLayers.push_back(new SUMORTree());
      52        7232 :     }
      53             : 
      54             : 
      55             :     /// @brief Destructor
      56        7217 :     ~LayeredRTree() {
      57       21651 :         for (std::vector<SUMORTree*>::iterator it = myLayers.begin(); it != myLayers.end(); ++it) {
      58       14434 :             delete *it;
      59             :         }
      60             :         myLayers.clear();
      61        7217 :     }
      62             : 
      63             : 
      64             :     /** @brief Insert entry (delegate to appropriate layer)
      65             :      * @param a_min Min of bounding rect
      66             :      * @param a_max Max of bounding rect
      67             :      * @param a_dataId Positive Id of data.  Maybe zero, but negative numbers not allowed.
      68             :      */
      69      388759 :     void Insert(const float a_min[2], const float a_max[2], GUIGlObject* const & a_dataId) {
      70      498683 :         myLayers[selectLayer(a_dataId)]->Insert(a_min, a_max, a_dataId);
      71      388759 :     }
      72             : 
      73             : 
      74             :     /** @brief Remove entry (delegate to appropriate layer)
      75             :      * @param a_min Min of bounding rect
      76             :      * @param a_max Max of bounding rect
      77             :      * @param a_dataId Positive Id of data.  Maybe zero, but negative numbers not allowed.
      78             :      */
      79        3119 :     void Remove(const float a_min[2], const float a_max[2], GUIGlObject* const & a_dataId) {
      80        6129 :         myLayers[selectLayer(a_dataId)]->Remove(a_min, a_max, a_dataId);
      81        3119 :     }
      82             : 
      83             :     /** @brief Find all within search rectangle (searches all layers in order)
      84             :      * @param a_min Min of search bounding rect
      85             :      * @param a_max Max of search bounding rect
      86             :      * @param a_searchResult Search result array.  Caller should set grow size. Function will reset, not append to array.
      87             :      * @param a_resultCallback Callback function to return result.  Callback should return 'true' to continue searching
      88             :      * @param a_context User context to pass as parameter to a_resultCallback
      89             :      * @return Returns the number of entries found
      90             :      */
      91      481004 :     int Search(const float a_min[2], const float a_max[2], const GUIVisualizationSettings& c) const {
      92             :         int result = 0;
      93     1443010 :         for (std::vector<SUMORTree*>::const_iterator it = myLayers.begin(); it != myLayers.end(); ++it) {
      94      962008 :             result += (*it)->Search(a_min, a_max, c);
      95             :         }
      96      481002 :         return result;
      97             :     }
      98             : 
      99             : 
     100             : protected:
     101             :     /// @brief the layers for drawing
     102             :     std::vector<SUMORTree*> myLayers;
     103             : 
     104             : private:
     105             : 
     106             :     /// @brief select the appropriate layer for each object
     107             :     inline size_t selectLayer(GUIGlObject* o) {
     108      391878 :         switch (o->getType()) {
     109             :             case GLO_EDGE:
     110             :             case GLO_LANE:
     111             :             case GLO_POI:
     112             :             case GLO_VEHICLE:
     113             :             case GLO_PERSON:
     114             :                 return 1;
     115             :                 break;
     116      112934 :             default:
     117      112934 :                 return 0;
     118             :         }
     119             :     }
     120             : 
     121             : };

Generated by: LCOV version 1.14