{
private boolean paused = false;
private long unpausedSysTime = 0, lastPausedInternalTime = 0;
- private int speedPercentage = 100;
+ private double speedFactor = 1;
public void pause()
{
@Override
public long getAsLong()
{
- return paused ? lastPausedInternalTime
- : lastPausedInternalTime + ((System.currentTimeMillis() - unpausedSysTime) * speedPercentage) / 100;
+ return (long) (paused ? lastPausedInternalTime
+ : lastPausedInternalTime + (System.currentTimeMillis() - unpausedSysTime) * speedFactor);
}
- public void setSpeedPercentage(int percentage)
+ public long simulTimeDeltaToRealTimeMillis(long simulTime)
{
+ return paused ? -1 : (long) (simulTime / speedFactor);
+ }
+
+ public void setSpeedFactor(double factor)
+ {
+ if (factor <= 0)
+ throw new IllegalArgumentException("time factor can't be smaller than 1");
if (!paused)
{
pause();
unpause();
}
- this.speedPercentage = Integer.min(100, Integer.max(percentage, 1));
+ this.speedFactor = factor;
}
public boolean isPaused()
{
// always execute to keep timeline from "hanging behind" for too long
long current = tf.getAsLong();
- timeline.executeUntil(timeline.laterThan(current), current + 10);
+ timeline.executeUntil(timeline.laterThan(current), System.currentTimeMillis() + 10);
+ long nextEventTime = timeline.nextEventTime();
long sleepTime;
if (timeline.hasNext())
- sleepTime = timeline.nextEventTime() - current;
+ sleepTime = tf.simulTimeDeltaToRealTimeMillis(nextEventTime - current);
else
sleepTime = 10000;
try
{
- nextExecSimulTime.set(current + sleepTime);
+ nextExecSimulTime.set(nextEventTime);
if (sleepTime > 0)
Thread.sleep(sleepTime);
return isPaused.get();
}
- public void setSpeedPercentage(int percentage)
+ public void setSpeedFactor(double factor)
{
- tf.setSpeedPercentage(percentage);
+ tf.setSpeedFactor(factor);
}
private void waitForIsRunning(boolean expectedState)
private Button resetButton;
private Button sbseButton;
private Button pauseButton;
+ private Label speedFactorLabel;
private Slider simSpeedSlider;
private Composite canvasParent;
private LogicUICanvas canvas;
// initialize executer
exec = new LogicExecuter(machine.getTimeline());
+ updateSpeedFactor();
+ updatePausedState();
exec.startLiveExecution();
} else
{
private void addSimulationControlWidgets(Composite parent)
{
Composite c = new Composite(parent, SWT.NONE);
+ c.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, false));
c.setLayout(new GridLayout(7, false));
resetButton = new Button(c, SWT.PUSH);
pauseButton.setSelection(true);
setPauseText(pauseButton, false);
- pauseButton.addListener(SWT.Selection, e ->
- {
- setPauseText(pauseButton, false);
- if (pauseButton.getSelection())
- {
- exec.unpauseLiveExecution();
- } else
- {
- exec.pauseLiveExecution();
- }
- });
+ pauseButton.addListener(SWT.Selection, e -> updatePausedState());
pauseButton.addMouseTrackListener(new MouseTrackListener()
{
@Override
}
});
- Label speedLabel = new Label(c, SWT.NONE);
- speedLabel.setText("Simulation Speed: ");
+ new Label(c, SWT.NONE).setText("Simulation Speed: ");
simSpeedSlider = new Slider(c, SWT.NONE);
- simSpeedSlider.setMinimum(1);
- simSpeedSlider.setMaximum(100 + simSpeedSlider.getThumb());
+ simSpeedSlider.setMinimum(0);
+ simSpeedSlider.setMaximum(50 + simSpeedSlider.getThumb());
simSpeedSlider.setIncrement(1);
+ simSpeedSlider.setSelection(0);
- Label speedPercentageLabel = new Label(c, SWT.NONE);
- speedPercentageLabel.setText("100%");
+ speedFactorLabel = new Label(c, SWT.NONE);
+ speedFactorLabel.setLayoutData(new GridData(SWT.FILL, SWT.FILL, true, true));
- simSpeedSlider.addListener(SWT.Selection, e ->
- {
- int selection = simSpeedSlider.getSelection();
- speedPercentageLabel.setText(selection + "%");
+ simSpeedSlider.addListener(SWT.Selection, e -> updateSpeedFactor());
+ updateSpeedFactor();
- exec.setSpeedPercentage(simSpeedSlider.getSelection());
- });
- simSpeedSlider.setSelection(100);
+ c.layout();
+ }
- c.setLayoutData(new GridData(GridData.GRAB_HORIZONTAL | GridData.FILL_HORIZONTAL));
- c.pack();
+ private void updatePausedState()
+ {
+ setPauseText(pauseButton, false);
+ if (exec != null)
+ if (pauseButton.getSelection())
+ exec.unpauseLiveExecution();
+ else
+ exec.pauseLiveExecution();
+ }
+
+ private void updateSpeedFactor()
+ {
+ double factor = Math.pow(1.32, simSpeedSlider.getSelection() - 50);
+ speedFactorLabel.setText(String.format("%f", factor));
+ if (exec != null)
+ exec.setSpeedFactor(factor);
}
private void addInstructionPreviewControlWidgets(Composite parent)