SUMO - Simulation of Urban MObility
|
00001 /****************************************************************************/ 00007 // ------------------- 00008 /****************************************************************************/ 00009 // SUMO, Simulation of Urban MObility; see http://sumo.sourceforge.net/ 00010 // Copyright (C) 2001-2012 DLR (http://www.dlr.de/) and contributors 00011 /****************************************************************************/ 00012 // 00013 // This file is part of SUMO. 00014 // SUMO is free software: you can redistribute it and/or modify 00015 // it under the terms of the GNU General Public License as published by 00016 // the Free Software Foundation, either version 3 of the License, or 00017 // (at your option) any later version. 00018 // 00019 /****************************************************************************/ 00020 #ifndef NIVissimVehTypeClass_h 00021 #define NIVissimVehTypeClass_h 00022 00023 00024 // =========================================================================== 00025 // included modules 00026 // =========================================================================== 00027 #ifdef _MSC_VER 00028 #include <windows_config.h> 00029 #else 00030 #include <config.h> 00031 #endif 00032 00033 #include <string> 00034 #include <map> 00035 #include <utils/common/RGBColor.h> 00036 00037 00038 // =========================================================================== 00039 // class definitions 00040 // =========================================================================== 00044 class NIVissimVehTypeClass { 00045 public: 00046 NIVissimVehTypeClass(int id, const std::string& name, 00047 const RGBColor& color, std::vector<int>& types); 00048 ~NIVissimVehTypeClass(); 00049 static bool dictionary(int id, const std::string& name, 00050 const RGBColor& color, std::vector<int>& types); 00051 static bool dictionary(int id, NIVissimVehTypeClass* o); 00052 static NIVissimVehTypeClass* dictionary(int name); 00053 static void clearDict(); 00054 SUMOReal meanSpeed() const; 00055 private: 00056 int myID; 00057 std::string myName; 00058 RGBColor myColor; 00059 std::vector<int> myTypes; 00060 private: 00061 typedef std::map<int, NIVissimVehTypeClass*> DictType; 00062 static DictType myDict; 00063 }; 00064 00065 00066 #endif 00067 00068 /****************************************************************************/ 00069