feat: multi select sudoku
All checks were successful
Linux arm64 / Build (push) Successful in 27s

This commit is contained in:
2025-01-30 18:35:41 +01:00
parent a74bf42e59
commit edfffaf061
3 changed files with 24 additions and 14 deletions

View File

@@ -1,24 +1,27 @@
package gui.menu;
import java.util.Arrays;
import game.Player;
import gui.SudokuSelector;
import imgui.ImGui;
import network.client.Client;
import network.server.Server;
import sudoku.constraint.Constraint;
import sudoku.structure.MultiDoku;
import sudoku.structure.SudokuFactory;
public class MultiPlayerView extends BaseView {
private final Client client;
private final Server server;
private final SudokuSelector selector;
private MultiDoku doku = null;
public MultiPlayerView(StateMachine stateMachine, Client client, Server server) {
super(stateMachine);
this.client = client;
this.server = server;
this.selector = new SudokuSelector(false, "Sélectionner le sudoku");
this.selector.onSelect.connect(this::onSelected);
this.client.onDisconnect.connect(this::onDisconnect);
this.client.onGameStarted
.connect(() -> this.stateMachine.pushState(new MultiPlayerDokuView(stateMachine, client, server)));
@@ -34,15 +37,22 @@ public class MultiPlayerView extends BaseView {
this.stateMachine.popState();
}
private void onSelected() {
this.doku = this.selector.getDoku();
}
public void renderGameStatus() {
if (this.server == null) {
ImGui.text("En attente de l'administrateur du serveur ...");
} else {
if (this.doku == null)
ImGui.beginDisabled();
if (ImGui.button("Démarrer")) {
// temp
MultiDoku doku = SudokuFactory.createBasicXShapedMultidoku(3, Arrays.asList(Constraint.Diagonal));
this.server.startGame(doku);
this.server.startGame(this.doku);
}
if (this.doku == null)
ImGui.endDisabled();
selector.render();
}
}

View File

@@ -9,7 +9,7 @@ public class SoloMenu extends BaseView {
public SoloMenu(StateMachine stateMachine) {
super(stateMachine);
this.sudokuSelector = new SudokuSelector(true);
this.sudokuSelector = new SudokuSelector(true, "Résoudre le sudoku");
this.sudokuSelector.onSelect.connect(this::pushSudokuState);
}