SUMO - Simulation of Urban MObility
NIVissimBoundedClusterObject.h
Go to the documentation of this file.
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 
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Friends Defines