package org.opentrafficsim.demo.geometry; import java.awt.Dimension; import java.awt.geom.Rectangle2D; import java.rmi.RemoteException; import javax.naming.NamingException; import org.djunits.unit.UNITS; import org.djunits.value.vdouble.scalar.Duration; import org.djunits.value.vdouble.scalar.Time; import org.opentrafficsim.core.dsol.OTSModelInterface; import org.opentrafficsim.core.dsol.OTSReplication; import nl.tudelft.simulation.dsol.SimRuntimeException; import nl.tudelft.simulation.dsol.animation.D2.AnimationPanel; import nl.tudelft.simulation.dsol.experiment.ReplicationMode; import nl.tudelft.simulation.dsol.gui.swing.DSOLApplication; import nl.tudelft.simulation.dsol.gui.swing.DSOLPanel; import nl.tudelft.simulation.dsol.simtime.SimTimeDoubleUnit; import nl.tudelft.simulation.dsol.simulators.DEVSAnimator; import nl.tudelft.simulation.dsol.simulators.SimulatorInterface; import nl.tudelft.simulation.event.Event; /** *

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

* $LastChangedDate$, @version $Revision$, by $Author$, * initial version Oct 16, 2014
* @author Alexander Verbraeck */ public class TestGeometry extends DSOLApplication implements UNITS { /** */ private static final long serialVersionUID = 1L; /** * @param title t * @param panel p */ public TestGeometry(final String title, final DSOLPanel panel) { super(title, panel); } /** * @param args args * @throws RemoteException if error * @throws SimRuntimeException if error * @throws NamingException if error */ public static void main(final String[] args) throws SimRuntimeException, NamingException, RemoteException { OTSModelInterface model = new TestModel(); DEVSAnimator.TimeDoubleUnit simulator = new DEVSAnimator.TimeDoubleUnit(); OTSReplication replication = new OTSReplication("rep1", new SimTimeDoubleUnit(Time.ZERO), Duration.ZERO, new Duration(1800.0, SECOND), model); simulator.initialize(replication, ReplicationMode.TERMINATING); DSOLPanel panel = new DSOLPanel(model, simulator); Rectangle2D extent = new Rectangle2D.Double(-50, -50, 300, 100); Dimension size = new Dimension(1024, 768); AnimationPanel animationPanel = new AnimationPanel(extent, size, simulator); panel.getTabbedPane().addTab(0, "animation", animationPanel); // tell the animation panel to update its statistics animationPanel.notify(new Event(SimulatorInterface.START_REPLICATION_EVENT, simulator, null)); new TestGeometry("TestGeometry", panel); } }