00001 /****************************************************************************/ 00007 // ------------------- 00008 /****************************************************************************/ 00009 // SUMO, Simulation of Urban MObility; see http://sumo.sourceforge.net/ 00010 // Copyright 2001-2010 DLR (http://www.dlr.de/) and contributors 00011 /****************************************************************************/ 00012 // 00013 // This program is free software; you can redistribute it and/or modify 00014 // it under the terms of the GNU General Public License as published by 00015 // the Free Software Foundation; either version 2 of the License, or 00016 // (at your option) any later version. 00017 // 00018 /****************************************************************************/ 00019 #ifndef NIVissimNodeDef_h 00020 #define NIVissimNodeDef_h 00021 00022 00023 // =========================================================================== 00024 // included modules 00025 // =========================================================================== 00026 #ifdef _MSC_VER 00027 #include <windows_config.h> 00028 #else 00029 #include <config.h> 00030 #endif 00031 00032 #include <string> 00033 #include <map> 00034 #include <utils/common/VectorHelper.h> 00035 #include <utils/geom/Boundary.h> 00036 #include "NIVissimExtendedEdgePointVector.h" 00037 #include "NIVissimNodeCluster.h" 00038 00039 00040 class NIVissimNodeDef { 00041 public: 00042 NIVissimNodeDef(int id, const std::string &name); 00043 virtual ~NIVissimNodeDef(); 00044 int buildNodeCluster(); 00045 // virtual void computeBounding() = 0; 00046 // bool partialWithin(const AbstractPoly &p, SUMOReal off=0.0) const; 00047 virtual void searchAndSetConnections() = 0; 00048 virtual SUMOReal getEdgePosition(int edgeid) const = 0; 00049 00050 public: 00051 static bool dictionary(int id, NIVissimNodeDef *o); 00052 static NIVissimNodeDef *dictionary(int id); 00053 // static IntVector getWithin(const AbstractPoly &p, SUMOReal off=0.0); 00054 // static void buildNodeClusters(); 00055 static void dict_assignConnectionsToNodes(); 00056 static size_t dictSize(); 00057 static void clearDict(); 00058 static int getMaxID(); 00059 protected: 00060 int myID; 00061 std::string myName; 00062 00063 private: 00064 typedef std::map<int, NIVissimNodeDef*> DictType; 00065 static DictType myDict; 00066 static int myMaxID; 00067 }; 00068 00069 00070 #endif 00071 00072 /****************************************************************************/ 00073
1.5.6