1 /**
2 *
3 */
4 package org.opentrafficsim.water;
5
6 import java.io.Serializable;
7
8 import javax.vecmath.Point3d;
9
10 import org.opentrafficsim.core.geometry.OTSPoint3D;
11
12 import com.vividsolutions.jts.geom.Coordinate;
13
14 import nl.tudelft.simulation.dsol.animation.Locatable;
15 import nl.tudelft.simulation.language.d3.DirectedPoint;
16
17 /**
18 * A located object can report its location.
19 * <p>
20 * Copyright (c) 2013-2019 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved. <br>
21 * BSD-style license. See <a href="http://opentrafficsim.org/docs/current/license.html">OpenTrafficSim License</a>.
22 * </p>
23 * <p>
24 * Based on software from the IDVV project, which is Copyright (c) 2013 Rijkswaterstaat - Dienst Water, Verkeer en Leefomgeving
25 * and licensed without restrictions to Delft University of Technology, including the right to sub-license sources and derived
26 * products to third parties.
27 * </p>
28 * $LastChangedDate: 2015-07-24 02:58:59 +0200 (Fri, 24 Jul 2015) $, @version $Revision: 1147 $, by $Author: averbraeck $,
29 * initial version Nov 6, 2016 <br>
30 * @author <a href="http://www.tbm.tudelft.nl/averbraeck">Alexander Verbraeck</a>
31 */
32 public interface Located extends Locatable, Serializable
33 {
34 /** @return the directed point */
35 @Override
36 DirectedPoint getLocation();
37
38 /** @return the GIS coordinate */
39 default Coordinate getCoordinate()
40 {
41 return new Coordinate(getLocation().x, getLocation().y);
42 }
43
44 /** @return the coordinate for DSOL 2D or 3D */
45 default Point3d getPoint3d()
46 {
47 return new Point3d(getLocation().x, getLocation().y, getLocation().z);
48 }
49
50 /** @return the coordinate for DSOL 2D or 3D */
51 default OTSPoint3D getOTSPoint3D()
52 {
53 return new OTSPoint3D(getLocation());
54 }
55
56 }