diff --git a/.idea/misc.xml b/.idea/misc.xml
index 81d2261..f6eb85c 100644
--- a/.idea/misc.xml
+++ b/.idea/misc.xml
@@ -1,5 +1,8 @@
-
+
+
+
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
new file mode 100644
index 0000000..fc1a162
--- /dev/null
+++ b/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/modules/app/Tetris.app.main.iml b/.idea/modules/app/Tetris.app.main.iml
new file mode 100644
index 0000000..59eb4e8
--- /dev/null
+++ b/.idea/modules/app/Tetris.app.main.iml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/allfiles.txt b/allfiles.txt
new file mode 100644
index 0000000..e14d775
--- /dev/null
+++ b/allfiles.txt
@@ -0,0 +1,157 @@
+275d761f246129253df1ecbc84c42c35f60daacc
+43037c4174ec4d9e98e904411c9f74ca17aee21a
+47908588e5d785be85631bcd14b437e073c2da36
+5a175ea4b487bdcf281e44e7b99629fc6a10848f
+63d5db5d6a80b960acd8bc31900ff1d01ae0a2a2
+6af84d8dda24e9a9155c9ad7144741702bbaa549
+7fb2becbb8fe125a9f592261924edda56e8eeef5
+9ad9193244d045a470ecd64b60d4b35da2301432
+b2649c364bf9bc52d52d609bc617c3ecff92197d
+f2eefabf58c718cbb700c9f7c9d1995f8c8825e6
+f9e3f1d2bba52b83d8bdb909ca2f685fd71a744c
+285a6fb90cd7243ccd0ebebdf0cc2cca3c6bbbe1
+34263085a001ecadcfc1482626b46f83b6c20230
+45764cdbc8e10a6d15248879b93e1dac505a444f
+7ecfdbc428688744005e1e6508bbcdf1757dd15b
+909dd2ba4b865549dac622980e05dd151a3078b2
+a35eade7d2fa03ac949b5313f01dcee83ca633cb
+b6b766eb03672730c856c6e6bde033321725a0ca
+b7f2a91f1d721fa17cc5dfaedb0c974a95db7f00
+b8980c6c2563f506f4c8fd26d44c82633e9b7bd0
+d5ea9b146c667cb7532effc060ef5afeac6ca80f
+e08921e14ca9ccb6adf89e5571e9140e44083cec
+f91f64602e6c6d892d70d71f4fc7a1bd943e23f3 .gitattributes
+436814bbf32f9cd78b3e88d1efde3880f48a3722 .gitignore
+edeba0a94c7c5a4bc4fbf5050e4b002323cc53f8 .gitignore
+228c629ac9a3448c664ca45fafa6afc681bcc533 .idea
+37c4a554cbf14f435db2eb43fd93b5314572a268 .idea
+67509bba335fc9098edc0f0fefca36544f0993ab .idea
+13566b81b018ad684f3a35fee301741b2734c8f4 .idea/.gitignore
+b86273d9424b73937ca6ad7933f6b7eeb60f4a3d .idea/compiler.xml
+3ced4eb7f9aa8e29aa4ab8cef00e2d62fb02b5e7 .idea/gradle.xml
+efd7cbf42e288c4de536a66dd5b6c6b401e63106 .idea/gradle.xml
+81d226132f2c293f23e938d1b088f3c00abc1686 .idea/misc.xml
+cf69fd4d67b426c9addf9d150be9cb736c001cad .idea/misc.xml
+d0f6ad47ffb00c0485911ecce8edf6ce7f28a477 .idea/modules
+fc1a1629b999aebe7d72c4239be6a9594508ee4b .idea/modules.xml
+007377fa005f8849275ecd3a4e57c083a95dde0f .idea/modules/app
+59eb4e8e7a4cde1845c2d12df2f5f887b3775a66 .idea/modules/app/Tetris.app.main.iml
+35eb1ddfbbc029bcab630581847471d7f238ec53 .idea/vcs.xml
+cf6b1e6b33b8ef5fee1ade2b99451bd7fb353e05 README.md
+e51a4c4f28fcdb8dc3f30efbfccf6e27e8e1fa14 README.md
+59e98406bf40d0fc19383388e7e80a5aadc26b81 app
+7b72780fd3dc796f13794bd100b0d58f48d7475e app
+933bfae3d434ba0127e5b513ca480397a9ba65a7 app
+9e4d904d3435b169f373d754fbdba260b386ecc6 app
+bdd0722cc2a4b143a1fa80624fd89ffb18001bdd app
+bdff75013af2bf7dc8f39bddc5f31f9ff234e3ef app
+d56532df58c46a44d915841fac86442cc994e5c2 app
+d8005883a27c854a1ff5528f37fc31a2e6541f8c app
+f97f03f5a0009680ba76eb8c333ddb9682fcc018 app
+fc7b1685b65c03b37b4d1bff9e7c4f347ce60ec4 app
+4e42499269f4de4ad25f8848a93050899b0e635c app/build.gradle.kts
+7761afadf778e47f1fc11a2bf5669773f29878c2 app/build.gradle.kts
+180251199dad9ccae5cc7ae13f357c98c5540e55 app/src
+3205c8924784b745bd8f5be1a26860b31b02f358 app/src
+560f85b087f3a7f6575b2c61a990aba403c0f4f0 app/src
+9e06263aea629f172fae7bc28eabeb57c14e5888 app/src
+a841045b330012fe0ecfa98b3f7b8d18111580d3 app/src
+a8b74c7c83b6e75cafbc4b8e0bc800c6b8521fa9 app/src
+aaff9850f38268a091376a0eef7967905188cf09 app/src
+bcfb14fb711fd14be5b1b8076a5efda37080ee0f app/src
+f007f0237ca71e800d7db8c34635ad110f42c75d app/src
+fe1bc10fb27f438ca79efd429ea5a521e41bc9bc app/src
+04db8c7235d24702994df1957291fff8faf2bd46 app/src/main
+0902215393bce49dfa3ecd0aa5f0e1c584386b12 app/src/main
+3a89ac8d4d833265aa9595c8a5d80de16ee962b3 app/src/main
+7834d89164faa50d5036abbc6238aebeba39e2b3 app/src/main
+825b72903c75ee3a43c50957297febc6f8454abf app/src/main
+85a2d198317a8c23d4cbddecebcb014a7eed2a8c app/src/main
+a4b085629a56c63578bf37d857207c69655c8998 app/src/main
+ac1f499f8f6a6cff37760c64c365e747517a6a2d app/src/main
+c307f9ff858ab68ca5885db0ff7bcde889ecf069 app/src/main
+fa83d5052bfb6ac895b870389976d78235a19ed0 app/src/main
+406bae490815756155b3fa74894ac90af4729d55 app/src/main/java
+46e9f38431f8d2dd63dbf85ccf00ed7d30a7aa07 app/src/main/java
+47ebae455de4f74aebeda3b61c39f6de7dc5787c app/src/main/java
+87258211368f0099c706bb9bc7672a1f2c13314a app/src/main/java
+b6258a0cd88de47ecc461c7a95e3d7d84aad076c app/src/main/java
+bd90ebf3aec01671e777f3b504bdefad7da095f4 app/src/main/java
+d8f563bb6df5415260ee68915fccf1ca17a08601 app/src/main/java
+e279b50ac5fa998111f2e8fa7ac7efe3352f6632 app/src/main/java
+e5f3aa2866dce3d75db8479d1907bc35bc858fd4 app/src/main/java
+fbb230cd6058cc92bc2c672f672526b4fcc9637e app/src/main/java
+46b2a66453905c875d568305525afa60370730aa app/src/main/java/org
+48ec3dd6b23ac5c38e273f4e1d65428a21b7df9c app/src/main/java/org
+5faf95a17c62b60da2c4fe796f803d4bffc9c7a0 app/src/main/java/org
+7fc649a4d65844dc0db5098249d401b7adb0d6d4 app/src/main/java/org
+9559f15394becd850d5e817c90d0db96b99cee9b app/src/main/java/org
+b5c48c1995f4fb6f62e75d07d2030d9547a57a33 app/src/main/java/org
+bba960b198ee13c0f5d73372ccfd70d205ff6417 app/src/main/java/org
+d41e5945ee49818da4f5bfdab5d9e47368bf2a2c app/src/main/java/org
+dba0b55f00404e964d0b2c2295972c485b8ca743 app/src/main/java/org
+df2516764274971681cefdbfa00815210623e49f app/src/main/java/org
+0267e55f9afebc7ccd00cfbc497deca998df0453 app/src/main/java/org/App.java
+21004147fd711cd40f11146345ba5cb3dd846f12 app/src/main/java/org/App.java
+b4c4a7a3acefffa1035e72d70b937e5be85cbc66 app/src/main/java/org/App.java
+38d0aa6cb8a953654b787eb0cc3cee103fcc50c4 app/src/main/java/org/Controlers
+fb3ca2a75dca5f0607fa13b3ddfec119a764c9d0 app/src/main/java/org/Controlers/MusiqueControleur.java
+4377bdeadf3c1f0c7d58e32ddee2a2b0306f6918 app/src/main/java/org/Controlers/TetrisControleur.java
+31741b0eb81f9f55a0834f166071e777b8517f4e app/src/main/java/org/Models
+d0b53e04d1008d05417864bdbb79e72f84acc412 app/src/main/java/org/Models
+d12a4a85b4ffb4b14cb67503aa5c4ee994acdd91 app/src/main/java/org/Models
+d930a9b6229347676698aa95277782f9d377fa8b app/src/main/java/org/Models
+ec027e6b7978ccc38c30e75866fa3c24bd8f5e1e app/src/main/java/org/Models
+f4acf157438fbc994f8845263530815e1b652655 app/src/main/java/org/Models
+0d5767fc1455d0d0dd14775c16ba7d7e5ad3e477 app/src/main/java/org/Models/Grille.java
+7ac21e234e5bbcb1a2b4d85473cc86413a68de4a app/src/main/java/org/Models/Grille.java
+25c029e912b2f49c5d614e7a40421bde7eb763d5 app/src/main/java/org/Models/Jeu.java
+08c51b0b9a17c2f37ee423d3a4e7a82015ffccb9 app/src/main/java/org/Models/PieceCourante.java
+2d3c532f5745ae24cfe2f557c36ac472058ee21c app/src/main/java/org/Models/PieceCourante.java
+86d1530bb33c6c4c9538aa494d5c55383267adaa app/src/main/java/org/Models/PieceCourante.java
+cdaf4968517482a45cce64caa7b001da3ef543b3 app/src/main/java/org/Models/PieceI.java
+57a7d9ff57ac32f5fa4e4035e0988cc589d2019b app/src/main/java/org/Models/PieceJ.java
+0e81a40d602f3a4f721834547d6985efa9e293ee app/src/main/java/org/Models/PieceL.java
+226a9b0516575ffc65901159acef8de04e8a21c5 app/src/main/java/org/Models/PieceL.java
+284565182bf9b4564dec8ad696c0576bce0e0217 app/src/main/java/org/Models/PieceL.java
+737375d02b8e61cf3b65d2d8d0ac608b4a26ae66 app/src/main/java/org/Models/PieceL.java
+9f6680ef25242cbf0578899edd62ecd1ab24f8af app/src/main/java/org/Models/PieceO.java
+316ddf03e2f5c3f008e686ad89b558d6032782b0 app/src/main/java/org/Models/PieceS.java
+d1c2e8eaa383a1be7e6dc8c753e138e0445066f5 app/src/main/java/org/Models/PieceT.java
+c8f6b30308d9de6357427dc89034bb005380dfe1 app/src/main/java/org/Models/PieceZ.java
+061b4848f6b663bb07fce79f94328db80436578d app/src/main/java/org/Views
+0ce912db8ac48c9daa1ddeacd52cf32ad91f21d8 app/src/main/java/org/Views
+1d7329f5dcae721ae288de4897f7ce91b633dccd app/src/main/java/org/Views
+1e947b07a51e3a5a68dd4e7927361bbfc3588cd7 app/src/main/java/org/Views
+3e9d2a47453a976b57f7d220abaa0bf363ad603d app/src/main/java/org/Views
+b0c5f7464ff2de1cd5020082e113923d73dc215a app/src/main/java/org/Views
+dd2984e67126b93efff053ee738158497b0c59dd app/src/main/java/org/Views
+0a74b7c91004bf8df974ad51a78488fba4ba725d app/src/main/java/org/Views/VueControle.java
+9bbadde40fcf92b615223508f2eaa4ec884700b2 app/src/main/java/org/Views/VueControle.java
+ecf3e5e7beff66c0fbf92639794f4879b3b54ea1 app/src/main/java/org/Views/VueControle.java
+4af98386b8404e99248f3e607754f1b1ff2d7c5e app/src/main/java/org/Views/VueGrille.java
+7358e68c8f6ef7f5f1566c5679da2dbd358cd7a8 app/src/main/java/org/Views/VueGrille.java
+eeb4c236c10bb7bf6f457abe1b7f2cb895294967 app/src/main/java/org/Views/VueGrille.java
+1c8f92d5442c0e29cffc9efb0bd220f702bb4c70 app/src/main/java/org/Views/VueTetris.java
+9bea88db10d1104245a639fbdfc36d5ce5b3996e app/src/main/java/org/Views/VueTetris.java
+a0fcdf9cd80ca09bb2e752b62600bb5b52525c87 app/src/main/java/org/Views/VueTetris.java
+b9c58474b464a49fd2363102da7610b0f14b8789 app/src/main/java/org/Views/VueTetris.java
+8f6480b8461fa38be6423a9843811a17dc792d37 app/src/main/resources
+33f3440505856889eaca7a07c2b95de223c05962 app/src/main/resources/TetrisMusic.wav
+2c4404f3029e26336e3c520686429d66a49d62f7 app/src/test
+a8f00d3495d40e504c8ad30f8ea431be1371bb42 app/src/test/java
+edc54f19667ec12b3325ae8418a318d2995b7f7f app/src/test/java/org
+d73c43ece67b0651f4f602eadd5e5136fc7bbd77 app/src/test/java/org/example
+998c02900d09b9572eff2e9fe488146010da28fb app/src/test/java/org/example/AppTest.java
+723ca3a32bfd03239e931f38ae071989f1e17d37 gradle
+377538c9965c6177781d5bbf1fdc2644e77d7950 gradle.properties
+f5172b8e111dc2d56e4d73a30629ae7b35086711 gradle/libs.versions.toml
+35fcf56b0a312bb6d76f3be24e580ec5ecd912df gradle/wrapper
+1b33c55baabb587c669f562ae36f953de2481846 gradle/wrapper/gradle-wrapper.jar
+ca025c83a7cc5e4f5eb7bc7a5ff8cae62df35ffb gradle/wrapper/gradle-wrapper.properties
+23d15a9367071145e9c79bb4ddf879d1fbe78b5d gradlew
+db3a6ac207e507b0bc1635a9f2c18d3b174e682e gradlew.bat
+489872589b67af275bb7e2a96ec926b831e1dbc0 readme_files
+3e51bb76143fcc8580ba88e2fb05df47ef0335df readme_files/ProjetEncadréTetris.pdf
+b8db60d529f7cf31077a8a6b442a20395f32c592 readme_files/activiteTetris.svg
+2f84576889e655dc28783d875bf1189708a4d3fc settings.gradle.kts
diff --git a/app/build.gradle.kts b/app/build.gradle.kts
index 4e42499..96e0bbc 100644
--- a/app/build.gradle.kts
+++ b/app/build.gradle.kts
@@ -23,6 +23,10 @@ dependencies {
// This dependency is used by the application.
implementation(libs.guava)
+
+ // 🔊 JLayer pour lire les fichiers MP3
+ implementation("javazoom:jlayer:1.0.1")
+
}
// Apply a specific Java toolchain to ease working on different environments.
diff --git a/app/src/main/java/org/App.java b/app/src/main/java/org/App.java
index 0267e55..8a9cf90 100644
--- a/app/src/main/java/org/App.java
+++ b/app/src/main/java/org/App.java
@@ -14,7 +14,5 @@ public class App {
Grille grille = new Grille(10, 10);
//VueGrille vueGrille = new VueGrille(grille);
VueTetris vueTetris = new VueTetris(grille);
-
-
}
}
\ No newline at end of file
diff --git a/app/src/main/java/org/Controlers/TetrisControleur.java b/app/src/main/java/org/Controlers/TetrisControleur.java
new file mode 100644
index 0000000..ef1f891
--- /dev/null
+++ b/app/src/main/java/org/Controlers/TetrisControleur.java
@@ -0,0 +1,50 @@
+package org.Controlers;
+
+import org.Models.Musique;
+import org.Views.VueControle;
+
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+
+public class TetrisControleur {
+ private boolean partieEnPause = false;
+ private boolean partieTerminee = false;
+ private Musique musique;
+ private VueControle vueControle;
+
+ public TetrisControleur(VueControle vueControle) {
+ this.vueControle = vueControle;
+ this.musique = new Musique();
+ musique.start();//demarer musique
+ //action play/pause
+ this.vueControle.getPauseButton().addActionListener(new ActionListener() {
+ @Override
+ public void actionPerformed(ActionEvent e) {
+ switchPlayPause();
+ }
+ });
+ vueControle.getQuitterButton().addActionListener(e -> {
+ System.out.println("Fermeture de l'application...");
+ System.exit(0);
+ });
+
+ }
+
+ public void switchPlayPause() {
+ if (partieTerminee) {
+ return;
+ }
+ partieEnPause = !partieEnPause;
+ musique.basculePlayPause();
+ vueControle.getPauseButton().setText(partieEnPause ? "PLAY" : "PAUSE");
+ System.out.println(partieEnPause ? "Partie en pause" : "Partie en cours");
+ }
+
+ public void setPartieTerminee() {
+ partieTerminee = true;
+ musique.arreterMusique();
+ vueControle.getPauseButton().setEnabled(false);
+ System.out.println("Partie terminée");
+ }
+
+}
diff --git a/app/src/main/java/org/Models/Musique.java b/app/src/main/java/org/Models/Musique.java
new file mode 100644
index 0000000..3e6babe
--- /dev/null
+++ b/app/src/main/java/org/Models/Musique.java
@@ -0,0 +1,52 @@
+package org.Models;
+
+import javazoom.jl.player.Player;
+
+import java.io.BufferedInputStream;
+import java.io.InputStream;
+
+public class Musique extends Thread{
+ private Player player;
+ private boolean stop = false;
+ private boolean enPause = false;
+
+ public void run(){
+ while (!stop) {
+ try {
+ if (!enPause) {
+ InputStream musique = getClass().getResourceAsStream("/TetrisMusic.mp3");
+ //System.out.println(musique != null ? "Musique trouvée" : "Musique introuvable");
+ if (musique == null) {
+ System.err.println("Erreur : le fichier musique.mp3 est introuvable.");
+ return;
+ }
+ BufferedInputStream buffer = new BufferedInputStream(musique);
+ player = new Player(buffer);
+ player.play();
+ } else {
+ Thread.sleep(1000); // Attendre 1 seconde avant de vérifier à nouveau
+ }
+ } catch (Exception e) {
+ System.err.println("Erreur lors de la lecture de la musique : " + e.getMessage());
+ }
+ }
+ }
+
+ public void basculePlayPause() {
+ if (enPause) {
+ enPause = false;
+ } else {
+ enPause = true;
+ if (player != null) {
+ player.close();
+ }
+ }
+ }
+
+ public void arreterMusique() {
+ stop = true;
+ if (player != null) {
+ player.close();
+ }
+ }
+}
diff --git a/app/src/main/java/org/Models/PieceI.java b/app/src/main/java/org/Models/PieceI.java
new file mode 100644
index 0000000..cdaf496
--- /dev/null
+++ b/app/src/main/java/org/Models/PieceI.java
@@ -0,0 +1,17 @@
+package org.Models;
+
+public class PieceI extends PieceCourante {
+
+ public PieceI(){
+ super();
+ this.motif[0][1] = true;
+ this.motif[1][1] = true;
+ this.motif[2][1] = true;
+ this.motif[3][1] = true;
+ }
+
+ @Override
+ public boolean[][] getMotif() {
+ return super.getMotif();
+ }
+}
diff --git a/app/src/main/java/org/Models/PieceJ.java b/app/src/main/java/org/Models/PieceJ.java
new file mode 100644
index 0000000..57a7d9f
--- /dev/null
+++ b/app/src/main/java/org/Models/PieceJ.java
@@ -0,0 +1,17 @@
+package org.Models;
+
+public class PieceJ extends PieceCourante {
+
+ public PieceJ(){
+ super();
+ this.motif[0][2] = true;
+ this.motif[1][2] = true;
+ this.motif[2][2] = true;
+ this.motif[2][1] = true;
+ }
+
+ @Override
+ public boolean[][] getMotif() {
+ return super.getMotif();
+ }
+}
diff --git a/app/src/main/java/org/Models/PieceL.java b/app/src/main/java/org/Models/PieceL.java
index 0e81a40..737375d 100644
--- a/app/src/main/java/org/Models/PieceL.java
+++ b/app/src/main/java/org/Models/PieceL.java
@@ -4,10 +4,11 @@ public class PieceL extends PieceCourante {
public PieceL(){
super();
- this.motif[1][0] = true;
- this.motif[2][0] = true;
- this.motif[3][0] = true;
- this.motif[3][1] = true;
+ this.motif[0][1] = true;
+ this.motif[1][1] = true;
+ this.motif[2][1] = true;
+ this.motif[2][2] = true;
+
}
@Override
diff --git a/app/src/main/java/org/Models/PieceO.java b/app/src/main/java/org/Models/PieceO.java
new file mode 100644
index 0000000..9f6680e
--- /dev/null
+++ b/app/src/main/java/org/Models/PieceO.java
@@ -0,0 +1,16 @@
+package org.Models;
+
+public class PieceO extends PieceCourante{
+ public PieceO(){
+ super();
+ this.motif[0][1] = true;
+ this.motif[0][2] = true;
+ this.motif[1][1] = true;
+ this.motif[1][2] = true;
+ }
+
+ @Override
+ public boolean[][] getMotif() {
+ return super.getMotif();
+ }
+}
diff --git a/app/src/main/java/org/Models/PieceS.java b/app/src/main/java/org/Models/PieceS.java
new file mode 100644
index 0000000..316ddf0
--- /dev/null
+++ b/app/src/main/java/org/Models/PieceS.java
@@ -0,0 +1,17 @@
+package org.Models;
+
+public class PieceS extends PieceCourante {
+
+ public PieceS(){
+ super();
+ this.motif[0][1] = true;
+ this.motif[1][1] = true;
+ this.motif[1][2] = true;
+ this.motif[2][2] = true;
+ }
+
+ @Override
+ public boolean[][] getMotif() {
+ return super.getMotif();
+ }
+}
diff --git a/app/src/main/java/org/Models/PieceT.java b/app/src/main/java/org/Models/PieceT.java
new file mode 100644
index 0000000..d1c2e8e
--- /dev/null
+++ b/app/src/main/java/org/Models/PieceT.java
@@ -0,0 +1,17 @@
+package org.Models;
+
+public class PieceT extends PieceCourante {
+
+ public PieceT(){
+ super();
+ this.motif[0][1] = true;
+ this.motif[1][1] = true;
+ this.motif[2][1] = true;
+ this.motif[1][2] = true;
+ }
+
+ @Override
+ public boolean[][] getMotif() {
+ return super.getMotif();
+ }
+}
diff --git a/app/src/main/java/org/Models/PieceZ.java b/app/src/main/java/org/Models/PieceZ.java
new file mode 100644
index 0000000..c8f6b30
--- /dev/null
+++ b/app/src/main/java/org/Models/PieceZ.java
@@ -0,0 +1,17 @@
+package org.Models;
+
+public class PieceZ extends PieceCourante {
+
+ public PieceZ(){
+ super();
+ this.motif[0][2] = true;
+ this.motif[1][2] = true;
+ this.motif[1][1] = true;
+ this.motif[2][1] = true;
+ }
+
+ @Override
+ public boolean[][] getMotif() {
+ return super.getMotif();
+ }
+}
diff --git a/app/src/main/java/org/Views/VueControle.java b/app/src/main/java/org/Views/VueControle.java
index ecf3e5e..5d5801a 100644
--- a/app/src/main/java/org/Views/VueControle.java
+++ b/app/src/main/java/org/Views/VueControle.java
@@ -10,6 +10,8 @@ public class VueControle extends JPanel {
private JPanel nextPiecePanel;
private JButton pauseButton;
private JPanel[][] caseNextPiece = new JPanel[4][4];
+ private JLabel nbLigneLabel;
+ private JButton quitterButton;
public VueControle() {
setLayout(new BoxLayout(this, BoxLayout.Y_AXIS));
@@ -17,11 +19,17 @@ public class VueControle extends JPanel {
setPreferredSize(new Dimension(200, 600));
//SCORE
- scoreLabel = new JLabel("Score: 0");
+ scoreLabel = new JLabel("SCORE : 0");
scoreLabel.setForeground(Color.white);
scoreLabel.setFont(new Font("Arial", Font.PLAIN, 16));
scoreLabel.setAlignmentX(Component.CENTER_ALIGNMENT);
+ //NB LIGNE
+ nbLigneLabel = new JLabel("LIGNES : 0");
+ nbLigneLabel.setForeground(Color.white);
+ nbLigneLabel.setFont(new Font("Arial", Font.PLAIN, 16));
+ nbLigneLabel.setAlignmentX(Component.CENTER_ALIGNMENT);
+
//NEXT PIECE
nextPiecePanel = new JPanel();
nextPiecePanel.setPreferredSize(new Dimension(100, 100));
@@ -30,16 +38,24 @@ public class VueControle extends JPanel {
nextPiecePanel.setAlignmentX(Component.CENTER_ALIGNMENT);
initierNextPiecePanel();
- //PAUSE BUTTON
- pauseButton = new JButton("Pause / Play");
- pauseButton.setAlignmentX(Component.CENTER_ALIGNMENT);
+ //PAUSE BUTTON & QUIT BUTTON
+ pauseButton = new JButton("PAUSE");
+ quitterButton = new JButton("QUITTER");
+ JPanel boutonsPanel = new JPanel();
+ boutonsPanel.setLayout(new FlowLayout(FlowLayout.CENTER, 10, 0));
+ boutonsPanel.setOpaque(false);
+ boutonsPanel.add(pauseButton);
+ boutonsPanel.add(quitterButton);
- add(Box.createVerticalStrut(20)); // Add some space at the top
+
+ add(Box.createVerticalStrut(20));
add(scoreLabel);
- add(Box.createVerticalStrut(20)); // Add some space between score and next piece
+ add(Box.createVerticalStrut(20));
+ add(nbLigneLabel);
+ add(Box.createVerticalStrut(20));
add(nextPiecePanel);
- add(Box.createVerticalStrut(20)); // Add some space between next piece and button
- add(pauseButton);
+ add(Box.createVerticalStrut(20));
+ add(boutonsPanel);
//setVisible(true);
}
@@ -52,6 +68,10 @@ public class VueControle extends JPanel {
return pauseButton;
}
+ public JButton getQuitterButton() {
+ return quitterButton;
+ }
+
public JPanel getNextPiecePanel() {
return nextPiecePanel;
}
diff --git a/app/src/main/java/org/Views/VueTetris.java b/app/src/main/java/org/Views/VueTetris.java
index a0fcdf9..b9c5847 100644
--- a/app/src/main/java/org/Views/VueTetris.java
+++ b/app/src/main/java/org/Views/VueTetris.java
@@ -1,8 +1,7 @@
package org.Views;
-import org.Models.Grille;
-import org.Models.PieceCourante;
-import org.Models.PieceL;
+import org.Controlers.TetrisControleur;
+import org.Models.*;
import javax.swing.*;
import java.awt.*;
@@ -13,6 +12,7 @@ public class VueTetris extends JFrame {
VueGrille vueGrille = new VueGrille(grille);
VueControle vueControle = new VueControle();
+ TetrisControleur controleur = new TetrisControleur(vueControle);
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setLayout(new BorderLayout());
@@ -25,7 +25,7 @@ public class VueTetris extends JFrame {
setVisible(true);
// Utilisation de la pièce L
- PieceCourante pieceL = new PieceL();
- vueControle.afficherPieceSuivante(pieceL);
+ PieceCourante pieceT = new PieceT();
+ vueControle.afficherPieceSuivante(pieceT);
}
}
diff --git a/app/src/main/resources/TetrisMusic.mp3 b/app/src/main/resources/TetrisMusic.mp3
new file mode 100644
index 0000000..6000053
Binary files /dev/null and b/app/src/main/resources/TetrisMusic.mp3 differ