|
|
|
@ -15,11 +15,13 @@ import javafx.scene.control.Label;
|
|
|
|
import javafx.scene.image.ImageView;
|
|
|
|
import javafx.scene.image.ImageView;
|
|
|
|
import javafx.scene.layout.AnchorPane;
|
|
|
|
import javafx.scene.layout.AnchorPane;
|
|
|
|
import javafx.scene.layout.GridPane;
|
|
|
|
import javafx.scene.layout.GridPane;
|
|
|
|
|
|
|
|
import javafx.scene.paint.Color;
|
|
|
|
import javafx.scene.paint.PhongMaterial;
|
|
|
|
import javafx.scene.paint.PhongMaterial;
|
|
|
|
import javafx.scene.shape.MeshView;
|
|
|
|
import javafx.scene.shape.MeshView;
|
|
|
|
import mock.app.Event;
|
|
|
|
import mock.app.Event;
|
|
|
|
import network.Messages.Enums.RaceStatusEnum;
|
|
|
|
import network.Messages.Enums.RaceStatusEnum;
|
|
|
|
import network.Messages.Enums.RequestToJoinEnum;
|
|
|
|
import network.Messages.Enums.RequestToJoinEnum;
|
|
|
|
|
|
|
|
import shared.model.Boat;
|
|
|
|
import visualiser.app.App;
|
|
|
|
import visualiser.app.App;
|
|
|
|
import visualiser.gameController.ControllerClient;
|
|
|
|
import visualiser.gameController.ControllerClient;
|
|
|
|
import visualiser.layout.SeaSurface;
|
|
|
|
import visualiser.layout.SeaSurface;
|
|
|
|
@ -125,14 +127,22 @@ public class InGameLobbyController extends Controller {
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void onChanged(Change change) {
|
|
|
|
public void onChanged(Change change) {
|
|
|
|
Platform.runLater(
|
|
|
|
Platform.runLater(() -> {
|
|
|
|
() -> {
|
|
|
|
while (change.next()) {
|
|
|
|
while (change.next()){
|
|
|
|
if (change.wasAdded() || change.wasRemoved() || change.wasUpdated()) {
|
|
|
|
if (change.wasAdded() || change.wasRemoved() || change.wasUpdated()){
|
|
|
|
populateLobby();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public void populateLobby() {
|
|
|
|
|
|
|
|
|
|
|
|
try{
|
|
|
|
try{
|
|
|
|
resetLobby();
|
|
|
|
resetLobby();
|
|
|
|
int count = 0;
|
|
|
|
int count = 0;
|
|
|
|
int row = 0;
|
|
|
|
int row = 0;
|
|
|
|
|
|
|
|
|
|
|
|
for (VisualiserBoat boat :visualiserRaceEvent.getVisualiserRaceState().getBoats()) {
|
|
|
|
for (VisualiserBoat boat :visualiserRaceEvent.getVisualiserRaceState().getBoats()) {
|
|
|
|
View3D playerBoatToSet = new View3D();
|
|
|
|
View3D playerBoatToSet = new View3D();
|
|
|
|
playerBoatToSet.setItems(subjects);
|
|
|
|
playerBoatToSet.setItems(subjects);
|
|
|
|
@ -174,12 +184,10 @@ public class InGameLobbyController extends Controller {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch(ConcurrentModificationException e){
|
|
|
|
catch(ConcurrentModificationException e){
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
/*
|
|
|
|
private void populatePlayers(ListChangeListener.Change change){
|
|
|
|
private void populatePlayers(ListChangeListener.Change change){
|
|
|
|
@ -192,7 +200,6 @@ public class InGameLobbyController extends Controller {
|
|
|
|
//Initialises the race clock.
|
|
|
|
//Initialises the race clock.
|
|
|
|
initialiseRaceClock(this.visualiserRaceEvent.getVisualiserRaceState());
|
|
|
|
initialiseRaceClock(this.visualiserRaceEvent.getVisualiserRaceState());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//Starts the race countdown timer.
|
|
|
|
//Starts the race countdown timer.
|
|
|
|
countdownTimer();
|
|
|
|
countdownTimer();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
@ -228,7 +235,6 @@ public class InGameLobbyController extends Controller {
|
|
|
|
new AnimationTimer() {
|
|
|
|
new AnimationTimer() {
|
|
|
|
@Override
|
|
|
|
@Override
|
|
|
|
public void handle(long arg0) {
|
|
|
|
public void handle(long arg0) {
|
|
|
|
|
|
|
|
|
|
|
|
//Get the current race status.
|
|
|
|
//Get the current race status.
|
|
|
|
RaceStatusEnum raceStatus = visualiserRaceEvent.getVisualiserRaceState().getRaceStatusEnum();
|
|
|
|
RaceStatusEnum raceStatus = visualiserRaceEvent.getVisualiserRaceState().getRaceStatusEnum();
|
|
|
|
|
|
|
|
|
|
|
|
|