forked from menault/TD3_DEV51_Qualite_Algo
Compare commits
5 Commits
5336077fc4
...
master
Author | SHA1 | Date | |
---|---|---|---|
9512df6c58 | |||
07c0e435be | |||
c87527973e | |||
843043740c | |||
2f3a6df740 |
38
.gitignore
vendored
Normal file
38
.gitignore
vendored
Normal file
@@ -0,0 +1,38 @@
|
||||
target/
|
||||
!.mvn/wrapper/maven-wrapper.jar
|
||||
!**/src/main/**/target/
|
||||
!**/src/test/**/target/
|
||||
|
||||
### IntelliJ IDEA ###
|
||||
.idea/modules.xml
|
||||
.idea/jarRepositories.xml
|
||||
.idea/compiler.xml
|
||||
.idea/libraries/
|
||||
*.iws
|
||||
*.iml
|
||||
*.ipr
|
||||
|
||||
### Eclipse ###
|
||||
.apt_generated
|
||||
.classpath
|
||||
.factorypath
|
||||
.project
|
||||
.settings
|
||||
.springBeans
|
||||
.sts4-cache
|
||||
|
||||
### NetBeans ###
|
||||
/nbproject/private/
|
||||
/nbbuild/
|
||||
/dist/
|
||||
/nbdist/
|
||||
/.nb-gradle/
|
||||
build/
|
||||
!**/src/main/**/build/
|
||||
!**/src/test/**/build/
|
||||
|
||||
### VS Code ###
|
||||
.vscode/
|
||||
|
||||
### Mac OS ###
|
||||
.DS_Store
|
6
.idea/vcs.xml
generated
Normal file
6
.idea/vcs.xml
generated
Normal file
@@ -0,0 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="VcsDirectoryMappings">
|
||||
<mapping directory="" vcs="Git" />
|
||||
</component>
|
||||
</project>
|
52
.idea/workspace.xml
generated
Normal file
52
.idea/workspace.xml
generated
Normal file
@@ -0,0 +1,52 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project version="4">
|
||||
<component name="ChangeListManager">
|
||||
<list default="true" id="8fb861b5-29c0-47e2-a838-348dc02d9dc0" name="Changes" comment="" />
|
||||
<option name="SHOW_DIALOG" value="false" />
|
||||
<option name="HIGHLIGHT_CONFLICTS" value="true" />
|
||||
<option name="HIGHLIGHT_NON_ACTIVE_CHANGELIST" value="false" />
|
||||
<option name="LAST_RESOLUTION" value="IGNORE" />
|
||||
</component>
|
||||
<component name="ComposerSettings">
|
||||
<execution />
|
||||
</component>
|
||||
<component name="Git.Settings">
|
||||
<option name="RECENT_GIT_ROOT_PATH" value="$PROJECT_DIR$" />
|
||||
</component>
|
||||
<component name="ProjectColorInfo"><![CDATA[{
|
||||
"associatedIndex": 0
|
||||
}]]></component>
|
||||
<component name="ProjectId" id="33mEzzBwtK7Ze4qzSZYMoaUAwYr" />
|
||||
<component name="ProjectViewState">
|
||||
<option name="hideEmptyMiddlePackages" value="true" />
|
||||
<option name="showLibraryContents" value="true" />
|
||||
</component>
|
||||
<component name="PropertiesComponent"><![CDATA[{
|
||||
"keyToString": {
|
||||
"ModuleVcsDetector.initialDetectionPerformed": "true",
|
||||
"RunOnceActivity.ShowReadmeOnStart": "true",
|
||||
"RunOnceActivity.git.unshallow": "true",
|
||||
"git-widget-placeholder": "master",
|
||||
"last_opened_file_path": "C:/Users/rapha/Documents/Depo/TD3_DEV51_Bridja_Creuzet_Hochlaf",
|
||||
"vue.rearranger.settings.migration": "true"
|
||||
}
|
||||
}]]></component>
|
||||
<component name="SharedIndexes">
|
||||
<attachedChunks>
|
||||
<set>
|
||||
<option value="bundled-jdk-9823dce3aa75-bf35d07a577b-intellij.indexing.shared.core-IU-252.26830.84" />
|
||||
</set>
|
||||
</attachedChunks>
|
||||
</component>
|
||||
<component name="TaskManager">
|
||||
<task active="true" id="Default" summary="Default task">
|
||||
<changelist id="8fb861b5-29c0-47e2-a838-348dc02d9dc0" name="Changes" comment="" />
|
||||
<created>1759914117184</created>
|
||||
<option name="number" value="Default" />
|
||||
<option name="presentableId" value="Default" />
|
||||
<updated>1759914117184</updated>
|
||||
<workItem from="1759914119706" duration="22000" />
|
||||
</task>
|
||||
<servers />
|
||||
</component>
|
||||
</project>
|
17
TD3_DEV51_Qualite_Algo/pom.xml
Normal file
17
TD3_DEV51_Qualite_Algo/pom.xml
Normal file
@@ -0,0 +1,17 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<groupId>fr.iutfbleau.TD3_DEV51_Qualite_Algo</groupId>
|
||||
<artifactId>TD3_DEV51_Qualite_Algo</artifactId>
|
||||
<version>1.0-SNAPSHOT</version>
|
||||
|
||||
<properties>
|
||||
<maven.compiler.source>23</maven.compiler.source>
|
||||
<maven.compiler.target>23</maven.compiler.target>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
</properties>
|
||||
|
||||
</project>
|
Binary file not shown.
Before Width: | Height: | Size: 166 KiB After Width: | Height: | Size: 122 KiB |
22735
TD3_DEV51_Qualite_Algo/resources/liste_francais.txt
Normal file
22735
TD3_DEV51_Qualite_Algo/resources/liste_francais.txt
Normal file
File diff suppressed because it is too large
Load Diff
@@ -1,12 +1,13 @@
|
||||
package fr.iutfbleau.TD3_DEV51_Qualite_Algo.Controllers;
|
||||
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Difficulty;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Word;
|
||||
|
||||
import java.text.Normalizer;
|
||||
import java.util.*;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Word;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Difficulty;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.View.hangedManView;
|
||||
|
||||
import javax.swing.*;
|
||||
|
||||
public class Game {
|
||||
private Word word;
|
||||
private hangedManView hangedManView;
|
||||
@@ -22,35 +23,48 @@ public class Game {
|
||||
|
||||
/* Hangmam Game */
|
||||
// Constructor
|
||||
public Game(Word word ,List<Word> allWord,hangedManView hangedManView) {
|
||||
this.word = word;
|
||||
public Game(hangedManView hangedManView, Difficulty difficulty) {
|
||||
this.hangedManView = hangedManView;
|
||||
this.errors = 0;
|
||||
this.wrongLetters = "";
|
||||
this.startTime = System.currentTimeMillis();
|
||||
this.endTime = 0;
|
||||
|
||||
allwords = WordList.readWordsFromFile();
|
||||
|
||||
switch (difficulty) {
|
||||
case EASY:
|
||||
this.word = selectWord(allWord, 0 , 7 );
|
||||
this.word = selectWord(allwords, 0 , 7 );
|
||||
break;
|
||||
case MEDIUM:
|
||||
this.word = selectWord(allWord, 0, Integer.MAX_VALUE);
|
||||
this.word = selectWord(allwords, 0, Integer.MAX_VALUE);
|
||||
break;
|
||||
case HARD:
|
||||
this.allwords = selectTwoWords(allWord);
|
||||
this.allwords = selectTwoWords(allwords);
|
||||
this.word = new Word(this.allwords.get(0).getText()+"- "+this.allwords.get(1).getText());
|
||||
break;
|
||||
|
||||
}
|
||||
hangedManView.setWord(word.getWord());
|
||||
}
|
||||
|
||||
/* Selected Word with conditions */
|
||||
private Word selectWord(List<Word> list, int min, int max) {
|
||||
for (Word word : list) {
|
||||
int length = word.getWord().length();
|
||||
|
||||
for(int i = 0; i< list.size();i++){
|
||||
|
||||
//génère un int aléatoire
|
||||
Random randomiser = new Random();
|
||||
randomiser.setSeed(System.currentTimeMillis()-i);
|
||||
Word word = list.get(randomiser.nextInt(0, list.size()));
|
||||
|
||||
int length = word.getText().length();
|
||||
if (length >= min && length <= max) {
|
||||
return word;
|
||||
// Supprime les caractères diacritiques (accents)
|
||||
return new Word(Normalizer.normalize(word.getText(), Normalizer.Form.NFD).replaceAll("\\p{InCombiningDiacriticalMarks}+", ""));
|
||||
}
|
||||
}
|
||||
|
||||
return list.getFirst();
|
||||
}
|
||||
|
||||
@@ -59,19 +73,6 @@ public class Game {
|
||||
return list.subList(0, Math.min(2, list.size()));
|
||||
}
|
||||
|
||||
public boolean playLetter(char caractere) {
|
||||
boolean correct;
|
||||
|
||||
if(difficulty == Difficulty.HARD){
|
||||
correct = this.allwords.get(0).VerifyLetter(caractere) || this.allwords.get(1).VerifyLetter(caractere);
|
||||
} else{
|
||||
correct = word.VerifyLetter(caractere);
|
||||
}
|
||||
|
||||
if (!correct) errors++;
|
||||
return correct;
|
||||
}
|
||||
|
||||
// Getters - Errors
|
||||
public int getErrors() {
|
||||
return this.errors;
|
||||
@@ -94,32 +95,40 @@ public class Game {
|
||||
public boolean isWon() {
|
||||
int score = calculateScore();
|
||||
if (word.IsComplete() && score > 0) {
|
||||
JOptionPane.showMessageDialog(null, "Bravo, voici ton score : "+score+"\n et ton temps : "+this.calculateTime()+"s (⓿_⓿).","(⓿_⓿)", JOptionPane.WARNING_MESSAGE);
|
||||
System.exit(0);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
// From view, verify if the letter is correct & finish the game if necessary (lost or won)
|
||||
public boolean playLetter(char c) {
|
||||
boolean correct = word.VerifyLetter(c);
|
||||
public boolean playLetter(char caractere) {
|
||||
boolean correct;
|
||||
|
||||
if(difficulty == Difficulty.HARD){
|
||||
correct = this.allwords.get(0).VerifyLetter(caractere) || this.allwords.get(1).VerifyLetter(caractere);
|
||||
} else{
|
||||
correct = word.VerifyLetter(caractere);
|
||||
}
|
||||
|
||||
if (!correct) {
|
||||
errors++;
|
||||
hangedManView.setState(errors);
|
||||
|
||||
wrongLetters += c + " ";
|
||||
wrongLetters += caractere + " ";
|
||||
hangedManView.setWrongLetters(wrongLetters);
|
||||
|
||||
if (isLost()) {
|
||||
finishedGame();
|
||||
}
|
||||
} else {
|
||||
hangedManView.setCorrectLetters(word.getHiddenWord());
|
||||
|
||||
hangedManView.setWord(word.getWord());
|
||||
if (word.IsComplete()) {
|
||||
finishedGame();
|
||||
}
|
||||
}
|
||||
hangedManView.setWord(word.getWord());
|
||||
|
||||
return correct;
|
||||
}
|
||||
@@ -129,6 +138,8 @@ public class Game {
|
||||
this.endTime = System.currentTimeMillis();
|
||||
|
||||
if (isLost()) {
|
||||
JOptionPane.showMessageDialog(null, "T'a perdu, pauvre con (⓿_⓿).\n Le mot était : "+this.word.getText(),"(⓿_⓿)", JOptionPane.WARNING_MESSAGE);
|
||||
System.exit(0);
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@@ -0,0 +1,36 @@
|
||||
package fr.iutfbleau.TD3_DEV51_Qualite_Algo.Controllers.Handler;
|
||||
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Controllers.Game;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.awt.event.ActionEvent;
|
||||
import java.awt.event.ActionListener;
|
||||
|
||||
public class SendLetterHandler implements ActionListener {
|
||||
|
||||
private JFrame frame;
|
||||
private Game gameControler;
|
||||
private JTextField letterField;
|
||||
|
||||
public SendLetterHandler(JFrame frame, Game gameControler, JTextField letterField) {
|
||||
this.frame = frame;
|
||||
this.gameControler = gameControler;
|
||||
this.letterField = letterField;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
try {
|
||||
// on récupère la lettre du champs de saisie
|
||||
if(this.letterField.getText().length() > 1) {
|
||||
JOptionPane.showMessageDialog(this.frame, "Veuillez n'envoyer qu'une seule lettre. Merci (⓿_⓿).","(⓿_⓿)", JOptionPane.WARNING_MESSAGE);
|
||||
return;
|
||||
}
|
||||
char letter = letterField.getText().charAt(0);
|
||||
this.gameControler.playLetter(letter);
|
||||
this.letterField.setText("");
|
||||
} catch (Exception ex) {
|
||||
}
|
||||
}
|
||||
}
|
@@ -0,0 +1,35 @@
|
||||
package fr.iutfbleau.TD3_DEV51_Qualite_Algo.Controllers;
|
||||
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Word;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
import java.io.FileReader;
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class WordList {
|
||||
|
||||
public WordList()
|
||||
{}
|
||||
|
||||
public static List<Word> readWordsFromFile() {
|
||||
List<Word> words = new ArrayList<>();
|
||||
|
||||
try (BufferedReader br = new BufferedReader(new FileReader("resources/liste_francais.txt"))) {
|
||||
String line;
|
||||
|
||||
while ((line = br.readLine()) != null) {
|
||||
line = line.trim(); // Supprime les espaces inutiles
|
||||
if (!line.isEmpty()) {
|
||||
words.add(new Word(line));
|
||||
}
|
||||
}
|
||||
|
||||
} catch (IOException e) {
|
||||
System.err.println("Erreur lors de la lecture du fichier : " + e.getMessage());
|
||||
}
|
||||
|
||||
return words;
|
||||
}
|
||||
}
|
@@ -1,7 +1,55 @@
|
||||
package fr.iutfbleau.TD3_DEV51_Qualite_Algo;
|
||||
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Controllers.Game;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Controllers.Handler.SendLetterHandler;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Difficulty;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.Models.Word;
|
||||
import fr.iutfbleau.TD3_DEV51_Qualite_Algo.View.hangedManView;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.io.IOException;
|
||||
|
||||
public class Main {
|
||||
public static void main(String[] args) {
|
||||
|
||||
public static void main(String[] args) throws IOException {
|
||||
|
||||
JFrame frame = new JFrame();
|
||||
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
|
||||
frame.setSize(800, 600);
|
||||
frame.setResizable(false);
|
||||
|
||||
frame.setLayout(new GridBagLayout());
|
||||
GridBagConstraints GBC = new GridBagConstraints();
|
||||
|
||||
GBC.fill = GridBagConstraints.BOTH;
|
||||
GBC.gridx = 0;
|
||||
GBC.gridy = 0;
|
||||
GBC.gridwidth = 1;
|
||||
GBC.gridheight = 1;
|
||||
GBC.weightx = 1;
|
||||
GBC.weighty = 1;
|
||||
|
||||
hangedManView drawingView = new hangedManView();
|
||||
frame.add(drawingView, GBC);
|
||||
|
||||
GBC.gridy = 1;
|
||||
GBC.weighty = 0;
|
||||
|
||||
JPanel panel = new JPanel();
|
||||
panel.setLayout(new FlowLayout(FlowLayout.CENTER));
|
||||
|
||||
JTextField TextField = new JTextField();
|
||||
TextField.setColumns(10);
|
||||
panel.add(TextField,GBC);
|
||||
|
||||
Game gameControler = new Game(drawingView, Difficulty.HARD);
|
||||
|
||||
JButton button = new JButton("send");
|
||||
button.addActionListener(new SendLetterHandler(frame,gameControler,TextField));
|
||||
panel.add(button);
|
||||
|
||||
frame.add(panel,GBC);
|
||||
|
||||
frame.setVisible(true);
|
||||
}
|
||||
}
|
@@ -19,4 +19,13 @@ public class Letter{
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
if(this.status){
|
||||
return letter + "";
|
||||
}else{
|
||||
return "_ ";
|
||||
}
|
||||
}
|
||||
}
|
@@ -4,13 +4,13 @@ import java.util.*;
|
||||
|
||||
public class Word {
|
||||
private final String word;
|
||||
private Letter[] tabLetter;
|
||||
private String character;
|
||||
private ArrayList<Letter> tabLetter;
|
||||
|
||||
private Word(String word){
|
||||
public Word(String word){
|
||||
this.word = word;
|
||||
this.tabLetter = new ArrayList<>();
|
||||
for(int i = 0; i< this.word.length();i++){
|
||||
this.tabLetter[i] = new Letter(this.word.charAt(i));
|
||||
this.tabLetter.add(new Letter(this.word.charAt(i)));
|
||||
}
|
||||
}
|
||||
/* Lettre dans le mot */
|
||||
@@ -37,7 +37,14 @@ public class Word {
|
||||
return true;
|
||||
}
|
||||
public String getWord() {
|
||||
return word;
|
||||
String return_word = "";
|
||||
for(Letter letter : this.tabLetter){
|
||||
return_word += letter.toString();
|
||||
}
|
||||
return return_word;
|
||||
}
|
||||
|
||||
public String getText(){
|
||||
return this.word;
|
||||
}
|
||||
}
|
@@ -1,75 +1,103 @@
|
||||
package fr.iutfbleau.TD3_DEV51_Qualite_Algo.View;
|
||||
import javax.imageio.ImageIO;
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.io.File;
|
||||
import java.io.IOException;
|
||||
|
||||
|
||||
public class hangedManView extends JComponent {
|
||||
|
||||
private int state;
|
||||
private String word;
|
||||
private String wrongLetters;
|
||||
|
||||
public hangedManView() throws IOException {
|
||||
super();
|
||||
this.state = 0;
|
||||
this.word = "";
|
||||
this.wrongLetters = "";
|
||||
}
|
||||
|
||||
protected void paintComponent(Graphics g) {
|
||||
super.paintComponent(g);
|
||||
Graphics2D g2d = (Graphics2D) g;
|
||||
|
||||
int x = 150;
|
||||
int y = 200;
|
||||
|
||||
int x = this.getWidth()/2;
|
||||
int y = this.getHeight()/2;
|
||||
|
||||
if(this.state > 8) {
|
||||
// paint une image
|
||||
g2d.drawImage(new ImageIcon(Thread.currentThread().getContextClassLoader().getResource("resources/HangedGirl.jpg")).getImage(), x, y, this);
|
||||
double ratio = 0.5;
|
||||
g2d.drawImage(new ImageIcon("resources/HangedGirl.jpg").getImage(), (this.getWidth()-(int) (567*ratio))/2, 0, (int) (567*ratio), (int) (1080*ratio), this);
|
||||
}else{
|
||||
this.drawStand(g2d, x, y);
|
||||
// on paint un homme batton
|
||||
// Base
|
||||
if (this.state > 0) {
|
||||
g2d.drawLine(x - 100, y + 100, x + 100, y + 100);
|
||||
}
|
||||
// Poteau vertical
|
||||
if (this.state > 1) {
|
||||
g2d.drawLine(x - 50, y + 100, x - 50, y - 100);
|
||||
}
|
||||
// Traverse horizontale
|
||||
if (this.state > 2) {
|
||||
g2d.drawLine(x - 50, y - 100, x + 50, y - 100);
|
||||
}
|
||||
// Petite corde verticale
|
||||
if (this.state > 3) {
|
||||
g2d.drawLine(x + 50, y - 100, x + 50, y - 70);
|
||||
}
|
||||
|
||||
x += 50;
|
||||
y -= 40;
|
||||
this.drawBudy(g2d, x, y);
|
||||
}
|
||||
|
||||
// Tête
|
||||
if (this.state > 4) {
|
||||
g2d.drawOval(x - 15, y - 30, 30, 30);
|
||||
}
|
||||
// Corps
|
||||
if (this.state > 5) {
|
||||
g2d.drawLine(x, y, x, y + 40);
|
||||
}
|
||||
// Bras
|
||||
if (this.state > 6) {
|
||||
g2d.drawLine(x, y + 10, x - 20, y + 20);
|
||||
g2d.drawLine(x, y + 10, x + 20, y + 20);
|
||||
}
|
||||
// Jambes
|
||||
if (this.state > 7) {
|
||||
g2d.drawLine(x, y + 40, x - 20, y + 70);
|
||||
g2d.drawLine(x, y + 40, x + 20, y + 70);
|
||||
}
|
||||
// on dessine le mot en dessous du pendu et au centre de la fenêtre.
|
||||
g2d.setFont(new Font("Roboto", Font.BOLD, 20));
|
||||
g2d.drawString(this.word, (this.getWidth()-g2d.getFontMetrics().stringWidth(this.word))/2, this.getHeight()-50);
|
||||
|
||||
// on dessine les mauvaises lettres en rouge
|
||||
g2d.setColor(Color.RED);
|
||||
g2d.drawString(this.wrongLetters, (this.getWidth()-g2d.getFontMetrics().stringWidth(this.wrongLetters))/2, this.getHeight()-10);
|
||||
}
|
||||
|
||||
private void drawStand(Graphics2D g2d, int x, int y) {
|
||||
// Base
|
||||
if (this.state > 0) {
|
||||
g2d.drawLine(x - 100, y + 100, x + 100, y + 100);
|
||||
}
|
||||
// Poteau vertical
|
||||
if (this.state > 1) {
|
||||
g2d.drawLine(x - 50, y + 100, x - 50, y - 100);
|
||||
}
|
||||
// Traverse horizontale
|
||||
if (this.state > 2) {
|
||||
g2d.drawLine(x - 50, y - 100, x + 50, y - 100);
|
||||
}
|
||||
// Petite corde verticale
|
||||
if (this.state > 3) {
|
||||
g2d.drawLine(x + 50, y - 100, x + 50, y - 70);
|
||||
}
|
||||
}
|
||||
|
||||
private void drawBudy(Graphics g2d,int x, int y) {
|
||||
|
||||
// Tête
|
||||
if (this.state > 4) {
|
||||
g2d.drawOval(x - 15, y - 30, 30, 30);
|
||||
}
|
||||
// Corps
|
||||
if (this.state > 5) {
|
||||
g2d.drawLine(x, y, x, y + 40);
|
||||
}
|
||||
// Bras
|
||||
if (this.state > 6) {
|
||||
g2d.drawLine(x, y + 10, x - 20, y + 20);
|
||||
g2d.drawLine(x, y + 10, x + 20, y + 20);
|
||||
}
|
||||
// Jambes
|
||||
if (this.state > 7) {
|
||||
g2d.drawLine(x, y + 40, x - 20, y + 70);
|
||||
g2d.drawLine(x, y + 40, x + 20, y + 70);
|
||||
}
|
||||
}
|
||||
|
||||
public void setState(int state) {
|
||||
this.state = state;
|
||||
this.repaint();
|
||||
}
|
||||
|
||||
public void setWord(String word) {
|
||||
this.word = word;
|
||||
this.repaint();
|
||||
}
|
||||
|
||||
public void setWrongLetters(String letters) {
|
||||
this.wrongLetters = letters;
|
||||
this.repaint();
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user