Develope game branch #33
|
@ -7,40 +7,65 @@ public abstract class FXController {
|
||||||
FactoryDecorator factoryDecorator;
|
FactoryDecorator factoryDecorator;
|
||||||
FileIO fileIO;
|
FileIO fileIO;
|
||||||
Pane pane;
|
Pane pane;
|
||||||
|
IsObserver listener;
|
||||||
|
|
||||||
|
public FXController(){
|
||||||
|
listener = new IsObserver() {
|
||||||
|
@Override
|
||||||
|
public void update() {
|
||||||
|
loadContent();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
public void setup(TournamentDecorator tournamentDecorator, FileIO fileIO, FactoryDecorator factoryDecorator, Pane pane){
|
public void setup(TournamentDecorator tournamentDecorator, FileIO fileIO, FactoryDecorator factoryDecorator, Pane pane){
|
||||||
this.tournamentDecorator = tournamentDecorator;
|
this.tournamentDecorator = tournamentDecorator;
|
||||||
this.fileIO = fileIO;
|
this.fileIO = fileIO;
|
||||||
this.factoryDecorator = factoryDecorator;
|
this.factoryDecorator = factoryDecorator;
|
||||||
this.pane = pane;
|
this.pane = pane;
|
||||||
tournamentDecorator.addListener(new IsObserver() {
|
addListener();
|
||||||
@Override
|
|
||||||
public void update() {
|
|
||||||
loadContent();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
factoryDecorator.addListener(new IsObserver() {
|
|
||||||
@Override
|
|
||||||
public void update() {
|
|
||||||
loadContent();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public abstract void loadContent();
|
public abstract void loadContent();
|
||||||
|
|
||||||
|
protected void setTournamentDecorator(TournamentDecorator tournamentDecorator) {
|
||||||
|
this.tournamentDecorator = tournamentDecorator;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addListener(){
|
||||||
|
tournamentDecorator.addListener(listener);
|
||||||
|
factoryDecorator.addListener(listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void removeListener(){
|
||||||
|
tournamentDecorator.removeListener(listener);
|
||||||
|
factoryDecorator.removeListener(listener);
|
||||||
|
}
|
||||||
|
|
||||||
protected TournamentDecorator getTournamentDecorator() {
|
protected TournamentDecorator getTournamentDecorator() {
|
||||||
return tournamentDecorator;
|
return tournamentDecorator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void setFactoryDecorator(FactoryDecorator factoryDecorator) {
|
||||||
|
this.factoryDecorator = factoryDecorator;
|
||||||
|
}
|
||||||
|
|
||||||
protected FactoryDecorator getFactoryDecorator() {
|
protected FactoryDecorator getFactoryDecorator() {
|
||||||
return factoryDecorator;
|
return factoryDecorator;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void setFileIO(FileIO fileIO) {
|
||||||
|
this.fileIO = fileIO;
|
||||||
|
}
|
||||||
|
|
||||||
protected FileIO getFileIO() {
|
protected FileIO getFileIO() {
|
||||||
return fileIO;
|
return fileIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void setPane(Pane pane) {
|
||||||
|
this.pane = pane;
|
||||||
|
}
|
||||||
|
|
||||||
protected Pane getPane() {
|
protected Pane getPane() {
|
||||||
return pane;
|
return pane;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,8 +1,11 @@
|
||||||
package ch.zhaw.projekt2.turnierverwaltung;
|
package ch.zhaw.projekt2.turnierverwaltung;
|
||||||
|
|
||||||
|
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameController;
|
||||||
|
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameDecorator;
|
||||||
import ch.zhaw.projekt2.turnierverwaltung.main.tournamentList.TournamentListController;
|
import ch.zhaw.projekt2.turnierverwaltung.main.tournamentList.TournamentListController;
|
||||||
import javafx.fxml.FXMLLoader;
|
import javafx.fxml.FXMLLoader;
|
||||||
import javafx.scene.layout.BorderPane;
|
import javafx.scene.layout.BorderPane;
|
||||||
|
import javafx.scene.layout.VBox;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
|
@ -10,6 +13,7 @@ import java.net.URL;
|
||||||
public class Factory {
|
public class Factory {
|
||||||
private TournamentDecorator tournamentDecorator;
|
private TournamentDecorator tournamentDecorator;
|
||||||
private FileIO fileIO;
|
private FileIO fileIO;
|
||||||
|
//TODO save views instead of recreate them.
|
||||||
|
|
||||||
public Factory(FileIO fileIO, TournamentDecorator tournamentDecorator){
|
public Factory(FileIO fileIO, TournamentDecorator tournamentDecorator){
|
||||||
this.fileIO = fileIO;
|
this.fileIO = fileIO;
|
||||||
|
@ -54,6 +58,20 @@ public class Factory {
|
||||||
setCenterOfBorderPane(pane, getClass().getResource("gameScheduleView/GameSchedule.fxml"), factoryDecorator);
|
setCenterOfBorderPane(pane, getClass().getResource("gameScheduleView/GameSchedule.fxml"), factoryDecorator);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public GameController loadGameView(VBox box, GameDecorator gameDecorator, FactoryDecorator factoryDecorator) {
|
||||||
|
try {
|
||||||
|
FXMLLoader loader = new FXMLLoader(getClass().getResource("gameScheduleView/Game.fxml"));
|
||||||
|
box.getChildren().add(loader.load());
|
||||||
|
GameController controller = loader.getController();
|
||||||
|
controller.setup(tournamentDecorator, fileIO, factoryDecorator, box, gameDecorator);
|
||||||
|
return controller;
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
//TODO LOGGER
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
private FXController setCenterOfBorderPane(BorderPane pane, URL location, FactoryDecorator factoryDecorator) {
|
private FXController setCenterOfBorderPane(BorderPane pane, URL location, FactoryDecorator factoryDecorator) {
|
||||||
FXController controller = null;
|
FXController controller = null;
|
||||||
try {
|
try {
|
||||||
|
@ -61,7 +79,6 @@ public class Factory {
|
||||||
pane.setCenter(loader.load());
|
pane.setCenter(loader.load());
|
||||||
controller = loader.getController();
|
controller = loader.getController();
|
||||||
controller.setup(tournamentDecorator, fileIO, factoryDecorator, pane);
|
controller.setup(tournamentDecorator, fileIO, factoryDecorator, pane);
|
||||||
controller.loadContent();
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
//TODO handle and logging?
|
//TODO handle and logging?
|
||||||
|
|
|
@ -1,7 +1,14 @@
|
||||||
package ch.zhaw.projekt2.turnierverwaltung;
|
package ch.zhaw.projekt2.turnierverwaltung;
|
||||||
|
|
||||||
|
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameController;
|
||||||
|
import ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameDecorator;
|
||||||
|
import javafx.geometry.Pos;
|
||||||
|
import javafx.scene.Node;
|
||||||
import javafx.scene.layout.BorderPane;
|
import javafx.scene.layout.BorderPane;
|
||||||
|
import javafx.scene.layout.HBox;
|
||||||
import javafx.scene.layout.Pane;
|
import javafx.scene.layout.Pane;
|
||||||
|
import javafx.scene.layout.VBox;
|
||||||
|
import javafx.scene.shape.Line;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -44,8 +51,7 @@ public class FactoryDecorator implements IsObservable{
|
||||||
public void openTournament(FileIO.TournamentFile tournamentFile){
|
public void openTournament(FileIO.TournamentFile tournamentFile){
|
||||||
try {
|
try {
|
||||||
factory.setTournament(fileIO.loadTournament(tournamentFile));
|
factory.setTournament(fileIO.loadTournament(tournamentFile));
|
||||||
factory.loadGameScheduler((BorderPane) pane, this);
|
openScheduleView();
|
||||||
informListener();
|
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
} catch (ClassNotFoundException e) {
|
} catch (ClassNotFoundException e) {
|
||||||
|
@ -53,18 +59,106 @@ public class FactoryDecorator implements IsObservable{
|
||||||
} //TODO handle and logging
|
} //TODO handle and logging
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void openTournamentList() {
|
||||||
|
factory.loadTournamentList((BorderPane) pane, this);
|
||||||
|
informListener();
|
||||||
|
}
|
||||||
|
|
||||||
public void openParticipantFormular() {
|
public void openParticipantFormular() {
|
||||||
factory.loadParticipantFormular((BorderPane) pane, this);
|
factory.loadParticipantFormular((BorderPane) pane, this);
|
||||||
|
informListener();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void openPlacesFormular() {
|
public void openPlacesFormular() {
|
||||||
factory.loadPlacesFormular((BorderPane) pane, this);
|
factory.loadPlacesFormular((BorderPane) pane, this);
|
||||||
|
informListener();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void openScheduleView() {
|
public void openScheduleView() {
|
||||||
factory.loadGameScheduler((BorderPane) pane, this);
|
factory.loadGameScheduler((BorderPane) pane, this);
|
||||||
|
informListener();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void loadGameList(HBox hBoxCenter, TournamentDecorator tournamentDecorator, boolean treeView) {
|
||||||
|
hBoxCenter.getChildren().clear();
|
||||||
|
|
||||||
|
List<List<Game>> gameList = tournamentDecorator.getTournament().getGameList();
|
||||||
|
|
||||||
|
List<GameDecorator> gameDecoratorsList = new ArrayList<>();
|
||||||
|
double gameBoxHeight = 0;
|
||||||
|
double spacingFactor = 0;
|
||||||
|
for (int i = 0; i < gameList.size(); i++) {
|
||||||
|
List<GameDecorator> newGameDecoratorsList = new ArrayList<>();
|
||||||
|
VBox vBox = new VBox();
|
||||||
|
if(treeView){
|
||||||
|
vBox.setAlignment(Pos.CENTER);
|
||||||
|
vBox.setSpacing(gameBoxHeight * spacingFactor);
|
||||||
|
} else {
|
||||||
|
vBox.setAlignment(Pos.TOP_CENTER);
|
||||||
|
}
|
||||||
|
spacingFactor = spacingFactor * 2 + 1;
|
||||||
|
for (int j = 0; j < gameList.get(i).size(); j++) {
|
||||||
|
GameDecorator gameDecorator = new GameDecorator(gameList.get(i).get(j));
|
||||||
|
newGameDecoratorsList.add(gameDecorator);
|
||||||
|
GameController gameController = openGameView(vBox,gameDecorator);
|
||||||
|
if(i>0){
|
||||||
|
gameController.addListener(gameDecoratorsList.get(j*2));
|
||||||
|
gameController.addListener(gameDecoratorsList.get(j*2+1));
|
||||||
|
} else if(gameBoxHeight == 0) {
|
||||||
|
gameBoxHeight = gameController.getGameBoxHeigth();
|
||||||
|
}
|
||||||
|
gameDecorator.addListener(new IsObserver() {
|
||||||
|
@Override
|
||||||
|
public void update() {
|
||||||
|
tournamentDecorator.saveTournament();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
gameController.loadContent();
|
||||||
|
}
|
||||||
|
hBoxCenter.getChildren().add(vBox);
|
||||||
|
if(treeView){
|
||||||
|
if(i+1 < gameList.size())
|
||||||
|
hBoxCenter.getChildren().add(drawLines(vBox, gameBoxHeight, 30));
|
||||||
|
}
|
||||||
|
gameDecoratorsList = newGameDecoratorsList;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public VBox drawLines(VBox gameVBox, double gameBoxHeight, double lineLength){
|
||||||
|
VBox completeLineVBox = new VBox();
|
||||||
|
completeLineVBox.setAlignment(Pos.CENTER_LEFT);
|
||||||
|
double lineSpacing = gameVBox.getSpacing() + gameBoxHeight - 1;
|
||||||
|
completeLineVBox.setSpacing(lineSpacing);
|
||||||
|
for(int i = 0; i < gameVBox.getChildren().size(); i+=2){
|
||||||
|
HBox lineBox = new HBox();
|
||||||
|
lineBox.setAlignment(Pos.CENTER);
|
||||||
|
|
||||||
|
//add Lines from left Game to center
|
||||||
|
VBox vBox = new VBox();
|
||||||
|
vBox.setSpacing(lineSpacing);
|
||||||
|
vBox.getChildren().add(new Line(0,0,lineLength,0));
|
||||||
|
vBox.getChildren().add(new Line(0,0,lineLength,0));
|
||||||
|
lineBox.getChildren().add(vBox);
|
||||||
|
|
||||||
|
|
||||||
|
//add vertical line
|
||||||
|
lineBox.getChildren().add(new Line(0, 0, 0, lineSpacing));
|
||||||
|
|
||||||
|
//add line to right game
|
||||||
|
lineBox.getChildren().add(new Line(0, 0, lineLength, 0));
|
||||||
|
|
||||||
|
completeLineVBox.getChildren().add(lineBox);
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
return completeLineVBox;
|
||||||
|
}
|
||||||
|
|
||||||
|
public GameController openGameView(VBox vBox, GameDecorator gameDecorator) {
|
||||||
|
return factory.loadGameView(vBox ,gameDecorator, this);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public void informListener() {
|
public void informListener() {
|
||||||
for(IsObserver observer : listener) {
|
for(IsObserver observer : listener) {
|
||||||
observer.update();
|
observer.update();
|
||||||
|
|
|
@ -81,7 +81,7 @@ public class FileIO {
|
||||||
* @throws IOException File not readable
|
* @throws IOException File not readable
|
||||||
* @throws FileNotFoundException File not found
|
* @throws FileNotFoundException File not found
|
||||||
*/
|
*/
|
||||||
public Tournament loadTournament(File tournamentFile) throws IOException, ClassNotFoundException, FileNotFoundException {
|
public synchronized Tournament loadTournament(File tournamentFile) throws IOException, ClassNotFoundException, FileNotFoundException {
|
||||||
if (tournamentFile == null) {
|
if (tournamentFile == null) {
|
||||||
logger.warning("Given tournament file is empty");
|
logger.warning("Given tournament file is empty");
|
||||||
throw new IllegalArgumentException("Tournament File is null");
|
throw new IllegalArgumentException("Tournament File is null");
|
||||||
|
@ -125,7 +125,7 @@ public class FileIO {
|
||||||
* @throws IOException File not readable
|
* @throws IOException File not readable
|
||||||
* @throws FileNotFoundException File not found
|
* @throws FileNotFoundException File not found
|
||||||
*/
|
*/
|
||||||
public void saveTournament(Tournament tournament) throws IOException, FileNotFoundException {
|
public synchronized void saveTournament(Tournament tournament) throws IOException, FileNotFoundException {
|
||||||
if (tournament == null) {
|
if (tournament == null) {
|
||||||
logger.warning("Given tournament file is empty");
|
logger.warning("Given tournament file is empty");
|
||||||
throw new IllegalArgumentException("Null tournament received");
|
throw new IllegalArgumentException("Null tournament received");
|
||||||
|
|
|
@ -3,9 +3,21 @@ package ch.zhaw.projekt2.turnierverwaltung;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
public class Game implements Serializable {
|
public class Game implements Serializable {
|
||||||
private Participant participant1, Participant2;
|
private Participant participant1, participant2;
|
||||||
private int points1, points2;
|
private int points1, points2;
|
||||||
private Place place;
|
private Place place;
|
||||||
|
private Game previousGame1, previousGame2;
|
||||||
|
|
||||||
|
|
||||||
|
public Game(Participant participant1, Participant participant2) {
|
||||||
|
this.participant1 = participant1;
|
||||||
|
this.participant2 = participant2;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Game(Game previousGame1, Game previousGame2){
|
||||||
|
this.previousGame1 = previousGame1;
|
||||||
|
this.previousGame2 = previousGame2;
|
||||||
|
}
|
||||||
|
|
||||||
public Place getLocation() {
|
public Place getLocation() {
|
||||||
return place;
|
return place;
|
||||||
|
@ -39,11 +51,35 @@ public class Game implements Serializable {
|
||||||
this.participant1 = participant1;
|
this.participant1 = participant1;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Participant getParticipant2() {
|
public void setParticipant2(Participant participant2) {
|
||||||
return Participant2;
|
this.participant2 = participant2;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setParticipant2(Participant participant2) {
|
public Participant getParticipant2() {
|
||||||
Participant2 = participant2;
|
return participant2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setPlace(Place place) {
|
||||||
|
this.place = place;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Place getPlace() {
|
||||||
|
return place;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Participant getWinner(){
|
||||||
|
if(points1 > points2){
|
||||||
|
return participant1;
|
||||||
|
} else if(points2 > points1){
|
||||||
|
return participant2;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void refreshParticipants(){
|
||||||
|
participant1 = previousGame1.getWinner();
|
||||||
|
participant2 = previousGame2.getWinner();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,23 +5,20 @@ import javafx.collections.ObservableList;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.util.ArrayList;
|
import java.util.*;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public class Tournament implements Serializable {
|
public class Tournament implements Serializable {
|
||||||
private String name;
|
private String name;
|
||||||
private Type type;
|
private Type type;
|
||||||
private List<Participant> participants;
|
private List<Participant> participants;
|
||||||
private List<Place> places;
|
private List<Place> places;
|
||||||
|
private List<List<Game>> gameList;
|
||||||
|
|
||||||
|
|
||||||
public Tournament(String name, Type type) throws InvalidNameException, InvalidTypeException {
|
public Tournament(String name, Type type) throws InvalidNameException, InvalidTypeException {
|
||||||
if(!name.matches("[\\w]{1,20}")){
|
if (!name.matches("[\\w]{1,20}")) {
|
||||||
throw new InvalidNameException("Invalid Name entered"); //TODO handle en logging.
|
throw new InvalidNameException("Invalid Name entered"); //TODO handle en logging.
|
||||||
} else if(!Arrays.asList(Type.values()).contains(type)){
|
} else if (!Arrays.asList(Type.values()).contains(type)) {
|
||||||
throw new InvalidTypeException("Invalid Type selected"); //TODO handle en logging.
|
throw new InvalidTypeException("Invalid Type selected"); //TODO handle en logging.
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -29,6 +26,7 @@ public class Tournament implements Serializable {
|
||||||
setType(type);
|
setType(type);
|
||||||
participants = new ArrayList<>();
|
participants = new ArrayList<>();
|
||||||
places = new ArrayList<>();
|
places = new ArrayList<>();
|
||||||
|
gameList = new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addParticipant(Participant newParticipant) throws ParticipantExistsException {
|
public void addParticipant(Participant newParticipant) throws ParticipantExistsException {
|
||||||
|
@ -37,7 +35,7 @@ public class Tournament implements Serializable {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removeParticipant(Participant participant) throws ParticipantNotExistsException {
|
public void removeParticipant(Participant participant) throws ParticipantNotExistsException {
|
||||||
if(!participants.contains(participant)){
|
if (!participants.contains(participant)) {
|
||||||
throw new ParticipantNotExistsException("The given Participant is not part of this Tournament");
|
throw new ParticipantNotExistsException("The given Participant is not part of this Tournament");
|
||||||
}
|
}
|
||||||
participants.remove(participant);
|
participants.remove(participant);
|
||||||
|
@ -55,7 +53,7 @@ public class Tournament implements Serializable {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removePlace(Place place) throws PlaceNotExistsException {
|
public void removePlace(Place place) throws PlaceNotExistsException {
|
||||||
if(!places.contains(place)){
|
if (!places.contains(place)) {
|
||||||
throw new PlaceNotExistsException("The given Place is not part of this Tournament");
|
throw new PlaceNotExistsException("The given Place is not part of this Tournament");
|
||||||
}
|
}
|
||||||
places.remove(place);
|
places.remove(place);
|
||||||
|
@ -67,6 +65,52 @@ public class Tournament implements Serializable {
|
||||||
return placesObservable;
|
return placesObservable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
creates a complete new GameSchedule
|
||||||
|
*/
|
||||||
|
public void createGameSchedule() throws NumberOfParticipantInvalidException {
|
||||||
|
gameList = new ArrayList<>();
|
||||||
|
if (type == Type.KO) {
|
||||||
|
if (numberOfParticipantValid()) {
|
||||||
|
calcGameSchedule();
|
||||||
|
//TODO Logging
|
||||||
|
} else {
|
||||||
|
throw new NumberOfParticipantInvalidException("Can not Create Game Schedule for KO Modus");
|
||||||
|
//TODO Logging
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
} else {
|
||||||
|
//TODO for Type Group
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean numberOfParticipantValid() {
|
||||||
|
double res = Math.log(participants.size()) / Math.log(2);
|
||||||
|
return (res * 10) % 10 == 0 && participants.size() >=4;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void calcGameSchedule() {
|
||||||
|
Collections.shuffle(participants);
|
||||||
|
|
||||||
|
for (int i = 0; i < (Math.log(participants.size()) / Math.log(2)); i++) {
|
||||||
|
List<Game> gameRound = new ArrayList<>();
|
||||||
|
if (i == 0) {
|
||||||
|
for (int j = 0; j < participants.size() - 1; j += 2) {
|
||||||
|
gameRound.add(new Game(participants.get(j), participants.get(j+1)));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for (int j = 0; j < (gameList.get(i-1).size()/2); j++) {
|
||||||
|
gameRound.add(new Game(gameList.get(i-1).get(j*2),gameList.get(i-1).get(j*2+1)));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
gameList.add(gameRound);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
@ -83,6 +127,10 @@ public class Tournament implements Serializable {
|
||||||
this.type = type;
|
this.type = type;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<List<Game>> getGameList() {
|
||||||
|
return gameList;
|
||||||
|
}
|
||||||
|
|
||||||
public enum Type {
|
public enum Type {
|
||||||
KO("KO-System"), GROUPS("Gruppenspiele");
|
KO("KO-System"), GROUPS("Gruppenspiele");
|
||||||
|
|
||||||
|
@ -97,7 +145,7 @@ public class Tournament implements Serializable {
|
||||||
return name;
|
return name;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static ObservableList<Type> getObservableList(){
|
public static ObservableList<Type> getObservableList() {
|
||||||
ObservableList<Type> items = FXCollections.observableArrayList();
|
ObservableList<Type> items = FXCollections.observableArrayList();
|
||||||
items.addAll(values());
|
items.addAll(values());
|
||||||
return items;
|
return items;
|
||||||
|
@ -159,5 +207,14 @@ public class Tournament implements Serializable {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class NumberOfParticipantInvalidException extends Exception {
|
||||||
|
public NumberOfParticipantInvalidException() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
public NumberOfParticipantInvalidException(String msg) {
|
||||||
|
super(msg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,11 +4,14 @@ import java.io.IOException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.concurrent.ExecutorService;
|
||||||
|
import java.util.concurrent.Executors;
|
||||||
|
|
||||||
public class TournamentDecorator implements IsObservable{
|
public class TournamentDecorator implements IsObservable{
|
||||||
private Tournament tournament;
|
private Tournament tournament;
|
||||||
private FileIO fileIO;
|
private FileIO fileIO;
|
||||||
private List<IsObserver> listener = new ArrayList<>();
|
private List<IsObserver> listener = new ArrayList<>();
|
||||||
|
private ExecutorService executorService;
|
||||||
|
|
||||||
public TournamentDecorator(FileIO fileIO){
|
public TournamentDecorator(FileIO fileIO){
|
||||||
setFileIO(fileIO);
|
setFileIO(fileIO);
|
||||||
|
@ -16,10 +19,12 @@ public class TournamentDecorator implements IsObservable{
|
||||||
@Override
|
@Override
|
||||||
public void update() {
|
public void update() {
|
||||||
if(tournament != null){
|
if(tournament != null){
|
||||||
|
|
||||||
saveTournament();
|
saveTournament();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
executorService = Executors.newFixedThreadPool(Runtime.getRuntime().availableProcessors());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setFileIO(FileIO fileIO) {
|
public void setFileIO(FileIO fileIO) {
|
||||||
|
@ -44,14 +49,13 @@ public class TournamentDecorator implements IsObservable{
|
||||||
listener.remove(observer);
|
listener.remove(observer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void saveTournament(){
|
public void saveTournament(){
|
||||||
try {
|
executorService.execute(new saveTask());
|
||||||
fileIO.saveTournament(tournament);
|
|
||||||
} catch (IOException e) {
|
|
||||||
e.printStackTrace(); //TODO handle and logging
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void createTournament(String name, Tournament.Type type){
|
public void createTournament(String name, Tournament.Type type){
|
||||||
if(fileIO.tournamentExists(name)){
|
if(fileIO.tournamentExists(name)){
|
||||||
System.out.println("Tournament with same name exists already.");
|
System.out.println("Tournament with same name exists already.");
|
||||||
|
@ -79,6 +83,11 @@ public class TournamentDecorator implements IsObservable{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void createNewGameSchedule() throws Tournament.NumberOfParticipantInvalidException {
|
||||||
|
tournament.createGameSchedule();
|
||||||
|
informListener();
|
||||||
|
}
|
||||||
|
|
||||||
public void savePlayer(String firstName, String name, String phoneNumber, String dateOfBirth){
|
public void savePlayer(String firstName, String name, String phoneNumber, String dateOfBirth){
|
||||||
try {
|
try {
|
||||||
tournament.addParticipant(new Player(firstName, name, phoneNumber, dateOfBirth));
|
tournament.addParticipant(new Player(firstName, name, phoneNumber, dateOfBirth));
|
||||||
|
@ -121,9 +130,23 @@ public class TournamentDecorator implements IsObservable{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void informListener() {
|
public void informListener() {
|
||||||
for(IsObserver observer : listener) {
|
for(IsObserver observer : listener) {
|
||||||
observer.update();
|
observer.update();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class saveTask implements Runnable {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
try {
|
||||||
|
fileIO.saveTournament(tournament);
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace(); //TODO handle and logging
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,13 +25,13 @@ public class MainWindow extends Application {
|
||||||
|
|
||||||
BorderPane pane = factory.loadMainWindow();
|
BorderPane pane = factory.loadMainWindow();
|
||||||
factoryDecorator = new FactoryDecorator(fileIO, factory, pane);
|
factoryDecorator = new FactoryDecorator(fileIO, factory, pane);
|
||||||
factory.loadTournamentList(pane, factoryDecorator);
|
factoryDecorator.openTournamentList();
|
||||||
|
|
||||||
|
|
||||||
Scene scene = new Scene(pane);
|
Scene scene = new Scene(pane);
|
||||||
primaryStage.setScene(scene);
|
primaryStage.setScene(scene);
|
||||||
primaryStage.setMaximized(true);
|
primaryStage.setMaximized(true);
|
||||||
primaryStage.setResizable(false);
|
primaryStage.setResizable(true);
|
||||||
primaryStage.setFullScreen(false);
|
primaryStage.setFullScreen(false);
|
||||||
primaryStage.show();
|
primaryStage.show();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,16 +1,80 @@
|
||||||
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
|
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
|
||||||
|
|
||||||
import ch.zhaw.projekt2.turnierverwaltung.FXController;
|
import ch.zhaw.projekt2.turnierverwaltung.*;
|
||||||
|
import javafx.beans.value.ObservableValue;
|
||||||
|
import javafx.event.Event;
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
import javafx.scene.control.ChoiceBox;
|
import javafx.scene.control.ChoiceBox;
|
||||||
|
import javafx.scene.control.Label;
|
||||||
|
import javafx.scene.control.TextField;
|
||||||
|
import javafx.scene.layout.Pane;
|
||||||
|
import javafx.scene.layout.VBox;
|
||||||
|
|
||||||
public class GameController extends FXController {
|
public class GameController extends FXController{
|
||||||
|
|
||||||
|
private GameDecorator gameDecorator;
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
private ChoiceBox<?> placesChoiceBox;
|
private VBox mainVBox;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private Label participantNameOne;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private Label participantNameTwo;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private ChoiceBox<Place> placesChoiceBox;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private TextField pointsTeamOne;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private TextField pointsTeamTwo;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
void saveGameResult(Event event) {
|
||||||
|
gameDecorator.saveGameResult(pointsTeamOne.getText(), pointsTeamTwo.getText());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private void saveGamePlace(Place newPlace) {
|
||||||
|
gameDecorator.saveGamePlace(newPlace);
|
||||||
|
}
|
||||||
|
|
||||||
|
public double getGameBoxHeigth(){
|
||||||
|
return mainVBox.getPrefHeight();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void loadContent() {
|
public void loadContent() {
|
||||||
|
participantNameOne.setText(gameDecorator.getParticipantOne());
|
||||||
|
participantNameTwo.setText(gameDecorator.getParticipantTwo());
|
||||||
|
pointsTeamOne.setText(String.valueOf(gameDecorator.getPoints1()));
|
||||||
|
pointsTeamTwo.setText(String.valueOf(gameDecorator.getPoints2()));
|
||||||
|
placesChoiceBox.setItems(getTournamentDecorator().getTournament().getPlaces());
|
||||||
|
placesChoiceBox.setValue(gameDecorator.getPlace());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void refreshParticipants(){
|
||||||
|
gameDecorator.refreshParticipants();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addListener(GameDecorator gameDecorator){
|
||||||
|
gameDecorator.addListener(new IsObserver() {
|
||||||
|
@Override
|
||||||
|
public void update() {
|
||||||
|
refreshParticipants();
|
||||||
|
loadContent();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void setup(TournamentDecorator tournamentDecorator, FileIO fileIO, FactoryDecorator factoryDecorator, Pane pane, GameDecorator gameDecorator) {
|
||||||
|
setTournamentDecorator(tournamentDecorator);
|
||||||
|
this.gameDecorator = gameDecorator;
|
||||||
|
placesChoiceBox.getSelectionModel().selectedItemProperty().addListener((ObservableValue<? extends Place> observable, Place oldValue, Place newValue) -> saveGamePlace(newValue));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -0,0 +1,82 @@
|
||||||
|
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
|
||||||
|
|
||||||
|
import ch.zhaw.projekt2.turnierverwaltung.*;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
|
public class GameDecorator implements IsObservable{
|
||||||
|
private Game game;
|
||||||
|
private List<IsObserver> listener = new ArrayList<>();
|
||||||
|
|
||||||
|
public GameDecorator (Game game) {
|
||||||
|
this.game = game;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void addListener(IsObserver observer) {
|
||||||
|
listener.add(observer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void removeListener(IsObserver observer) {
|
||||||
|
listener.remove(observer);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void saveGameResult(String points1, String points2){
|
||||||
|
if(points1.length() > 0){
|
||||||
|
game.setPoints1(Integer.parseInt(points1));
|
||||||
|
} else {
|
||||||
|
game.setPoints1(0);
|
||||||
|
}
|
||||||
|
if(points2.length() > 0) {
|
||||||
|
game.setPoints2(Integer.parseInt(points2));
|
||||||
|
} else {
|
||||||
|
game.setPoints2(0);
|
||||||
|
}
|
||||||
|
informListener();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void saveGamePlace(Place place){
|
||||||
|
game.setPlace(place);
|
||||||
|
informListener();
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPoints1() {
|
||||||
|
return String.valueOf(game.getPoints1());
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPoints2() {
|
||||||
|
return String.valueOf(game.getPoints2());
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getParticipantOne() {
|
||||||
|
if (game.getParticipant1() != null) {
|
||||||
|
return game.getParticipant1().toString();
|
||||||
|
}
|
||||||
|
return "1";
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getParticipantTwo() {
|
||||||
|
if (game.getParticipant2() != null) {
|
||||||
|
return game.getParticipant2().toString();
|
||||||
|
}
|
||||||
|
return "2";
|
||||||
|
}
|
||||||
|
|
||||||
|
public void refreshParticipants(){
|
||||||
|
game.refreshParticipants();
|
||||||
|
informListener();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Place getPlace() {
|
||||||
|
return game.getPlace();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void informListener() {
|
||||||
|
for(IsObserver observer : listener) {
|
||||||
|
observer.update();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,24 +1,69 @@
|
||||||
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
|
package ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView;
|
||||||
|
|
||||||
import ch.zhaw.projekt2.turnierverwaltung.FXController;
|
import ch.zhaw.projekt2.turnierverwaltung.FXController;
|
||||||
|
import ch.zhaw.projekt2.turnierverwaltung.Tournament;
|
||||||
import javafx.event.ActionEvent;
|
import javafx.event.ActionEvent;
|
||||||
import javafx.fxml.FXML;
|
import javafx.fxml.FXML;
|
||||||
|
import javafx.scene.control.Button;
|
||||||
|
import javafx.scene.control.CheckBox;
|
||||||
|
import javafx.scene.layout.HBox;
|
||||||
|
|
||||||
public class GameScheduleController extends FXController {
|
public class GameScheduleController extends FXController {
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private Button createScheduleBtn;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private Button editLocBtn;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private Button editParticipantBtn;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private Button closeTournamentBtn;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private HBox hBoxCenter;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
private CheckBox treeView;
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
void createNewSchedule(ActionEvent event) {
|
||||||
|
try {
|
||||||
|
getTournamentDecorator().createNewGameSchedule();
|
||||||
|
} catch (Tournament.NumberOfParticipantInvalidException e) {
|
||||||
|
//TODO Method in FactoryDecorater to show msg
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
void openPlacesFormular(ActionEvent event) {
|
void openPlacesFormular(ActionEvent event) {
|
||||||
|
removeListener();
|
||||||
getFactoryDecorator().openPlacesFormular();
|
getFactoryDecorator().openPlacesFormular();
|
||||||
}
|
}
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
void openParticipantFormular(ActionEvent event) {
|
void openParticipantFormular(ActionEvent event) {
|
||||||
|
removeListener();
|
||||||
getFactoryDecorator().openParticipantFormular();
|
getFactoryDecorator().openParticipantFormular();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
void closeTournament(ActionEvent event) {
|
||||||
|
removeListener();
|
||||||
|
getFactoryDecorator().openTournamentList();
|
||||||
|
}
|
||||||
|
|
||||||
|
@FXML
|
||||||
|
void changeView(ActionEvent event) {
|
||||||
|
loadContent();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void loadContent() {
|
public void loadContent() {
|
||||||
|
getFactoryDecorator().loadGameList(hBoxCenter, getTournamentDecorator(), treeView.isSelected());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -89,6 +89,7 @@ public class ParticipantFormularController extends FXController {
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
void close(ActionEvent event) {
|
void close(ActionEvent event) {
|
||||||
|
removeListener();
|
||||||
getFactoryDecorator().openScheduleView();
|
getFactoryDecorator().openScheduleView();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,6 +68,7 @@ public class PlacesFormularController extends FXController {
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
void close(ActionEvent event) {
|
void close(ActionEvent event) {
|
||||||
|
removeListener();
|
||||||
getFactoryDecorator().openScheduleView();
|
getFactoryDecorator().openScheduleView();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -4,8 +4,6 @@ import javafx.scene.control.Alert;
|
||||||
import javafx.scene.control.ButtonBar;
|
import javafx.scene.control.ButtonBar;
|
||||||
import javafx.scene.control.ButtonType;
|
import javafx.scene.control.ButtonType;
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
|
|
||||||
public class AlertDelete extends Alert {
|
public class AlertDelete extends Alert {
|
||||||
ButtonType yesButton = new ButtonType("Ja", ButtonBar.ButtonData.YES);
|
ButtonType yesButton = new ButtonType("Ja", ButtonBar.ButtonData.YES);
|
||||||
ButtonType noButton = new ButtonType("Nein", ButtonBar.ButtonData.NO);
|
ButtonType noButton = new ButtonType("Nein", ButtonBar.ButtonData.NO);
|
||||||
|
|
|
@ -61,6 +61,7 @@ public class TournamentListController extends FXController {
|
||||||
|
|
||||||
@FXML
|
@FXML
|
||||||
void openTournament(ActionEvent event) {
|
void openTournament(ActionEvent event) {
|
||||||
|
removeListener();
|
||||||
FileIO.TournamentFile tournamentFile = tournamentListView.getSelectionModel().getSelectedItems().get(0);
|
FileIO.TournamentFile tournamentFile = tournamentListView.getSelectionModel().getSelectedItems().get(0);
|
||||||
getFactoryDecorator().openTournament(tournamentFile);
|
getFactoryDecorator().openTournament(tournamentFile);
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,40 +7,53 @@
|
||||||
<?import javafx.scene.layout.HBox?>
|
<?import javafx.scene.layout.HBox?>
|
||||||
<?import javafx.scene.layout.VBox?>
|
<?import javafx.scene.layout.VBox?>
|
||||||
|
|
||||||
|
<VBox alignment="CENTER" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="90.0" prefWidth="450.0" style="-fx-border-color: black; -fx-border-insets: 2; -fx-border-width: 3;" xmlns="http://javafx.com/javafx/18" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameController">
|
||||||
<VBox alignment="CENTER" maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="150.0" prefWidth="200.0" xmlns="http://javafx.com/javafx/17" xmlns:fx="http://javafx.com/fxml/1" fx:controller="GameContoller">
|
|
||||||
<children>
|
<children>
|
||||||
<Label fx:id="teamNameOne" text="Team One" />
|
<VBox fx:id="mainVBox" alignment="CENTER" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" prefHeight="90.0">
|
||||||
<HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
|
|
||||||
<children>
|
<children>
|
||||||
<Label text="Points">
|
<HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
|
||||||
<HBox.margin>
|
<children>
|
||||||
<Insets right="20.0" />
|
<Label fx:id="participantNameOne" style="-fx-font-weight: bold;" text="Participant One">
|
||||||
</HBox.margin>
|
<HBox.margin>
|
||||||
</Label>
|
<Insets right="20.0" />
|
||||||
<TextField fx:id="pointsTeamOne" prefHeight="25.0" prefWidth="50.0" />
|
</HBox.margin>
|
||||||
|
</Label>
|
||||||
|
<TextField fx:id="pointsTeamOne" alignment="CENTER" onKeyTyped="#saveGameResult" prefHeight="25.0" prefWidth="50.0">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin>
|
||||||
|
</TextField>
|
||||||
|
<Label text=":">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin>
|
||||||
|
</Label>
|
||||||
|
<TextField fx:id="pointsTeamTwo" alignment="CENTER" onKeyTyped="#saveGameResult" prefHeight="25.0" prefWidth="50.0">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin>
|
||||||
|
</TextField>
|
||||||
|
<Label fx:id="participantNameTwo" style="-fx-font-weight: bold;" text="Participant Two">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin>
|
||||||
|
</Label>
|
||||||
|
</children>
|
||||||
|
</HBox>
|
||||||
|
<HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
|
||||||
|
<children>
|
||||||
|
<Label text="Ort">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin>
|
||||||
|
</Label>
|
||||||
|
<ChoiceBox fx:id="placesChoiceBox" prefWidth="150.0" />
|
||||||
|
</children>
|
||||||
|
<VBox.margin>
|
||||||
|
<Insets top="10.0" />
|
||||||
|
</VBox.margin>
|
||||||
|
</HBox>
|
||||||
</children>
|
</children>
|
||||||
</HBox>
|
</VBox>
|
||||||
<Label fx:id="teamNameTwo" text="Team Two" />
|
|
||||||
<HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
|
|
||||||
<children>
|
|
||||||
<Label text="Points">
|
|
||||||
<HBox.margin>
|
|
||||||
<Insets right="20.0" />
|
|
||||||
</HBox.margin>
|
|
||||||
</Label>
|
|
||||||
<TextField fx:id="pointsTeamTwo" prefHeight="25.0" prefWidth="50.0" />
|
|
||||||
</children>
|
|
||||||
</HBox>
|
|
||||||
<HBox alignment="CENTER" prefHeight="100.0" prefWidth="200.0">
|
|
||||||
<children>
|
|
||||||
<Label text="Ort">
|
|
||||||
<HBox.margin>
|
|
||||||
<Insets right="20.0" />
|
|
||||||
</HBox.margin>
|
|
||||||
</Label>
|
|
||||||
<ChoiceBox fx:id="placesChoiceBox" prefWidth="150.0" />
|
|
||||||
</children>
|
|
||||||
</HBox>
|
|
||||||
</children>
|
</children>
|
||||||
</VBox>
|
</VBox>
|
||||||
|
|
|
@ -1,26 +1,41 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
<?import javafx.geometry.Insets?>
|
<?import javafx.geometry.*?>
|
||||||
<?import javafx.scene.control.Button?>
|
<?import javafx.scene.control.*?>
|
||||||
<?import javafx.scene.layout.BorderPane?>
|
<?import javafx.scene.layout.*?>
|
||||||
<?import javafx.scene.layout.HBox?>
|
|
||||||
|
|
||||||
|
<BorderPane maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/11.0.2" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameScheduleController">
|
||||||
<BorderPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="400.0" prefWidth="600.0" xmlns="http://javafx.com/javafx/17" xmlns:fx="http://javafx.com/fxml/1" fx:controller="ch.zhaw.projekt2.turnierverwaltung.main.gameScheduleView.GameScheduleController">
|
|
||||||
<top>
|
<top>
|
||||||
<HBox alignment="CENTER_RIGHT" prefHeight="100.0" prefWidth="200.0" BorderPane.alignment="CENTER">
|
<HBox alignment="TOP_RIGHT" prefHeight="100.0" prefWidth="200.0" BorderPane.alignment="CENTER">
|
||||||
<children>
|
<children>
|
||||||
<Button mnemonicParsing="false" onAction="#openParticipantFormular" text="Teilnehmer bearbeiten">
|
<CheckBox fx:id="treeView" mnemonicParsing="false" onAction="#changeView" selected="true" text="Baumansicht" />
|
||||||
|
<Button fx:id="createScheduleBtn" mnemonicParsing="false" onAction="#createNewSchedule" text="Create New Game Schedule">
|
||||||
<HBox.margin>
|
<HBox.margin>
|
||||||
<Insets right="20.0" />
|
<Insets right="20.0" />
|
||||||
</HBox.margin>
|
</HBox.margin>
|
||||||
</Button>
|
</Button>
|
||||||
<Button mnemonicParsing="false" onAction="#openPlacesFormular" text="Orte bearbeiten">
|
<Button fx:id="editParticipantBtn" mnemonicParsing="false" onAction="#openParticipantFormular" text="Teilnehmer bearbeiten">
|
||||||
<HBox.margin>
|
<HBox.margin>
|
||||||
<Insets right="40.0" />
|
<Insets right="20.0" />
|
||||||
</HBox.margin>
|
</HBox.margin>
|
||||||
</Button>
|
</Button>
|
||||||
|
<Button fx:id="editLocBtn" mnemonicParsing="false" onAction="#openPlacesFormular" text="Orte bearbeiten">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin>
|
||||||
|
</Button>
|
||||||
|
<Button fx:id="closeTournamentBtn" layoutX="470.0" layoutY="10.0" mnemonicParsing="false" onAction="#closeTournament" text="Close Tournament">
|
||||||
|
<HBox.margin>
|
||||||
|
<Insets right="20.0" />
|
||||||
|
</HBox.margin></Button>
|
||||||
</children>
|
</children>
|
||||||
</HBox>
|
</HBox>
|
||||||
</top>
|
</top>
|
||||||
|
<center>
|
||||||
|
<ScrollPane maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" prefHeight="200.0" prefWidth="200.0" BorderPane.alignment="CENTER">
|
||||||
|
<content>
|
||||||
|
<HBox fx:id="hBoxCenter" maxHeight="1.7976931348623157E308" maxWidth="1.7976931348623157E308" prefHeight="324.0" prefWidth="600.0" />
|
||||||
|
</content>
|
||||||
|
</ScrollPane>
|
||||||
|
</center>
|
||||||
</BorderPane>
|
</BorderPane>
|
||||||
|
|
Loading…
Reference in New Issue