Eclipse SUMO - Simulation of Urban MObility
NIVissimNodeDef_Edges.h
Go to the documentation of this file.
1 /****************************************************************************/
2 // Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3 // Copyright (C) 2001-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 /****************************************************************************/
18 // -------------------
19 /****************************************************************************/
20 #pragma once
21 #include <config.h>
22 
23 
24 #include <string>
25 #include <map>
28 #include "NIVissimNodeDef.h"
29 
31  public NIVissimNodeDef {
32 public:
33  NIVissimNodeDef_Edges(int id, const std::string& name,
35  virtual ~NIVissimNodeDef_Edges();
36  static bool dictionary(int id, const std::string& name,
38 // virtual void computeBounding();
39 // virtual void searchAndSetConnections();
40  virtual double getEdgePosition(int edgeid) const;
41 
45  class id_matches {
46  public:
47  explicit id_matches(int id) : myEdgeID(id) { }
49  return e->getID() == myEdgeID;
50  }
51  private:
52  int myEdgeID;
53  };
54 
56  public:
59  return e->getEdgeID() == myEdge->getID() &&
61  }
62  private:
64  };
65 
66 protected:
68 };
std::vector< NIVissimNodeParticipatingEdge * > NIVissimNodeParticipatingEdgeVector
bool operator()(NIVissimNodeParticipatingEdge *e)
lying_within_match(NIVissimNodeParticipatingEdge *e)
NIVissimNodeParticipatingEdge * myEdge
bool operator()(NIVissimExtendedEdgePoint *e)
NIVissimNodeParticipatingEdgeVector myEdges
NIVissimNodeDef_Edges(int id, const std::string &name, const NIVissimNodeParticipatingEdgeVector &edges)
virtual double getEdgePosition(int edgeid) const
static bool dictionary(int id, const std::string &name, const NIVissimNodeParticipatingEdgeVector &edges)