KeyListeners для JComboBox, который используется в качестве редактора ячеек в таблице

Извините, если это звучит как основной вопрос, но я относительно новичок в java. У меня есть JComboBox, который я заполняю из базы данных, а затем использую в JTable. Я делаю это, используя следующий код:

itemEditortxt = new JComboBox(buildComboBoxmodel("SELECT item_name FROM items ORDER BY item_name"));
AutoCompleteDecorator.decorate(itemEditortxt);
TableColumn ledgerColumn = invoicePurchasedTable.getColumnModel().getColumn(0);
ledgerColumn.setCellEditor(new ComboBoxCellEditor(itemEditortxt));

Я пытаюсь добавить прослушиватели клавиш в JComboBox, но по какой-то причине они не вызываются, когда я нажимаю любую клавишу, когда фокус находится на ячейке, которая использует JComboBox. Вот как я добавляю пометы:

itemEditortxt.addKeyListener(new KeyListener() {
        @Override
        public void keyPressed(KeyEvent e) {System.out.print("line1");}
        @Override
        public void keyReleased(KeyEvent e) {System.out.print("line2");}
        @Override
        public void keyTyped(KeyEvent e) {System.out.print("line3");}
    });

Может кто-нибудь, пожалуйста, скажите мне, что я делаю неправильно? Спасибо. Далее следует SSCCE. Есть два похожих JComboBox, один добавляется обычно, а другой используется как редактор ячеек. В первом пользователь может использовать стрелки клавиатуры, а затем нажать ENTER, чтобы сделать выбор. Это не относится к тому, что в таблице. Спасибо:

package sp2;
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import javax.swing.event.*;
import java.util.*;
import javax.swing.table.*;
import org.jdesktop.swingx.autocomplete.*;

class InvoicePurchasedModel extends DefaultTableModel {
public InvoicePurchasedModel (Vector<Vector<Object>> data, Vector<String> columnNames) {
    super(data, columnNames);
}

@Override
public Class getColumnClass(int col) {
    if (col == 0) 
        return String.class;
    else
        return Double.class;   
}
}

public class SP2 {    
JFrame mainPage;
JTabbedPane jtp;
JPanel mainPanel;
JPanel purchasedInvoicesPanel;    
RXTable invoicePurchasedTable;
DefaultTableModel invoicePurchasedtm;
JComboBox itemEditortxt;
JComboBox itemEditortxt2;

SP2() {
    mainPage = new JFrame("System");
    mainPage.getContentPane().setLayout(new GridLayout());
    mainPage.setSize(1200, 1200);
    mainPage.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    createTabs();    
    mainPage.setVisible(true);
}

void createTabs() {
    jtp = new JTabbedPane();
    mainPanel = new JPanel();
    mainPanel.setLayout(new GridLayout());
    mainPage.getContentPane().add(jtp);      
    purchasedInvoicesPanel = new JPanel();
    jtp.addTab("Purchased", purchasedInvoicesPanel);
    invoicePurchasedtm = buildInvoicePurchasedTableModel();
    invoicePurchasedTable = new RXTable(invoicePurchasedtm) {
        private final KeyStroke tabKeyStroke = KeyStroke.getKeyStroke(KeyEvent.VK_TAB, 0); 
            public void changeSelection(int row, int column, boolean toggle, boolean extend)
            {
                super.changeSelection(row, column, toggle, extend);
                if (editCellAt(row, column))
                {
                    Component editor = getEditorComponent();
                    editor.requestFocusInWindow();
                }
            }
        }; 
    invoicePurchasedTable.setCellSelectionEnabled(true);
    invoicePurchasedTable.setSelectAllForEdit(true);
    purchasedInvoicesPanel.setLayout(new BoxLayout(purchasedInvoicesPanel, BoxLayout.PAGE_AXIS));
    JPanel purchasedInvoicesPanel1 = new JPanel();
    JPanel purchasedInvoicesPanel2 = new JPanel();
    purchasedInvoicesPanel.add(purchasedInvoicesPanel1);
    purchasedInvoicesPanel.add(purchasedInvoicesPanel2);
    JScrollPane invoicePurchasedscrollPane = new JScrollPane(invoicePurchasedTable);
    invoicePurchasedTable.setPreferredScrollableViewportSize(new Dimension(1000, 400));
    String[] names = {"aa", "aa1", "aa2", "bb", "bb1", "bb2"};
    itemEditortxt = new JComboBox(names);
    itemEditortxt2 = new JComboBox(names);
    AutoCompleteDecorator.decorate(itemEditortxt);
    AutoCompleteDecorator.decorate(itemEditortxt2);
    TableColumn ledgerColumn = invoicePurchasedTable.getColumnModel().getColumn(0);
    ledgerColumn.setCellEditor(new ComboBoxCellEditor(itemEditortxt));
    purchasedInvoicesPanel1.add(itemEditortxt2);
    purchasedInvoicesPanel2.add(invoicePurchasedscrollPane);
}

public static DefaultTableModel buildInvoicePurchasedTableModel() {
    Vector<String> columnNames = new Vector<String>();
    columnNames.add("Item");
    columnNames.add("Quantity");
    columnNames.add("Unit Price");
    columnNames.add("Amount");
    Vector<Vector<Object>> data = new Vector<Vector<Object>>();
    Vector<Object> vector = new Vector<Object>();
    vector.add("");
    vector.add(0.00);
    vector.add(0.00);
    vector.add(0.00);
    data.add(vector);
    return new InvoicePurchasedModel(data, columnNames);
}

/**
 * @param args the command line arguments
 */
public static void main(String[] args) {
    // TODO code application logic here
    SwingUtilities.invokeLater(new Runnable() {
       public void run() {
           new SP2();
       } 
    });
}
}

