Eclipse SUMO - Simulation of Urban MObility
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
GNEChargingStation.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-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/****************************************************************************/
18// A class for visualizing chargingStation geometry (adapted from GUILaneWrapper)
19/****************************************************************************/
20#pragma once
21#include <config.h>
22
23#include "GNEStoppingPlace.h"
24
25// ===========================================================================
26// class definitions
27// ===========================================================================
28
30
31public:
34
53 GNEChargingStation(const std::string& id, GNENet* net, const std::string& filename, GNELane* lane, const double startPos, const double endPos,
54 const std::string& name, double chargingPower, double efficiency, bool chargeInTransit, SUMOTime chargeDelay,
55 const std::string& chargeType, const SUMOTime waitingTime, const std::string& parkingAreaID, bool friendlyPosition, const Parameterised::Map& parameters);
56
59
63 void writeAdditional(OutputDevice& device) const;
64
67
69 void updateGeometry();
70
72
75
80 void drawGL(const GUIVisualizationSettings& s) const;
81
83
86
87 /* @brief method for getting the Attribute of an XML key
88 * @param[in] key The attribute key
89 * @return string with the value associated to key
90 */
91 std::string getAttribute(SumoXMLAttr key) const;
92
93 /* @brief method for getting the Attribute of an XML key in double format (to avoid unnecessary parse<double>(...) for certain attributes)
94 * @param[in] key The attribute key
95 * @return double with the value associated to key
96 */
97 double getAttributeDouble(SumoXMLAttr key) const;
98
99 /* @brief method for setting the attribute and letting the object perform additional changes
100 * @param[in] key The attribute key
101 * @param[in] value The new value
102 * @param[in] undoList The undoList on which to register changes
103 */
104 void setAttribute(SumoXMLAttr key, const std::string& value, GNEUndoList* undoList);
105
106 /* @brief method for checking if the key and their correspond attribute are valids
107 * @param[in] key The attribute key
108 * @param[in] value The value associated to key key
109 * @return true if the value is valid, false in other case
110 */
111 bool isValid(SumoXMLAttr key, const std::string& value);
112
114
115protected:
117 double myChargingPower = 0;
118
120 double myEfficiency = 0;
121
123 bool myChargeInTransit = false;
124
127
129 std::string myChargeType = "normal";
130
133
135 std::string myParkingAreaID;
136
137private:
139 void setAttribute(SumoXMLAttr key, const std::string& value);
140
143
146};
long long int SUMOTime
Definition GUI.h:36
SumoXMLAttr
Numbers representing SUMO-XML - attributes.
std::string getAttribute(SumoXMLAttr key) const
GNEChargingStation(const GNEChargingStation &)=delete
Invalidated copy constructor.
std::string myChargeType
charging type
~GNEChargingStation()
Destructor.
std::string myParkingAreaID
parking area ID
bool isValid(SumoXMLAttr key, const std::string &value)
method for checking if the key and their correspondent attribute are valids
void drawGL(const GUIVisualizationSettings &s) const
Draws the object.
void setAttribute(SumoXMLAttr key, const std::string &value, GNEUndoList *undoList)
method for setting the attribute and letting the object perform additional changes
SUMOTime myChargeDelay
delay in the starting of charge
GNEChargingStation & operator=(const GNEChargingStation &)=delete
Invalidated assignment operator.
bool myChargeInTransit
enable or disable charge in transit
double myChargingPower
Charging power pro timestep.
void writeAdditional(OutputDevice &device) const
write additional element into a xml file
double myEfficiency
efficiency of the charge
void updateGeometry()
update pre-computed geometry information
SUMOTime myWaitingTime
waiting time before start charging
double getAttributeDouble(SumoXMLAttr key) const
This lane is powered by an underlying GNEEdge and basically knows how to draw itself.
Definition GNELane.h:46
A NBNetBuilder extended by visualisation and editing capabilities.
Definition GNENet.h:42
Stores the information about how to visualize structures.
Static storage of an output device and its base (abstract) implementation.
std::map< std::string, std::string > Map
parameters map