как объявить JLabels в actionListener (actionEvent e), чтобы текст мог быть установлен при нажатии JButton - PullRequest
0 голосов
/ 17 июня 2020

Я кодирую игру Rock Paper Scissors, и я пытаюсь заставить каждую из JLabels обновляться всякий раз, когда нажимается одна из трех кнопок (Rock, Paper, Scissors).

Проблема в том, что каждый из JLabel определяется в createWindow (), и мне нужно, чтобы они также были определены в ActionListener (ActionEvent e).

Я попытался скопировать-вставить часть кода из createWindow () и обновления JLabels, но единственная проблема в том, что он создает совершенно новое окно без кнопок (содержит только текст). Если я попытаюсь создать экземпляры меток вне основного метода, JLabels вообще не появятся.

Любая помощь приветствуется (независимо от того, нужно ли мне переписывать всю программу или нет), я новичок to Java и Swing, и любая критика будет так или иначе полезна. (Я пишу в Eclipse IDE).

  import java.awt.*;
  import java.awt.event.ActionEvent;
  import java.awt.event.ActionListener;
  import javax.swing.*;

  public class RockPaperScissors extends JPanel implements ActionListener {
public static void main(String[] args) {
    RockPaperScissors sm = new RockPaperScissors();
    sm.createWindow();
}
private void createWindow() {
    // create JFrame/JPanel
    JFrame frame = new JFrame("Rock! Paper! Scissors!");
    JPanel panel = new JPanel();
    JLabel title = new JLabel("Rock! Paper! Scissors!");
    JLabel playerchoice = new JLabel("");
    JLabel computerdecision = new JLabel("");
    JLabel outcome = new JLabel("");
    frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    frame.setLocationRelativeTo(null);
    frame.setVisible(true);
    frame.pack();
    frame.setExtendedState(JFrame.MAXIMIZED_BOTH);
    JButton button1 = new JButton("Rock");
    panel.add(button1);
    button1.addActionListener(this);
    button1.setBounds(480, 500, 100, 50);
    JButton button2 = new JButton("Paper");
    panel.add(button2);
    button2.addActionListener(this);
    button2.setBounds(590, 500, 100, 50);
    JButton button3 = new JButton("Scissors");
    panel.add(button3);
    button3.addActionListener(this);
    button3.setBounds(700, 500, 100, 50);
    frame.add(panel);
    panel.setLayout(new BorderLayout());
    GroupLayout layout = new GroupLayout(this);
    this.setLayout(layout);
    panel.add(title);
    panel.add(playerchoice);
    panel.add(computerdecision);
    panel.add(outcome);
    outcome.setBounds(571, 90, 260, 200);
    computerdecision.setBounds(571, 100, 260, 200);
    playerchoice.setBounds(571, 120, 260, 200);
    title.setBounds(571, 0, 260, 200);
}
     public void actionPerformed(ActionEvent e) {
    // JLabels
    int choice = 0;
    int computerchoice = 0;
    int min = -1;
    int max = -3;
    computerchoice = (int) (Math.random() * (max - min - 1) + min);
    if (computerchoice == -1) {
        panel.add(computerdecision);
        computerdecision.setText("The Computer Chose Rock!");
        // for checking
        System.out.println("The Computer Chose Rock!");
    } else if (computerchoice == -2) {
        panel.add(computerdecision);
        computerdecision.setText("The Computer Chose Paper!");
        // for checking
        System.out.println("The Computer Chose Paper!");
    } else if (computerchoice == -3) {
        panel.add(computerdecision);
        computerdecision.setText("The Computer Chose Scissors!");
        // for checking
        System.out.println("The Computer chose Scissors!");
    }
    if (e.getActionCommand().equals("Rock")) {
        choice = 1;
        panel.add(playerchoice);
        playerchoice.setText("You chose Rock!");
        // for checking
        System.out.println("You chose Rock!");
    } else if (e.getActionCommand().equals("Paper")) {
        choice = 2;
        panel.add(playerchoice);
        playerchoice.setText("You chose Paper!");
        // for checking
        System.out.println("You chose Paper!");
    } else if (e.getActionCommand().equals("Scissors")) {
        choice = 3;
        panel.add(playerchoice);
        playerchoice.setText("You chose Scissors!");
        // for checking
        System.out.println("You chose Scissors!");
    }
    if (choice + computerchoice == 0) {
        panel.add(outcome);
        outcome.setText("It is a Tie!");
        // for checking
        System.out.println("It is a Tie!");
    } else if (choice + computerchoice == 1 || choice + computerchoice == -2) {
        panel.add(outcome);
        outcome.setText("You Win!");
        // for checking
        System.out.println("You Win!");
    } else if (choice + computerchoice == 2 || choice + computerchoice == -1) {
        panel.add(outcome);
        outcome.setText("You Lose...");
        // for checking
        System.out.println("You Lose...");
    }
}}

1 Ответ

0 голосов
/ 17 июня 2020

Решение вашей проблемы очень простое, просто сделайте члены panel, playerchoice, computerdecision и outcome класса RockPaperScissors вместо локальных переменных, подобных этой

public class RockPaperScissors extends JPanel implements ActionListener {
     private JPanel panel;
     private JLabel computerdecision;
     private JLabel playerchoice;
     private JLabel outcome;

     ...

     private void createWindow() {
         JFrame frame = new JFrame("Rock! Paper! Scissors!");
         panel = new JPanel();
         playerchoice = new JLabel("");
         computerdecision = new JLabel("");
         outcome = new JLabel("");
         JLabel title = new JLabel("Rock! Paper! Scissors!");
         ...
     }
     ...
}
...