person user3245747    schedule 20.02.2014    source источник
comment
ListSelectionListener вместо KeyListener   -  person mKorbel    schedule 20.02.2014
comment
Вы пытаетесь добавить слушателя в текстовое поле внутри поля со списком?   -  person Paul Samsotha    schedule 20.02.2014
comment
Проблема в том, что в jComboBox, который используется в таблице, пользователь не может сделать выбор из выпадающего списка с помощью клавиши ввода. Он должен использовать мышь. Я хочу, чтобы выбор был сделан с помощью клавиши ввода. Я пытался использовать ListSelectionListener и DocumentListener, но в обоих этих случаях я не знаю, когда пользователь нажимает ввод. Я попытался добавить прослушиватель клавиш во всплывающее меню как таковое: BasicComboPopup popup = (BasicComboPopup)itemEditortxt.getAccessibleContext().getAccessibleChild(0); Список JList = popup.getList(); list.addKeyListener (новый KeyListener()...   -  person user3245747    schedule 20.02.2014
comment
не используйте KeyListener, особенно с комбинацией, украшенной автозаполнением (внутри выполняется тяжелая работа, которая, скорее всего, будет мешать вашей). Вместо этого объясните, чего вы хотите достичь, чтобы мы могли предложить правильное решение.   -  person kleopatra    schedule 20.02.2014
comment
ааа, только что прочитал ваш комментарий и быстро проверил: workform. Итак, пришло время для SSCCE, демонстрирующего проблему.   -  person kleopatra    schedule 20.02.2014
comment
Я хочу, чтобы поле со списком, которое я использую в качестве редактора ячеек в JTable, действовало как обычное поле со списком: пользователь может прокручивать список вниз с помощью клавиш со стрелками и может использовать функцию автозаполнения (эти вещи уже работают) и (это часть, которая не работает) пользователь должен иметь возможность сделать выбор, нажав клавишу ввода. В настоящий момент нажатие клавиши ввода, когда X выделен, но Y отображается в текстовом поле Combobox, приведет к перемещению фокуса на следующую ячейку без изменения выбранного значения с Y на X.   -  person user3245747    schedule 20.02.2014
comment
пожалуйста, отредактируйте свой вопрос, чтобы добавить дополнительную информацию (и не забудьте SSCCE :-). Повторяю: клавиша ввода работает, так что, вероятно, где-то что-то не так.   -  person kleopatra    schedule 20.02.2014
comment
Я добавил SSCCE. Я ценю вашу помощь.   -  person user3245747    schedule 20.02.2014
comment
удалите переопределение changeSelection, и ввод в комбинированном редакторе автозаполнения будет работать как положено :)   -  person kleopatra    schedule 21.02.2014
comment
Я пробовал это, но это все еще не работает.   -  person user3245747    schedule 21.02.2014


Ответы (2)


«Я пытаюсь добавить ключевые прослушиватели в JComboBox, но по какой-то причине они не вызываются, когда я нажимаю любую клавишу, когда фокус находится на ячейке, которая использует JComboBox».

Я думаю, что вы, возможно, пытаетесь добавить слушателя в «текстовое поле» для поля со списком. Первое, что вам нужно сделать, это получить компонент редактора. затем вы можете добавить DocumentListener к Document из JTextComponent

JTextComponent editor = (JTextComponent) comboBox.getEditor().getEditorComponent();
editor.getDocument().addDocumentListener(new DocumentListener(){
    ...
});
person Paul Samsotha    schedule 20.02.2014

Итак, проблема была вызвана AutoCompleteDecorator. Я деактивировал его и вместо этого использовал AutoCompletion.enable(employeeDelete). Теперь клавиши ENTER и TAB работают как положено. Я ценю все комментарии, которые помогли мне.

person user3245747    schedule 22.02.2014