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