Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
eclipse
GitHub Repository: eclipse/sumo
Path: blob/main/src/netimport/vissim/tempstructs/NIVissimNodeDef_Edges.h
169684 views
1
/****************************************************************************/
2
// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3
// Copyright (C) 2001-2025 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 NIVissimNodeDef_Edges.h
15
/// @author Daniel Krajzewicz
16
/// @date Sept 2002
17
///
18
// -------------------
19
/****************************************************************************/
20
#pragma once
21
#include <config.h>
22
23
24
#include <string>
25
#include <map>
26
#include "NIVissimNodeParticipatingEdgeVector.h"
27
#include "NIVissimExtendedEdgePoint.h"
28
#include "NIVissimNodeDef.h"
29
30
class NIVissimNodeDef_Edges :
31
public NIVissimNodeDef {
32
public:
33
NIVissimNodeDef_Edges(int id, const std::string& name,
34
const NIVissimNodeParticipatingEdgeVector& edges);
35
virtual ~NIVissimNodeDef_Edges();
36
static bool dictionary(int id, const std::string& name,
37
const NIVissimNodeParticipatingEdgeVector& edges);
38
// virtual void computeBounding();
39
// virtual void searchAndSetConnections();
40
virtual double getEdgePosition(int edgeid) const;
41
42
/**
43
*
44
*/
45
class id_matches {
46
public:
47
explicit id_matches(int id) : myEdgeID(id) { }
48
bool operator()(NIVissimNodeParticipatingEdge* e) {
49
return e->getID() == myEdgeID;
50
}
51
private:
52
int myEdgeID;
53
};
54
55
class lying_within_match {
56
public:
57
explicit lying_within_match(NIVissimNodeParticipatingEdge* e) : myEdge(e) { }
58
bool operator()(NIVissimExtendedEdgePoint* e) {
59
return e->getEdgeID() == myEdge->getID() &&
60
myEdge->positionLiesWithin(e->getPosition());
61
}
62
private:
63
NIVissimNodeParticipatingEdge* myEdge;
64
};
65
66
protected:
67
NIVissimNodeParticipatingEdgeVector myEdges;
68
};
69
70