feat: multi synced player scores
All checks were successful
Linux arm64 / Build (push) Successful in 31s
All checks were successful
Linux arm64 / Build (push) Successful in 31s
This commit is contained in:
27
app/src/main/java/common/ConsumerSignal.java
Normal file
27
app/src/main/java/common/ConsumerSignal.java
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package common;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.function.Consumer;
|
||||||
|
|
||||||
|
public class ConsumerSignal<T> {
|
||||||
|
private final Set<Consumer<T>> listeners;
|
||||||
|
|
||||||
|
public ConsumerSignal() {
|
||||||
|
this.listeners = new HashSet<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void connect(Consumer<T> listener) {
|
||||||
|
this.listeners.add(listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void clear() {
|
||||||
|
this.listeners.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void emit(T arg) {
|
||||||
|
for (Consumer<T> listener : this.listeners) {
|
||||||
|
listener.accept(arg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,10 +8,20 @@ public class Player implements Serializable {
|
|||||||
|
|
||||||
private final String pseudo;
|
private final String pseudo;
|
||||||
private final int id;
|
private final int id;
|
||||||
|
private int score;
|
||||||
|
|
||||||
public Player(int id, String pseudo) {
|
public Player(int id, String pseudo) {
|
||||||
this.pseudo = pseudo;
|
this.pseudo = pseudo;
|
||||||
this.id = id;
|
this.id = id;
|
||||||
|
this.score = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getScore() {
|
||||||
|
return score;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setScore(int score) {
|
||||||
|
this.score = score;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getPseudo() {
|
public String getPseudo() {
|
||||||
|
|||||||
@@ -6,6 +6,7 @@ import java.util.List;
|
|||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import common.ConsumerSignal;
|
||||||
import common.Signal;
|
import common.Signal;
|
||||||
import gui.ColorGenerator.Color;
|
import gui.ColorGenerator.Color;
|
||||||
import imgui.ImGui;
|
import imgui.ImGui;
|
||||||
@@ -33,6 +34,7 @@ public class SudokuRenderer {
|
|||||||
private final Set<Cell> diagonals = new HashSet<>();
|
private final Set<Cell> diagonals = new HashSet<>();
|
||||||
|
|
||||||
public final Signal onResolve = new Signal();
|
public final Signal onResolve = new Signal();
|
||||||
|
public final ConsumerSignal<Cell> onCellChange = new ConsumerSignal<>();
|
||||||
|
|
||||||
public SudokuRenderer(MultiDoku doku) {
|
public SudokuRenderer(MultiDoku doku) {
|
||||||
this.doku = RenderableMultidoku.fromMultidoku(doku);
|
this.doku = RenderableMultidoku.fromMultidoku(doku);
|
||||||
@@ -72,11 +74,13 @@ public class SudokuRenderer {
|
|||||||
if (currentCell.getSymbolIndex() == i) {
|
if (currentCell.getSymbolIndex() == i) {
|
||||||
if (ImGui.button("X", cellSize)) {
|
if (ImGui.button("X", cellSize)) {
|
||||||
currentCell.setSymbolIndex(Cell.NOSYMBOL);
|
currentCell.setSymbolIndex(Cell.NOSYMBOL);
|
||||||
|
this.onCellChange.emit(currentCell);
|
||||||
ImGui.closeCurrentPopup();
|
ImGui.closeCurrentPopup();
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (ImGui.button(Options.Symboles.getSymbols().get(i), cellSize)) {
|
if (ImGui.button(Options.Symboles.getSymbols().get(i), cellSize)) {
|
||||||
currentCell.trySetValue(i);
|
if (currentCell.trySetValue(i))
|
||||||
|
this.onCellChange.emit(currentCell);
|
||||||
if (this.doku.getDoku().isSolved())
|
if (this.doku.getDoku().isSolved())
|
||||||
this.onResolve.emit();
|
this.onResolve.emit();
|
||||||
ImGui.closeCurrentPopup();
|
ImGui.closeCurrentPopup();
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package gui;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
import common.Signal;
|
import common.ConsumerSignal;
|
||||||
import imgui.ImGui;
|
import imgui.ImGui;
|
||||||
import imgui.extension.imguifiledialog.ImGuiFileDialog;
|
import imgui.extension.imguifiledialog.ImGuiFileDialog;
|
||||||
import imgui.extension.imguifiledialog.flag.ImGuiFileDialogFlags;
|
import imgui.extension.imguifiledialog.flag.ImGuiFileDialogFlags;
|
||||||
@@ -16,7 +16,7 @@ import sudoku.structure.SudokuFactory;
|
|||||||
|
|
||||||
public class SudokuSelector {
|
public class SudokuSelector {
|
||||||
|
|
||||||
public final Signal onSelect = new Signal();
|
public final ConsumerSignal<MultiDoku> onSelect = new ConsumerSignal<>();
|
||||||
private MultiDoku doku;
|
private MultiDoku doku;
|
||||||
|
|
||||||
private final boolean canGenEmptyGrid;
|
private final boolean canGenEmptyGrid;
|
||||||
@@ -63,7 +63,7 @@ public class SudokuSelector {
|
|||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
this.onSelect.emit();
|
this.onSelect.emit(this.doku);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void renderFileDialog() {
|
public void renderFileDialog() {
|
||||||
@@ -75,7 +75,7 @@ public class SudokuSelector {
|
|||||||
String filePath = entry.getValue();
|
String filePath = entry.getValue();
|
||||||
this.doku = SudokuFactory.fromfile(filePath);
|
this.doku = SudokuFactory.fromfile(filePath);
|
||||||
if (this.doku != null)
|
if (this.doku != null)
|
||||||
this.onSelect.emit();
|
this.onSelect.emit(this.doku);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
@@ -129,8 +129,4 @@ public class SudokuSelector {
|
|||||||
renderFileDialog();
|
renderFileDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
public MultiDoku getDoku() {
|
|
||||||
return doku;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import gui.SudokuRenderer;
|
|||||||
import imgui.ImGui;
|
import imgui.ImGui;
|
||||||
import network.client.Client;
|
import network.client.Client;
|
||||||
import network.server.Server;
|
import network.server.Server;
|
||||||
|
import sudoku.structure.Cell;
|
||||||
|
|
||||||
public class MultiPlayerDokuView extends BaseView{
|
public class MultiPlayerDokuView extends BaseView{
|
||||||
|
|
||||||
@@ -16,9 +17,14 @@ public class MultiPlayerDokuView extends BaseView{
|
|||||||
this.client = client;
|
this.client = client;
|
||||||
this.server = server;
|
this.server = server;
|
||||||
this.sudokuRenderer = new SudokuRenderer(this.client.getGame().getDoku());
|
this.sudokuRenderer = new SudokuRenderer(this.client.getGame().getDoku());
|
||||||
|
this.sudokuRenderer.onCellChange.connect(this::onCellChange);
|
||||||
this.client.onDisconnect.connect(this::onDisconnect);
|
this.client.onDisconnect.connect(this::onDisconnect);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void onCellChange(Cell cell) {
|
||||||
|
this.client.sendCellChange(cell);
|
||||||
|
}
|
||||||
|
|
||||||
public void onDisconnect() {
|
public void onDisconnect() {
|
||||||
if (server == null) {
|
if (server == null) {
|
||||||
closeMenu();
|
closeMenu();
|
||||||
|
|||||||
@@ -37,8 +37,8 @@ public class MultiPlayerView extends BaseView {
|
|||||||
this.stateMachine.popState();
|
this.stateMachine.popState();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onSelected() {
|
private void onSelected(MultiDoku doku) {
|
||||||
this.doku = this.selector.getDoku();
|
this.doku = doku;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void renderGameStatus() {
|
public void renderGameStatus() {
|
||||||
|
|||||||
@@ -2,6 +2,7 @@ package gui.menu;
|
|||||||
|
|
||||||
import gui.SudokuSelector;
|
import gui.SudokuSelector;
|
||||||
import imgui.ImGui;
|
import imgui.ImGui;
|
||||||
|
import sudoku.structure.MultiDoku;
|
||||||
|
|
||||||
public class SoloMenu extends BaseView {
|
public class SoloMenu extends BaseView {
|
||||||
|
|
||||||
@@ -13,8 +14,8 @@ public class SoloMenu extends BaseView {
|
|||||||
this.sudokuSelector.onSelect.connect(this::pushSudokuState);
|
this.sudokuSelector.onSelect.connect(this::pushSudokuState);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void pushSudokuState() {
|
private void pushSudokuState(MultiDoku doku) {
|
||||||
this.stateMachine.pushState(new SudokuView(stateMachine, this.sudokuSelector.getDoku()));
|
this.stateMachine.pushState(new SudokuView(stateMachine, doku));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ public class ConnexionThread extends Thread {
|
|||||||
// System.out.println(objectInputStream.available());
|
// System.out.println(objectInputStream.available());
|
||||||
Object o = objectInputStream.readObject();
|
Object o = objectInputStream.readObject();
|
||||||
if (o instanceof Packet packet) {
|
if (o instanceof Packet packet) {
|
||||||
connexion.visitPacket(packet);
|
connexion.visit(packet);
|
||||||
}
|
}
|
||||||
} catch (ClassNotFoundException | IOException e) {
|
} catch (ClassNotFoundException | IOException e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
|
|||||||
@@ -7,7 +7,11 @@ import java.util.Random;
|
|||||||
import common.Signal;
|
import common.Signal;
|
||||||
import game.Game;
|
import game.Game;
|
||||||
import game.Player;
|
import game.Player;
|
||||||
|
import network.protocol.packets.ChangeCellPacket;
|
||||||
import network.protocol.packets.LoginPacket;
|
import network.protocol.packets.LoginPacket;
|
||||||
|
import sudoku.structure.Cell;
|
||||||
|
import sudoku.structure.MultiDoku;
|
||||||
|
import sudoku.structure.Sudoku;
|
||||||
|
|
||||||
public class Client {
|
public class Client {
|
||||||
private final ClientConnexion clientConnection;
|
private final ClientConnexion clientConnection;
|
||||||
@@ -54,4 +58,16 @@ public class Client {
|
|||||||
stop();
|
stop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void sendCellChange(Cell cell) {
|
||||||
|
MultiDoku doku = getGame().getDoku();
|
||||||
|
for (int sudokuIndex = 0; sudokuIndex < doku.getNbSubGrids(); sudokuIndex++) {
|
||||||
|
Sudoku sudoku = doku.getSubGrid(sudokuIndex);
|
||||||
|
int cellIndex = sudoku.getCells().indexOf(cell);
|
||||||
|
if (cellIndex != -1) {
|
||||||
|
this.clientConnection.sendPacket(new ChangeCellPacket(sudokuIndex, cellIndex, cell.getSymbolIndex()));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,13 +6,16 @@ import java.net.UnknownHostException;
|
|||||||
|
|
||||||
import game.Player;
|
import game.Player;
|
||||||
import network.Connexion;
|
import network.Connexion;
|
||||||
|
import network.protocol.packets.ChangeCellPacket;
|
||||||
import network.protocol.packets.ConnexionInfoPacket;
|
import network.protocol.packets.ConnexionInfoPacket;
|
||||||
import network.protocol.packets.DisconnectPacket;
|
import network.protocol.packets.DisconnectPacket;
|
||||||
|
import network.protocol.packets.EndGamePacket;
|
||||||
import network.protocol.packets.KeepAlivePacket;
|
import network.protocol.packets.KeepAlivePacket;
|
||||||
import network.protocol.packets.LoginPacket;
|
import network.protocol.packets.LoginPacket;
|
||||||
import network.protocol.packets.PlayerJoinPacket;
|
import network.protocol.packets.PlayerJoinPacket;
|
||||||
import network.protocol.packets.PlayerLeavePacket;
|
import network.protocol.packets.PlayerLeavePacket;
|
||||||
import network.protocol.packets.StartGamePacket;
|
import network.protocol.packets.StartGamePacket;
|
||||||
|
import network.protocol.packets.UpdatePlayerScorePacket;
|
||||||
import sudoku.io.SudokuSerializer;
|
import sudoku.io.SudokuSerializer;
|
||||||
|
|
||||||
public class ClientConnexion extends Connexion {
|
public class ClientConnexion extends Connexion {
|
||||||
@@ -73,4 +76,23 @@ public class ClientConnexion extends Connexion {
|
|||||||
this.client.onGameStarted.emit();
|
this.client.onGameStarted.emit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void visitPacket(EndGamePacket packet) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
throw new UnsupportedOperationException("Unimplemented method 'visitPacket'");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void visitPacket(UpdatePlayerScorePacket packet) {
|
||||||
|
Player player = this.client.getGame().getPlayerById(packet.getPlayerId());
|
||||||
|
assert(player != null);
|
||||||
|
player.setScore(packet.getCellsLeft());
|
||||||
|
System.out.println("Score for " + player.getPseudo() + " : " + packet.getCellsLeft());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void visitPacket(ChangeCellPacket packet) {
|
||||||
|
throw new UnsupportedOperationException("Unimplemented method 'visitPacketChangeCell'");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,16 +1,19 @@
|
|||||||
package network.protocol;
|
package network.protocol;
|
||||||
|
|
||||||
|
import network.protocol.packets.ChangeCellPacket;
|
||||||
import network.protocol.packets.ConnexionInfoPacket;
|
import network.protocol.packets.ConnexionInfoPacket;
|
||||||
import network.protocol.packets.DisconnectPacket;
|
import network.protocol.packets.DisconnectPacket;
|
||||||
|
import network.protocol.packets.EndGamePacket;
|
||||||
import network.protocol.packets.KeepAlivePacket;
|
import network.protocol.packets.KeepAlivePacket;
|
||||||
import network.protocol.packets.LoginPacket;
|
import network.protocol.packets.LoginPacket;
|
||||||
import network.protocol.packets.PlayerJoinPacket;
|
import network.protocol.packets.PlayerJoinPacket;
|
||||||
import network.protocol.packets.PlayerLeavePacket;
|
import network.protocol.packets.PlayerLeavePacket;
|
||||||
import network.protocol.packets.StartGamePacket;
|
import network.protocol.packets.StartGamePacket;
|
||||||
|
import network.protocol.packets.UpdatePlayerScorePacket;
|
||||||
|
|
||||||
public interface PacketVisitor {
|
public interface PacketVisitor {
|
||||||
|
|
||||||
default void visitPacket(Packet packet) {
|
default void visit(Packet packet) {
|
||||||
packet.accept(this);
|
packet.accept(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -21,5 +24,8 @@ public interface PacketVisitor {
|
|||||||
void visitPacket(PlayerJoinPacket packet);
|
void visitPacket(PlayerJoinPacket packet);
|
||||||
void visitPacket(PlayerLeavePacket packet);
|
void visitPacket(PlayerLeavePacket packet);
|
||||||
void visitPacket(StartGamePacket packet);
|
void visitPacket(StartGamePacket packet);
|
||||||
|
void visitPacket(EndGamePacket packet);
|
||||||
|
void visitPacket(UpdatePlayerScorePacket packet);
|
||||||
|
void visitPacket(ChangeCellPacket packet);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,6 @@ package network.protocol;
|
|||||||
|
|
||||||
public enum Packets {
|
public enum Packets {
|
||||||
|
|
||||||
ConnectionInfo, KeepAlive, Disconnect, Login, PlayerJoin, PlayerLeave, StartGame
|
ConnectionInfo, KeepAlive, Disconnect, Login, PlayerJoin, PlayerLeave, StartGame, ChangeCell, EndGame, UpdatePlayerScore
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,38 @@
|
|||||||
|
package network.protocol.packets;
|
||||||
|
|
||||||
|
import network.protocol.Packet;
|
||||||
|
import network.protocol.PacketVisitor;
|
||||||
|
import network.protocol.Packets;
|
||||||
|
|
||||||
|
public class ChangeCellPacket extends Packet {
|
||||||
|
|
||||||
|
static private final long serialVersionUID = Packets.ChangeCell.ordinal();
|
||||||
|
|
||||||
|
private final int sudokuIndex;
|
||||||
|
private final int cellIndex;
|
||||||
|
private final int newValue;
|
||||||
|
|
||||||
|
public ChangeCellPacket(int sudokuIndex, int cellIndex, int newValue) {
|
||||||
|
this.sudokuIndex = sudokuIndex;
|
||||||
|
this.cellIndex = cellIndex;
|
||||||
|
this.newValue = newValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getSudokuIndex() {
|
||||||
|
return sudokuIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getCellIndex() {
|
||||||
|
return cellIndex;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getNewValue() {
|
||||||
|
return newValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void accept(PacketVisitor packetVisitor) {
|
||||||
|
packetVisitor.visitPacket(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,26 @@
|
|||||||
|
package network.protocol.packets;
|
||||||
|
|
||||||
|
import network.protocol.Packet;
|
||||||
|
import network.protocol.PacketVisitor;
|
||||||
|
import network.protocol.Packets;
|
||||||
|
|
||||||
|
public class EndGamePacket extends Packet {
|
||||||
|
|
||||||
|
static private final long serialVersionUID = Packets.EndGame.ordinal();
|
||||||
|
|
||||||
|
private final int winnerId;
|
||||||
|
|
||||||
|
public EndGamePacket(int winnerId) {
|
||||||
|
this.winnerId = winnerId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getWinnerId() {
|
||||||
|
return winnerId;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void accept(PacketVisitor packetVisitor) {
|
||||||
|
packetVisitor.visitPacket(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -0,0 +1,32 @@
|
|||||||
|
package network.protocol.packets;
|
||||||
|
|
||||||
|
import network.protocol.Packet;
|
||||||
|
import network.protocol.PacketVisitor;
|
||||||
|
import network.protocol.Packets;
|
||||||
|
|
||||||
|
public class UpdatePlayerScorePacket extends Packet {
|
||||||
|
|
||||||
|
static private final long serialVersionUID = Packets.UpdatePlayerScore.ordinal();
|
||||||
|
|
||||||
|
private final int playerId;
|
||||||
|
private final int cellsLeft;
|
||||||
|
|
||||||
|
public UpdatePlayerScorePacket(int playerId, int cellsLeft) {
|
||||||
|
this.playerId = playerId;
|
||||||
|
this.cellsLeft = cellsLeft;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getPlayerId() {
|
||||||
|
return playerId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getCellsLeft() {
|
||||||
|
return cellsLeft;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void accept(PacketVisitor packetVisitor) {
|
||||||
|
packetVisitor.visitPacket(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -70,6 +70,9 @@ public class Server {
|
|||||||
|
|
||||||
public void startGame(MultiDoku doku) {
|
public void startGame(MultiDoku doku) {
|
||||||
this.game.startGame(doku);
|
this.game.startGame(doku);
|
||||||
|
for (ServerConnexion connexion : this.connexions) {
|
||||||
|
connexion.setSudoku(doku);
|
||||||
|
}
|
||||||
broadcastPacket(new StartGamePacket(SudokuSerializer.serializeSudoku(doku).toString()));
|
broadcastPacket(new StartGamePacket(SudokuSerializer.serializeSudoku(doku).toString()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,14 +6,19 @@ import java.net.Socket;
|
|||||||
import game.Player;
|
import game.Player;
|
||||||
import game.Game.GameState;
|
import game.Game.GameState;
|
||||||
import network.Connexion;
|
import network.Connexion;
|
||||||
|
import network.protocol.packets.ChangeCellPacket;
|
||||||
import network.protocol.packets.ConnexionInfoPacket;
|
import network.protocol.packets.ConnexionInfoPacket;
|
||||||
import network.protocol.packets.DisconnectPacket;
|
import network.protocol.packets.DisconnectPacket;
|
||||||
|
import network.protocol.packets.EndGamePacket;
|
||||||
import network.protocol.packets.KeepAlivePacket;
|
import network.protocol.packets.KeepAlivePacket;
|
||||||
import network.protocol.packets.LoginPacket;
|
import network.protocol.packets.LoginPacket;
|
||||||
import network.protocol.packets.PlayerJoinPacket;
|
import network.protocol.packets.PlayerJoinPacket;
|
||||||
import network.protocol.packets.PlayerLeavePacket;
|
import network.protocol.packets.PlayerLeavePacket;
|
||||||
import network.protocol.packets.StartGamePacket;
|
import network.protocol.packets.StartGamePacket;
|
||||||
|
import network.protocol.packets.UpdatePlayerScorePacket;
|
||||||
import sudoku.io.SudokuSerializer;
|
import sudoku.io.SudokuSerializer;
|
||||||
|
import sudoku.structure.Cell;
|
||||||
|
import sudoku.structure.MultiDoku;
|
||||||
|
|
||||||
public class ServerConnexion extends Connexion {
|
public class ServerConnexion extends Connexion {
|
||||||
|
|
||||||
@@ -21,6 +26,7 @@ public class ServerConnexion extends Connexion {
|
|||||||
private final KeepAliveHandler keepAliveHandler;
|
private final KeepAliveHandler keepAliveHandler;
|
||||||
private boolean shouldClose = false;
|
private boolean shouldClose = false;
|
||||||
private Player player = null;
|
private Player player = null;
|
||||||
|
private MultiDoku doku;
|
||||||
|
|
||||||
public ServerConnexion(Socket socket, Server server) throws IOException {
|
public ServerConnexion(Socket socket, Server server) throws IOException {
|
||||||
super(socket);
|
super(socket);
|
||||||
@@ -44,7 +50,7 @@ public class ServerConnexion extends Connexion {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public synchronized void close() {
|
public synchronized void close() {
|
||||||
if(shouldClose)
|
if (shouldClose)
|
||||||
return;
|
return;
|
||||||
super.close();
|
super.close();
|
||||||
shouldClose = true;
|
shouldClose = true;
|
||||||
@@ -54,13 +60,19 @@ public class ServerConnexion extends Connexion {
|
|||||||
private void finishLogin() {
|
private void finishLogin() {
|
||||||
// send players that have already joined (excluding this one)
|
// send players that have already joined (excluding this one)
|
||||||
for (Player p : this.server.getGame().getPlayers().values()) {
|
for (Player p : this.server.getGame().getPlayers().values()) {
|
||||||
if (p.getId() != player.getId())
|
if (p.getId() != player.getId()) {
|
||||||
sendPacket(new PlayerJoinPacket(p));
|
sendPacket(new PlayerJoinPacket(p));
|
||||||
|
sendPacket(new UpdatePlayerScorePacket(p.getId(), p.getScore()));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.server.broadcastPacket(new PlayerJoinPacket(player));
|
this.server.broadcastPacket(new PlayerJoinPacket(player));
|
||||||
sendPacket(new ConnexionInfoPacket(player.getId()));
|
sendPacket(new ConnexionInfoPacket(player.getId()));
|
||||||
|
|
||||||
if (this.server.getGame().getGameState() == GameState.GameGoing) {
|
if (this.server.getGame().getGameState() == GameState.GameGoing) {
|
||||||
sendPacket(new StartGamePacket(SudokuSerializer.serializeSudoku(this.server.getGame().getDoku()).toString()));
|
setSudoku(this.server.getGame().getDoku());
|
||||||
|
sendPacket(
|
||||||
|
new StartGamePacket(SudokuSerializer.serializeSudoku(this.server.getGame().getDoku()).toString()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -102,4 +114,43 @@ public class ServerConnexion extends Connexion {
|
|||||||
throw new UnsupportedOperationException("Unimplemented method 'visitPacketStartGame'");
|
throw new UnsupportedOperationException("Unimplemented method 'visitPacketStartGame'");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void visitPacket(EndGamePacket packet) {
|
||||||
|
throw new UnsupportedOperationException("Unimplemented method 'visitPacket'");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void visitPacket(UpdatePlayerScorePacket packet) {
|
||||||
|
throw new UnsupportedOperationException("Unimplemented method 'visitPacket'");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void visitPacket(ChangeCellPacket packet) {
|
||||||
|
Cell cell = this.doku.getSubGrid(packet.getSudokuIndex()).getCell(packet.getCellIndex());
|
||||||
|
if (cell.getSymbolIndex() == Cell.NOSYMBOL && packet.getNewValue() == Cell.NOSYMBOL)
|
||||||
|
return;
|
||||||
|
if (cell.getSymbolIndex() != Cell.NOSYMBOL && packet.getNewValue() != Cell.NOSYMBOL) {
|
||||||
|
cell.trySetValue(packet.getNewValue());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (cell.getSymbolIndex() != Cell.NOSYMBOL && packet.getNewValue() == Cell.NOSYMBOL) {
|
||||||
|
cell.trySetValue(Cell.NOSYMBOL);
|
||||||
|
player.setScore(player.getScore() + 1);
|
||||||
|
sendPacket(new UpdatePlayerScorePacket(player.getId(), player.getScore()));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// on rajoute un chiffre à la grille
|
||||||
|
if (cell.trySetValue(packet.getNewValue())) {
|
||||||
|
player.setScore(player.getScore() - 1);
|
||||||
|
sendPacket(new UpdatePlayerScorePacket(player.getId(), player.getScore()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setSudoku(MultiDoku doku) {
|
||||||
|
this.doku = doku;
|
||||||
|
assert (player != null);
|
||||||
|
player.setScore(this.doku.getEmptyCells().size());
|
||||||
|
sendPacket(new UpdatePlayerScorePacket(player.getId(), player.getScore()));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -126,6 +126,8 @@ public class Cell {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public boolean trySetValue(int newValue) {
|
public boolean trySetValue(int newValue) {
|
||||||
|
if (!isMutable())
|
||||||
|
return false;
|
||||||
if (!canHaveValue(newValue))
|
if (!canHaveValue(newValue))
|
||||||
return false;
|
return false;
|
||||||
setSymbolIndex(newValue);
|
setSymbolIndex(newValue);
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
package sudoku.structure;
|
package sudoku.structure;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashSet;
|
||||||
import sudoku.io.SudokuSerializer;
|
import java.util.List;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @class MultiDoku
|
* @class MultiDoku
|
||||||
|
|||||||
Reference in New Issue
Block a user