Отключить кнопки на JAVA, но оставить уникальную кнопку в покое - PullRequest
0 голосов
/ 25 февраля 2019

В соответствии с моим предыдущим вопросом здесь: Удалить кнопку с тем же текстом при нажатии

Мне нужно, чтобы единственные кнопки, которые появляются более одной, исчезали при нажатии на них. Проблема в том, когданажав на «Уникальные» (см. рисунок), они тоже исчезнут.Мой код:

private String namesArr[] = {"Yakir","Yarden","Igor","Maoz","Moshe","Israel","Tal","Haim","Nati","Mor","Daniel","Idan"};
private Button buttonArr[] = new Button[namesArr.length];
private Font font;

public StudentsGUI(String caption) {
    super(caption);
    addWindowListener(new WindowAdapter(){
            public void windowClosing(WindowEvent e){
                    dispose();
                        System.exit(0);
                        }
                    }); 
    this.setLayout(new GridLayout(3,3));
    font = new Font("Ariel",Font.BOLD,35);

    for(int i=0;i<namesArr.length;i++) {
        buttonArr[i] = new Button(" "+namesArr[(int)(Math.random()*namesArr.length)]);
        buttonArr[i].setFont(font);
        buttonArr[i].addActionListener(this);
        this.add(buttonArr[i]);
    }
    setLocation(800,500);
    setVisible(true);
    pack();
}

public void actionPerformed(ActionEvent e) {
    if (e.getSource() instanceof Button) {
        String btnText = ((Button)e.getSource()).getLabel();
        for(int i=0; i<buttonArr.length; i++) {
            if (buttonArr[i].getLabel().equals(btnText)) {
                this.remove(buttonArr[i]);
                pack();
            }
        }
    }
}

Картинка, которая поможет вам понять: enter image description here

Так что, если нажать «Идан», ведьма - это уникальное имя, ничего не произойдеттак как у него только один экземпляр, но при нажатии на «Maoz» все кнопки с заголовком «Maoz» исчезнут (это уже происходит)

Ответы [ 2 ]

0 голосов
/ 25 февраля 2019

использование коллекций в соответствии с ответом @ Фредди должно быть лучше.Однако, если вы придерживаетесь массивов, то, как показано ниже, должно это сделать (хотя я и не проверял)

public void actionPerformed(ActionEvent e) {
        if (e.getSource() instanceof Button) {
            String btnText = ((Button)e.getSource()).getLabel();
            int counter = 0;
            for(int i=0; i<buttonArr.length; i++) {
                if (buttonArr[i].getLabel().equals(btnText)) counter++;
                if (count > 1) {
                   for(int j=0; j<buttonArr.length; j++) {
                      if (buttonArr[j].getLabel().equals(btnText))
                         this.remove(buttonArr[j]);
                   }
                }
            }
            pack();
        }
}
0 голосов
/ 25 февраля 2019

Вы имеете в виду что-то вроде этого (код может иметь синтаксические ошибки)?

public void actionPerformed(ActionEvent e) {
    if (e.getSource() instanceof Button) {
        String btnText = ((Button)e.getSource()).getLabel();

        List<Button> btnList = new ArrayList<Button>();
        for(int i=0; i<buttonArr.length; i++) {
            if (buttonArr[i].getLabel().equals(btnText)) {
                btnList.add(buttonArr[i]);
                //this.remove(buttonArr[i]);
                //pack();
            }
        }
        if (btnList.size() > 1) {
            for (Iterator<Button> it = btnList.iterator(); it.hasNext()) {
                this.remove(it.next());
            }
            pack();
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...