Line data Source code
1 : /****************************************************************************/
2 : // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 : // Copyright (C) 2002-2024 German Aerospace Center (DLR) and others.
4 : // This program and the accompanying materials are made available under the
5 : // terms of the Eclipse Public License 2.0 which is available at
6 : // https://www.eclipse.org/legal/epl-2.0/
7 : // This Source Code may also be made available under the following Secondary
8 : // Licenses when the conditions for such availability set forth in the Eclipse
9 : // Public License 2.0 are satisfied: GNU General Public License, version 2
10 : // or later which is available at
11 : // https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12 : // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13 : /****************************************************************************/
14 : /// @file NIVissimDisturbance.h
15 : /// @author Daniel Krajzewicz
16 : /// @author Michael Behrisch
17 : /// @date Sept 2002
18 : ///
19 : // -------------------
20 : /****************************************************************************/
21 : #pragma once
22 : #include <config.h>
23 :
24 : #include <map>
25 : #include <string>
26 : #include <utils/geom/AbstractPoly.h>
27 : #include <netbuild/NBConnection.h>
28 : #include "NIVissimExtendedEdgePoint.h"
29 : #include "NIVissimBoundedClusterObject.h"
30 : #include "NIVissimNodeParticipatingEdgeVector.h"
31 :
32 :
33 : // ===========================================================================
34 : // class declarations
35 : // ===========================================================================
36 : class NBNode;
37 : class NBEdge;
38 : class NBDistrictCont;
39 :
40 : class NIVissimDisturbance
41 : : public NIVissimBoundedClusterObject {
42 : public:
43 : NIVissimDisturbance(int id, const std::string& name,
44 : const NIVissimExtendedEdgePoint& edge,
45 : const NIVissimExtendedEdgePoint& by);
46 : virtual ~NIVissimDisturbance();
47 : void computeBounding();
48 : bool addToNode(NBNode* node, NBDistrictCont& dc,
49 : NBNodeCont& nc, NBEdgeCont& ec);
50 : int getEdgeID() const {
51 4018 : return myEdge.getEdgeID();
52 : }
53 : int getDisturbanceID() const {
54 4018 : return myDisturbance.getEdgeID();
55 : }
56 : NBConnection getConnection(NBNode* node, int aedgeid);
57 :
58 : public:
59 : static bool dictionary(const std::string& name,
60 : const NIVissimExtendedEdgePoint& edge,
61 : const NIVissimExtendedEdgePoint& by);
62 : static bool dictionary(int id, NIVissimDisturbance* o);
63 : static NIVissimDisturbance* dictionary(int id);
64 : static std::vector<int> getWithin(const AbstractPoly& poly);
65 : static void clearDict();
66 : static void dict_SetDisturbances();
67 : static void reportRefused();
68 :
69 : private:
70 : int myID;
71 : int myNode;
72 : std::string myName;
73 : NIVissimExtendedEdgePoint myEdge;
74 : NIVissimExtendedEdgePoint myDisturbance;
75 :
76 : typedef std::map<int, NIVissimDisturbance*> DictType;
77 : static DictType myDict;
78 : static int myRunningID;
79 : static int refusedProhibits;
80 : };
|