|
|
|
|
@ -20,11 +20,9 @@ import seng302.VisualiserInput;
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
import java.net.Socket;
|
|
|
|
|
import java.net.URL;
|
|
|
|
|
import java.time.Duration;
|
|
|
|
|
import java.time.Period;
|
|
|
|
|
import java.time.ZonedDateTime;
|
|
|
|
|
import java.text.DateFormat;
|
|
|
|
|
import java.text.SimpleDateFormat;
|
|
|
|
|
import java.time.format.DateTimeFormatter;
|
|
|
|
|
import java.time.temporal.ChronoUnit;
|
|
|
|
|
import java.util.*;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
@ -42,15 +40,15 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
@FXML private TableColumn<Boat, String> boatCodeColumn;
|
|
|
|
|
@FXML private Label timeZoneTime;
|
|
|
|
|
@FXML private Label timer;
|
|
|
|
|
|
|
|
|
|
private ZonedDateTime startingTime;
|
|
|
|
|
@FXML private Label raceStatusLabel;
|
|
|
|
|
@FXML private int PRERACE_TIME = 10;
|
|
|
|
|
|
|
|
|
|
//@FXML Button fifteenMinButton;
|
|
|
|
|
|
|
|
|
|
private RaceClock raceClock;
|
|
|
|
|
|
|
|
|
|
private StreamedCourse raceData;
|
|
|
|
|
private long timeLeft = 1;
|
|
|
|
|
private int raceStat;
|
|
|
|
|
|
|
|
|
|
private VisualiserInput visualiserInput;
|
|
|
|
|
@ -60,9 +58,15 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
*/
|
|
|
|
|
public void startRaceNoScaling() {
|
|
|
|
|
//startRace(1);
|
|
|
|
|
while(visualiserInput.getRaceStatus() == null);
|
|
|
|
|
countdownTimer();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void startRace(int raceScale){
|
|
|
|
|
//fifteenMinButton.setDisable(true);
|
|
|
|
|
//countdownTimer(raceScale);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void initialize(URL location, ResourceBundle resources){
|
|
|
|
|
raceData = new StreamedCourse();
|
|
|
|
|
@ -95,17 +99,19 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Countdown timer until race starts. Use PRERACE_TIME to set countdown duration.
|
|
|
|
|
* Countdown timer until race starts.
|
|
|
|
|
*/
|
|
|
|
|
protected void countdownTimer() {
|
|
|
|
|
new AnimationTimer() {
|
|
|
|
|
long currentTime = System.currentTimeMillis();
|
|
|
|
|
long startTime = currentTime + PRERACE_TIME;
|
|
|
|
|
DateFormat timerFormat = new SimpleDateFormat("'Race Clock:' -HH:mm:ss");
|
|
|
|
|
@Override
|
|
|
|
|
public void handle(long arg0) {
|
|
|
|
|
ZonedDateTime currentTime = raceClock.getTime();
|
|
|
|
|
//race about to start
|
|
|
|
|
timeLeft = startTime - currentTime;
|
|
|
|
|
raceStat = visualiserInput.getRaceStatus().getRaceStatus();
|
|
|
|
|
raceStatusLabel.setText("Race Status: " + visualiserInput.getRaceStatus().getRaceStatus());
|
|
|
|
|
if (raceStat == 2 || raceStat == 3) {
|
|
|
|
|
if (raceStat==2 || raceStat == 3) {
|
|
|
|
|
updateTime("Race is starting...");
|
|
|
|
|
stop();
|
|
|
|
|
parent.beginRace(visualiserInput);
|
|
|
|
|
@ -113,9 +119,9 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
start.setVisible(false);
|
|
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
long seconds = startingTime.toLocalDateTime().until(currentTime.toLocalDateTime(), ChronoUnit.SECONDS);
|
|
|
|
|
updateTime(String.format("Race starts in: %d:%02d:%02d", seconds / 3600, (seconds % 3600) / 60, (seconds % 60)));
|
|
|
|
|
updateTime(timerFormat.format(currentTime));
|
|
|
|
|
}
|
|
|
|
|
currentTime = System.currentTimeMillis();
|
|
|
|
|
}
|
|
|
|
|
}.start();
|
|
|
|
|
}
|
|
|
|
|
@ -136,8 +142,7 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
String dateFormat = "'Starting time:' HH:mm dd/MM/YYYY";
|
|
|
|
|
Platform.runLater(()-> {
|
|
|
|
|
long utcTime = visualiserInput.getRaceStatus().getExpectedStartTime();
|
|
|
|
|
startingTime = raceClock.getLocalTime(utcTime);
|
|
|
|
|
raceStartLabel.setText(DateTimeFormatter.ofPattern(dateFormat).format(startingTime));
|
|
|
|
|
raceStartLabel.setText(DateTimeFormatter.ofPattern(dateFormat).format(raceClock.getLocalTime(utcTime)));
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@ -158,11 +163,10 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
}
|
|
|
|
|
if (((StreamedCourse) o).hasReadCourse()) {
|
|
|
|
|
Platform.runLater(() -> {
|
|
|
|
|
setRaceClock();
|
|
|
|
|
while(visualiserInput.getRaceStatus() == null);
|
|
|
|
|
setRaceClock();
|
|
|
|
|
setStartingTime();
|
|
|
|
|
setCurrentTime();
|
|
|
|
|
startRaceNoScaling();
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
@ -177,6 +181,7 @@ public class StartController extends Controller implements Observer {
|
|
|
|
|
try {
|
|
|
|
|
visualiserInput = new VisualiserInput(socket, raceData);
|
|
|
|
|
new Thread(visualiserInput).start();
|
|
|
|
|
startRaceNoScaling();
|
|
|
|
|
} catch (IOException e) {
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
}
|
|
|
|
|
|