Changeset 1309 for GTP/trunk/Lib/Geom


Ignore:
Timestamp:
09/01/06 10:52:30 (18 years ago)
Author:
gumbau
Message:

Lod Manager structure modification

File:
1 edited

Legend:

Unmodified
Added
Removed
  • GTP/trunk/Lib/Geom/shared/GTGeometry/src/GeoLodManager.cpp

    r1071 r1309  
    1212#include "GeoLodManager.h" 
    1313#include "GeoLodObject.h" 
    14  
     14#include <algorithm> 
     15/* 
    1516namespace Geometry 
    1617{ 
     18 
     19 
    1720        class lodobj_idpos_node_t 
    1821        { 
     
    2124                LodObject *lodobj; 
    2225                float dist2cam; // used to index the lodobj in the other map 
    23                 bool must_recalculate_distance; 
    2426                bool operator < (const lodobj_idpos_node_t &o) const { return (lodobj->GetUniqueID()<o.lodobj->GetUniqueID()); } 
    2527        }; 
    26 } 
     28}*/ 
    2729 
    2830using namespace Geometry; 
     
    3234 near_range(near),far_range(far) 
    3335{ 
     36        // make the lodobj_dists vector into a heap 
     37        make_heap(lodobj_dists.begin(),lodobj_dists.end()); 
    3438} 
    3539 
    3640void Geometry::LodManager::AddLodObj(LodObject * o, const Geometry::Vector3 &p) 
    3741{ 
    38         float dist = CalculateDistToCamera(p);   
    39         lodobj_dists[dist] = lodobj_dist_node_t(o); 
     42        float dist = CalculateDistToCamera(p); 
     43        lodobj_dists.push_back(lodobj_dist_node_t(dist,o)); 
     44        push_heap(lodobj_dists.begin(),lodobj_dists.end()); 
     45//      lodobj_dists[dist] = lodobj_dist_node_t(o); 
    4046        UpdateLODObjectPos(o,p); 
    4147} 
     
    4450void Geometry::LodManager::UpdateLOD(void) 
    4551{ 
    46         // recalculate distances if have to 
    47         if (camera_changed) 
     52        if (!lodobj_dists.empty()) 
    4853        { 
    49                 // if the camera has changed, recalculate all lodobject distances to it          
    50                 lodobj_dists.clear(); 
    51                 for (std::map<Geometry::lodobj_idpos_node_t,Geometry::Vector3>::iterator it = lodobj_pos.begin(); it != lodobj_pos.end(); it++) 
    52                 { 
    53                         const lodobj_idpos_node_t & posnode = it->first; 
    54                         const Vector3 & pos = it->second; 
    55                         float newdist = CalculateDistToCamera(pos); 
    56                         lodobj_dists[newdist] = lodobj_dist_node_t(posnode.lodobj); 
    57                 } 
    58                 camera_changed=false; 
    59         } 
    60         else 
    61         { 
    62                 // if any of the objects changed its position, the distance must be recalculated 
    63                 for (std::map<Geometry::lodobj_idpos_node_t,Geometry::Vector3>::iterator it = lodobj_pos.begin(); it != lodobj_pos.end(); it++) 
    64                 { 
    65                         const lodobj_idpos_node_t & posnode = it->first; 
    66                         if (posnode.must_recalculate_distance) 
     54                // update distances to the camera 
     55                bool must_resort = false; 
     56                for (std::vector<lodobj_dist_node_t>::iterator it=lodobj_dists.begin(); it!=lodobj_dists.end(); it++) 
     57                {                        
     58                        lodobj_dist_node_t & node = *it; 
     59                        if (camera_changed || node.must_recalculate_distance) 
    6760                        { 
    68                                 const Vector3 & pos = it->second; 
    69                                 float newdist = CalculateDistToCamera(pos); 
    70                                 lodobj_dists[newdist] = lodobj_dist_node_t(posnode.lodobj); 
    71 /*                              lodobj_dists.erase(it);*/ 
     61                                RecalculateDist(node); 
     62                                must_resort=true; 
    7263                        } 
    7364                } 
     65                if (must_resort) 
     66                        sort_heap(lodobj_dists.begin(),lodobj_dists.end()); 
     67 
     68                // select a tree to change its LOD 
     69        //      float random_dist = SelectRandomDistance(); 
     70        //      std::map<float,Geometry::lodobj_dist_node_t>::iterator nearest = lodobj_dists.upper_bound(random_dist); 
     71 
     72                // the begining of the list is the greater element (greater dist)                
     73                lodobj_dist_node_t & node = lodobj_dists.front(); 
    7474        } 
     75        camera_changed=false; 
     76} 
    7577 
    76         // select a tree to change its LOD 
    77         float random_dist = SelectRandomDistance(); 
    78         std::map<float,Geometry::lodobj_dist_node_t>::iterator nearest = lodobj_dists.upper_bound(random_dist); 
     78void Geometry::LodManager::RecalculateDist(lodobj_dist_node_t & node) 
     79{ 
     80        std::map<uint32,Vector3>::iterator posit = lodobj_pos.find(node.lodobj->GetUniqueID()); 
     81        assert(posit!=lodobj_pos.end()); 
     82        const Vector3 & pos = posit->second; 
     83 
     84        node.dist2cam = CalculateDistToCamera(pos); 
    7985} 
     86 
    8087 
    8188void Geometry::LodManager::UpdateCamera(const Geometry::Vector3 &p) 
     
    8794void Geometry::LodManager::UpdateLODObjectPos(LodObject *o, const Geometry::Vector3 &p) 
    8895{ 
    89         lodobj_pos[lodobj_idpos_node_t(o)] = p; 
     96        lodobj_pos[o->GetUniqueID()] = p; 
    9097} 
    9198 
Note: See TracChangeset for help on using the changeset viewer.