SUMO - Simulation of Urban MObility
|
00001 /****************************************************************************/ 00007 // Exporter writing networks using the openDRIVE format 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 NWWriter_OpenDrive_h 00021 #define NWWriter_OpenDrive_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 <utils/common/StringBijection.h> 00034 00035 00036 // =========================================================================== 00037 // class declarations 00038 // =========================================================================== 00039 class NBNetBuilder; 00040 class OptionsCont; 00041 class PositionVector; 00042 class OutputDevice; 00043 00044 00045 // =========================================================================== 00046 // class definitions 00047 // =========================================================================== 00053 class NWWriter_OpenDrive { 00054 public: 00060 static void writeNetwork(const OptionsCont& oc, NBNetBuilder& nb); 00061 00062 protected: 00063 static void writePlanView(const PositionVector& shape, OutputDevice& device); 00064 static void writeEmptyCenterLane(OutputDevice& device); 00065 static int getID(const std::string& origID, StringBijection<int> &map, int& lastID); 00066 00067 }; 00068 00069 00070 #endif 00071 00072 /****************************************************************************/ 00073