Как обновить содержимое JComboBox из ArrayList? - PullRequest
7 голосов
/ 20 января 2011

У меня есть JComboBox на основе ArrayList:

private ArrayList<String> klienci = new ArrayList<String>();
private JComboBox klienciLista;

, и я добавляю его в конструктор:

klienciLista = new JComboBox(klienci.toArray());
klienciLista.setPrototypeDisplayValue("#############################");
panel.add(klienciLista); //JPanel panel

В начале Список пуст.Клиент получает через сокет новый ArrayList в потоке:

public void run() {
  try {
   host = InetAddress.getLocalHost().getHostName();
   socket = new Socket(host, SERVER_PORT);
   input = new ObjectInputStream(socket.getInputStream());
   output = new ObjectOutputStream(socket.getOutputStream());
   output.writeObject(nazwa);
  } catch (IOException e) {
   System.out.println(e);
   JOptionPane.showMessageDialog(null,
     "Polaczenie sieciowe dla klienta nie moze byc utworzone");
   setVisible(false);
   dispose(); // zwolnienie zasobów graficznych
      // okno graficzne nie zostanie utworzone
   return;
  }
  try {
   while (true) {
    container = new Object[2];
    container = (Object[]) input.readObject();
    String m = (String) container[0];
    setKlienci((ArrayList<String>) container[1]);
    klienciLista = new JComboBox(klienci.toArray());
    String pom = textArea.getText();
    textArea.setText(pom + ">>> " + m + "\n");
    klienciLista.revalidate();
    panel.revalidate();
    panel.repaint();

    if (m.equals("exit")) {
     input.close();
     output.close();
     socket.close();
     setVisible(false);
     dispose();
     break;
    }
   }
  } catch (Exception e) {
   System.out.println(e);
   JOptionPane.showMessageDialog(null,
     "Polaczenie sieciowe dla klienta zostalo przerwane");
   setVisible(false);
   dispose();
  }
 }

Я хочу, чтобы мой JComboBox klienciLista заполнялся новым ArrayList доступных клиентов, но этого не происходит.После подключения сервер отправляет arrayList, а клиент обновляет его, но не обновляет ComboBox.Почему это?

Ответы [ 5 ]

20 голосов
/ 20 января 2011

Это потому, что вы продолжаете создавать новый JComboBox в цикле, вместо того, чтобы обновлять существующий.

Вместо

while(true){
...
klienciLista = new JComboBox(klienci.toArray());
...
}

сделать:

while(true){
    ...
    klienciLista.removeAllItems();
    for(String s:klienci){
        klienciLista.addItem(s);
    }
    ...
}

или предпочтительно , используйте модель:

    klienciLista.setModel(new DefaultComboBoxModel(klienci.toArray()));
4 голосов
/ 20 января 2011

Это потому, что вы создаете новый JComboBox вместо обновления одного в графическом интерфейсе.

Посмотрите на метод addItem () в JComboBox: http://download.oracle.com/javase/6/docs/api/javax/swing/JComboBox.html

3 голосов
/ 20 января 2011

Во-первых, вы должны создать свой JComboBox из ComboBoxModel. Во-вторых, вы не должны вызывать новый JComboBox внутри цикла.

1 голос
/ 20 января 2011

Потому что, когда вы делаете klienciLista = new JComboBox(klienci.toArray()); вы создаете новый JComboBox и ссылаетесь на него через эту переменную, но оригинал JComboBox все еще существует в графическом интерфейсе. Вы ничего не сделали для изменения отображаемого в данный момент JComboBox.

0 голосов
/ 26 июня 2013

Очистите и обновите ваш список, а не ваш comboBox.

...