package org.opentrafficsim.imb.kpi; import org.opentrafficsim.kpi.interfaces.NodeDataInterface; import nl.tudelft.simulation.language.d3.CartesianPoint; /** *

* Copyright (c) 2013-2019 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
* BSD-style license. See OpenTrafficSim License. *

* @version $Revision$, $LastChangedDate$, by $Author$, initial version 13 okt. 2016
* @author Alexander Verbraeck * @author Peter Knoppers * @author Wouter Schakel */ public class NodeData implements NodeDataInterface { /** Node name. */ private final String nodeName; /** position. */ private final CartesianPoint position; /** * @param nodeName String; name of the node * @param position CartesianPoint; position of the node */ public NodeData(final String nodeName, final CartesianPoint position) { this.nodeName = nodeName; this.position = position; } /** * @return nodeName */ public final String getNodeName() { return this.nodeName; } /** * @return position */ public final CartesianPoint getPosition() { return this.position; } /** {@inheritDoc} */ @Override public String getId() { return getNodeName(); } /** {@inheritDoc} */ @Override public int hashCode() { final int prime = 31; int result = 1; result = prime * result + ((this.nodeName == null) ? 0 : this.nodeName.hashCode()); return result; } /** {@inheritDoc} */ @Override public boolean equals(Object obj) { if (this == obj) return true; if (obj == null) return false; if (getClass() != obj.getClass()) return false; NodeData other = (NodeData) obj; if (this.nodeName == null) { if (other.nodeName != null) return false; } else if (!this.nodeName.equals(other.nodeName)) return false; return true; } /** {@inheritDoc} */ @Override public String toString() { return "NodeData [nodeName=" + this.nodeName + ", position=" + this.position + "]"; } }