commit
596a675aaf
|
@ -167,6 +167,15 @@ public class LaticeApplicationConsole {
|
||||||
|
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
|
if (player.getScore()>=3) {
|
||||||
|
//Donner une action supplémentaire et enlever 3 points au joueur
|
||||||
|
player.Play(play, board, 0);
|
||||||
|
player.diffScore(3);
|
||||||
|
}else {
|
||||||
|
System.out.println("Il vous faut 3 points pour acheter une nouvelle action !");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
case 3: player.getRack().changeRack();
|
case 3: player.getRack().changeRack();
|
||||||
System.out.println("Votre rack à été changé avec succès !");
|
System.out.println("Votre rack à été changé avec succès !");
|
||||||
|
|
|
@ -42,6 +42,7 @@ import javafx.stage.Stage;
|
||||||
import latice.controller.MainScreenController;
|
import latice.controller.MainScreenController;
|
||||||
import latice.controller.PlayerNameInputController;
|
import latice.controller.PlayerNameInputController;
|
||||||
import latice.model.Color;
|
import latice.model.Color;
|
||||||
|
import latice.model.Constant;
|
||||||
import latice.model.Player;
|
import latice.model.Player;
|
||||||
import latice.model.Shape;
|
import latice.model.Shape;
|
||||||
import latice.model.Tile;
|
import latice.model.Tile;
|
||||||
|
@ -53,18 +54,6 @@ import latice.model.window.RectangleFX;
|
||||||
|
|
||||||
public class LaticeApplicationWindow extends Application {
|
public class LaticeApplicationWindow extends Application {
|
||||||
|
|
||||||
private static final int NUMBER_OF_BOX_ON_ONE_LINE = 9;
|
|
||||||
|
|
||||||
private static final int RECTANGLE_HEIGHT = 50;
|
|
||||||
|
|
||||||
private static final int RECTANGLE_WIDTH = 50;
|
|
||||||
|
|
||||||
private static final int Y_CENTER = 37;
|
|
||||||
|
|
||||||
private static final int X_CENTER = 355;
|
|
||||||
|
|
||||||
private static final int BOX_WIDTH = 52;
|
|
||||||
|
|
||||||
javafx.scene.paint.Color realColor = new javafx.scene.paint.Color(0, 0, 0, 0);
|
javafx.scene.paint.Color realColor = new javafx.scene.paint.Color(0, 0, 0, 0);
|
||||||
|
|
||||||
Image image = new Image("backgroundLatice.png");
|
Image image = new Image("backgroundLatice.png");
|
||||||
|
@ -136,10 +125,10 @@ public class LaticeApplicationWindow extends Application {
|
||||||
Rectangle[][] r = new Rectangle[9][9];
|
Rectangle[][] r = new Rectangle[9][9];
|
||||||
int counterI = 0;
|
int counterI = 0;
|
||||||
int counterJ = 0;
|
int counterJ = 0;
|
||||||
for (int i=1; i<=NUMBER_OF_BOX_ON_ONE_LINE ; i++) {
|
for (int i=1; i<=Constant.NUMBER_OF_BOX_ON_ONE_LINE ; i++) {
|
||||||
for (int j=1; j <= NUMBER_OF_BOX_ON_ONE_LINE ; j++) {
|
for (int j=1; j <= Constant.NUMBER_OF_BOX_ON_ONE_LINE ; j++) {
|
||||||
|
|
||||||
r[counterI][counterJ] = new Rectangle(i*BOX_WIDTH+X_CENTER,j*BOX_WIDTH+Y_CENTER,RECTANGLE_WIDTH,RECTANGLE_HEIGHT);
|
r[counterI][counterJ] = new Rectangle(i*Constant.BOX_WIDTH+Constant.X_CENTER,j*Constant.BOX_WIDTH+Constant.Y_CENTER,Constant.RECTANGLE_WIDTH,Constant.RECTANGLE_HEIGHT);
|
||||||
r[counterI][counterJ].setFill(realColor.TRANSPARENT);
|
r[counterI][counterJ].setFill(realColor.TRANSPARENT);
|
||||||
pane.getChildren().add(r[counterI][counterJ]);
|
pane.getChildren().add(r[counterI][counterJ]);
|
||||||
System.out.println(r[counterI][counterJ]);
|
System.out.println(r[counterI][counterJ]);
|
||||||
|
@ -213,23 +202,25 @@ public class LaticeApplicationWindow extends Application {
|
||||||
|
|
||||||
|
|
||||||
//Confirm Button
|
//Confirm Button
|
||||||
Image checkMark = new Image("checkMark.png");
|
Image checkMark = new Image("checkMark.png");
|
||||||
ImageView checkMarkView = new ImageView(checkMark);
|
ImageView checkMarkView = new ImageView(checkMark);
|
||||||
Button confirmButton = new Button("Confirm", checkMarkView);
|
Button confirmButton = new Button("Confirm", checkMarkView);
|
||||||
|
confirmButton.setPrefWidth(Constant.ACTION_BUTTONS_WIDTH);
|
||||||
confirmButton.setOnMouseClicked(new EventHandler<MouseEvent>() {
|
confirmButton.setPrefHeight(Constant.ACTION_BUTTONS_HEIGHT);
|
||||||
|
|
||||||
|
confirmButton.setOnMouseClicked(new EventHandler<MouseEvent>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void handle(MouseEvent arg0) {
|
public void handle(MouseEvent arg0) {
|
||||||
|
|
||||||
|
|
||||||
System.out.println("confirmed placement");
|
System.out.println("confirmed placement");
|
||||||
|
|
||||||
validateBtnClickedCount++;
|
validateBtnClickedCount++;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
//With Image
|
//With Image
|
||||||
|
@ -241,7 +232,15 @@ public class LaticeApplicationWindow extends Application {
|
||||||
Image changeIconImage = new Image("changeIcon.png");
|
Image changeIconImage = new Image("changeIcon.png");
|
||||||
ImageView changeIconView = new ImageView(changeIconImage);
|
ImageView changeIconView = new ImageView(changeIconImage);
|
||||||
Button changeButton = new Button("Change Rack", changeIconView);
|
Button changeButton = new Button("Change Rack", changeIconView);
|
||||||
|
changeButton.setPrefWidth(Constant.ACTION_BUTTONS_WIDTH);
|
||||||
|
changeButton.setPrefHeight(Constant.ACTION_BUTTONS_HEIGHT);
|
||||||
|
|
||||||
|
//Buy another action Button
|
||||||
|
Image buyActionImage = new Image("buyAction.png");
|
||||||
|
ImageView buyActionView = new ImageView(buyActionImage);
|
||||||
|
Button buyActionButton = new Button("Buy Action", buyActionView);
|
||||||
|
buyActionButton.setPrefWidth(Constant.ACTION_BUTTONS_WIDTH);
|
||||||
|
buyActionButton.setPrefHeight(Constant.ACTION_BUTTONS_HEIGHT);
|
||||||
|
|
||||||
changeButton.setOnMouseClicked(new EventHandler<MouseEvent>() {
|
changeButton.setOnMouseClicked(new EventHandler<MouseEvent>() {
|
||||||
|
|
||||||
|
@ -254,15 +253,31 @@ public class LaticeApplicationWindow extends Application {
|
||||||
|
|
||||||
rackImage.getChildren().clear();
|
rackImage.getChildren().clear();
|
||||||
|
|
||||||
rackImage.getChildren().addAll(rack2.createTileImage(), confirmButton, changeButton);
|
rackImage.getChildren().addAll(rack2.createTileImage(), confirmButton, changeButton, buyActionButton);
|
||||||
|
|
||||||
//Setting drag n drop on tiles
|
//Setting drag n drop on tiles
|
||||||
setDragnDropOnRack(rackImage);
|
setDragnDropOnRack(rackImage);
|
||||||
}
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
rackImage.getChildren().addAll(confirmButton, changeButton);
|
|
||||||
borderPane.setBottom(rackImage);
|
buyActionButton.setOnMouseClicked(new EventHandler<MouseEvent>() {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(MouseEvent arg0) {
|
||||||
|
//TODO verify score and give another play()
|
||||||
|
/*if (player.getScore()>=3) {
|
||||||
|
//Donner une action supplémentaire et enlever 3 points au joueur
|
||||||
|
player.Play(play, board, 0);
|
||||||
|
player.diffScore(3);
|
||||||
|
}else {
|
||||||
|
System.out.println("Il vous faut 3 points pour acheter une nouvelle action !");
|
||||||
|
}*/
|
||||||
|
}
|
||||||
|
|
||||||
|
});
|
||||||
|
rackImage.getChildren().addAll(confirmButton, changeButton, buyActionButton);
|
||||||
|
root.setBottom(rackImage);
|
||||||
|
|
||||||
//Adding lists to Arraylists
|
//Adding lists to Arraylists
|
||||||
listRackTile = rack2.getListRackTile();
|
listRackTile = rack2.getListRackTile();
|
||||||
|
@ -288,8 +303,8 @@ public class LaticeApplicationWindow extends Application {
|
||||||
//------------------------------------------------------------------------
|
//------------------------------------------------------------------------
|
||||||
|
|
||||||
//Setting drag & drop on rectangles
|
//Setting drag & drop on rectangles
|
||||||
for(int i=0; i<NUMBER_OF_BOX_ON_ONE_LINE; i++) {
|
for(int i=0; i<Constant.NUMBER_OF_BOX_ON_ONE_LINE; i++) {
|
||||||
for(int j=0; j<NUMBER_OF_BOX_ON_ONE_LINE; j++) {
|
for(int j=0; j<Constant.NUMBER_OF_BOX_ON_ONE_LINE; j++) {
|
||||||
int a = i;
|
int a = i;
|
||||||
int b = j;
|
int b = j;
|
||||||
|
|
||||||
|
@ -343,8 +358,8 @@ public class LaticeApplicationWindow extends Application {
|
||||||
}else {
|
}else {
|
||||||
moonErrorLabel.setText("Error ! Please place the first tile on the moon");
|
moonErrorLabel.setText("Error ! Please place the first tile on the moon");
|
||||||
//removing all tiles from gameboard
|
//removing all tiles from gameboard
|
||||||
for(int i=0; i<NUMBER_OF_BOX_ON_ONE_LINE; i++) {
|
for(int i=0; i<Constant.NUMBER_OF_BOX_ON_ONE_LINE; i++) {
|
||||||
for(int j=0; j<NUMBER_OF_BOX_ON_ONE_LINE; j++) {
|
for(int j=0; j<Constant.NUMBER_OF_BOX_ON_ONE_LINE; j++) {
|
||||||
r[i][j].setFill(realColor.TRANSPARENT);
|
r[i][j].setFill(realColor.TRANSPARENT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -366,10 +381,37 @@ public class LaticeApplicationWindow extends Application {
|
||||||
|
|
||||||
//rules / referee implementaion
|
//rules / referee implementaion
|
||||||
|
|
||||||
//this.transition(namePlayer1, namePlayer2);
|
this.transition(namePlayer1, namePlayer2);
|
||||||
//root.setLeft(namePlayer1);
|
//root.setLeft(namePlayer1);
|
||||||
|
|
||||||
|
//###################### display name, score and deck of each player ######################//
|
||||||
|
HBox players = new HBox();
|
||||||
|
|
||||||
|
ArrayList<Player> allPlayers = new ArrayList<>();
|
||||||
|
allPlayers.add(player1);
|
||||||
|
allPlayers.add(player2);
|
||||||
|
|
||||||
|
for (Player nameplayer : allPlayers ) {
|
||||||
|
VBox player = new VBox();
|
||||||
|
|
||||||
|
Text name = new Text();
|
||||||
|
name.setFont(Font.font(nameplayer.getName(), FontWeight.BOLD, 20));
|
||||||
|
name.setText(nameplayer.getName());
|
||||||
|
|
||||||
|
Text score = new Text();
|
||||||
|
score.setText("Score : ");
|
||||||
|
|
||||||
|
Text nbrOfTiles = new Text();
|
||||||
|
nbrOfTiles.setText("Tuiles restantes : ");
|
||||||
|
|
||||||
|
player.getChildren().addAll(name, score, nbrOfTiles);
|
||||||
|
player.setSpacing(5);
|
||||||
|
|
||||||
|
players.getChildren().add(player);
|
||||||
|
players.setMargin(player, new Insets(50,0,0,55));
|
||||||
|
}
|
||||||
|
System.out.println("largeur : " + root.getMaxWidth());
|
||||||
|
players.setSpacing(850);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -402,6 +444,7 @@ public class LaticeApplicationWindow extends Application {
|
||||||
//Setting drag n drop on tiles
|
//Setting drag n drop on tiles
|
||||||
for (int i=0; i<5; i++) {
|
for (int i=0; i<5; i++) {
|
||||||
int a = i;
|
int a = i;
|
||||||
|
System.out.println(a);
|
||||||
rackImage.getChildren().get(a).setOnDragDetected(new EventHandler<MouseEvent>() {
|
rackImage.getChildren().get(a).setOnDragDetected(new EventHandler<MouseEvent>() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -474,4 +517,4 @@ public class LaticeApplicationWindow extends Application {
|
||||||
borderPane.setRight(player2);
|
borderPane.setRight(player2);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,7 +1,6 @@
|
||||||
package latice.model;
|
package latice.model;
|
||||||
|
|
||||||
public class Constant {
|
public class Constant {
|
||||||
|
|
||||||
//for creating rectangles
|
//for creating rectangles
|
||||||
public static final int NUMBER_OF_BOX_ON_ONE_LINE = 9;
|
public static final int NUMBER_OF_BOX_ON_ONE_LINE = 9;
|
||||||
|
|
||||||
|
@ -15,5 +14,8 @@ public class Constant {
|
||||||
|
|
||||||
public static final int BOX_WIDTH = 52;
|
public static final int BOX_WIDTH = 52;
|
||||||
|
|
||||||
|
public static final int ACTION_BUTTONS_WIDTH = 120;
|
||||||
|
|
||||||
|
public static final int ACTION_BUTTONS_HEIGHT = 45;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 569 B |
|
@ -1,20 +1,20 @@
|
||||||
package latice;
|
package latice;
|
||||||
|
|
||||||
|
import static org.assertj.core.api.Assertions.assertThat;
|
||||||
import static org.junit.jupiter.api.Assertions.assertEquals;
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
|
||||||
import org.junit.jupiter.api.Test;
|
import org.junit.jupiter.api.Test;
|
||||||
import static org.assertj.core.api.Assertions.*;
|
|
||||||
|
|
||||||
import latice.model.Color;
|
import latice.model.Color;
|
||||||
import latice.model.Deck;
|
|
||||||
import latice.model.Player;
|
import latice.model.Player;
|
||||||
import latice.model.Position;
|
import latice.model.Position;
|
||||||
import latice.model.Rack;
|
|
||||||
import latice.model.Score;
|
|
||||||
import latice.model.Shape;
|
import latice.model.Shape;
|
||||||
import latice.model.Tile;
|
import latice.model.Tile;
|
||||||
|
import latice.model.console.Deck;
|
||||||
|
import latice.model.console.Rack;
|
||||||
|
import latice.model.console.Score;
|
||||||
|
|
||||||
class LaticeTest {
|
class LaticeTest {
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue