package org.opentrafficsim.demo.geometry; import java.awt.Dimension; import java.awt.geom.Rectangle2D; import java.rmi.RemoteException; import javax.naming.NamingException; 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.simulators.SimulatorInterface; import nl.tudelft.simulation.event.Event; import org.opentrafficsim.core.dsol.OTSDEVSAnimator; import org.opentrafficsim.core.dsol.OTSModelInterface; import org.opentrafficsim.core.dsol.OTSReplication; import org.opentrafficsim.core.dsol.OTSSimTimeDouble; import org.opentrafficsim.core.unit.TimeUnit; import org.opentrafficsim.core.value.vdouble.scalar.DoubleScalar; /** *

* Copyright (c) 2013-2015 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: pknoppers * $, initial version Oct 16, 2014
* @author Alexander Verbraeck */ public class TestGeometry extends DSOLApplication { /** */ private static final long serialVersionUID = 1L; /** * @param title t * @param panel p */ public TestGeometry(final String title, final DSOLPanel, DoubleScalar.Rel, OTSSimTimeDouble> 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 RemoteException, SimRuntimeException, NamingException { OTSModelInterface model = new TestModel(); OTSDEVSAnimator simulator = new OTSDEVSAnimator(); OTSReplication replication = new OTSReplication("rep1", new OTSSimTimeDouble(new DoubleScalar.Abs(0.0, TimeUnit.SECOND)), new DoubleScalar.Rel(0.0, TimeUnit.SECOND), new DoubleScalar.Rel(1800.0, TimeUnit.SECOND), model); simulator.initialize(replication, ReplicationMode.TERMINATING); DSOLPanel, DoubleScalar.Rel, OTSSimTimeDouble> panel = new DSOLPanel, DoubleScalar.Rel, OTSSimTimeDouble>(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); } }