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 NIVissimBoundedClusterObject_h 00021 #define NIVissimBoundedClusterObject_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 <set> 00034 #include <string> 00035 00036 00037 // =========================================================================== 00038 // class declarations 00039 // =========================================================================== 00040 class Boundary; 00041 00042 // =========================================================================== 00043 // class definitions 00044 // =========================================================================== 00048 class NIVissimBoundedClusterObject { 00049 public: 00050 NIVissimBoundedClusterObject(); 00051 virtual ~NIVissimBoundedClusterObject(); 00052 virtual void computeBounding() = 0; 00053 bool crosses(const AbstractPoly& poly, SUMOReal offset = 0) const; 00054 void inCluster(int id); 00055 bool clustered() const; 00056 const Boundary& getBoundary() const; 00057 public: 00058 static void closeLoading(); 00059 protected: 00060 typedef std::set<NIVissimBoundedClusterObject*> ContType; 00061 static ContType myDict; 00062 Boundary* myBoundary; 00063 int myClusterID; 00064 }; 00065 00066 00067 #endif 00068 00069 /****************************************************************************/ 00070