我试图获得一个按钮来启用/禁用自身,具体取决于JTable是否选择了任何行。
因此,我相信我需要将按钮设为ListSelectionListener,以监听JTable的SelectionModel,如本Oracle tutorial中所述。
我应该如何使用JFormDesigner 5做到这一点?
似乎我应该将以下代码添加到我的JButton中,但是我不知道如何在JFormDesigner中这样做。
// Implementing this method to be a ListSelectionListener.
public void valueChanged(ListSelectionEvent e) {
ListSelectionModel lsm = (ListSelectionModel)e.getSource();
boolean anyRowsSelected = !(lsm.isSelectionEmpty());
this.setEnabled( anyRowsSelected );
}
在我使用JFormDesigner添加actionPerformed处理程序的经验中,JFormDesigner在JFrame上创建了一个方法。但是我对Swing和OOP的理解是,ListSelectionListener的代码应该在侦听小部件本身(在我的情况下为JButton)内部。
我正在使用:JFormDesigner 5.0.0.1,IntelliJ 10.5,Java 1.6.0_24,Mac OS X 10.6.7。
- - - - 解决了 - - - - - -
感谢“气垫船充满鳗鱼”回答了我的问题。
解决方案:我将代码添加到JFrame中以创建ListSelectionListener。这样就可以完成工作,而不会干扰JFormDesigner工具。
我增强了“气垫船充满鳗鱼”给出的示例代码,以使其更具交互性。我向按钮添加了一个ActionListener,以清除用户的选择。现在,用户可以看到按钮在启用和禁用之间切换。
我的版本显示了一个细微的错误:清除表格的选择后,所选单元格将变为黑色。我不知道但这超出了这个StackOverflow问题的范围。不管有什么错误,此代码都是针对此问题的良好演示。
import java.awt.BorderLayout;
import java.awt.event.*;
import javax.swing.*;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import javax.swing.table.DefaultTableModel;
public class TableAndButton extends JPanel {
private static final String[] COLUMN_NAMES = {"Mon", "Tues", "Wed", "Thurs", "Fri"};
private JButton button = new JButton("Clear user's selection");
private DefaultTableModel model = new DefaultTableModel(COLUMN_NAMES, 10);
private JTable table = new JTable(model);
public TableAndButton() {
JPanel btnPanel = new JPanel();
btnPanel.add(button);
table.getSelectionModel().addListSelectionListener(new ListSelectionListener() {
public void valueChanged(ListSelectionEvent e) {
ListSelectionModel lsm = (ListSelectionModel)e.getSource();
boolean anyRowSelected = !(lsm.isSelectionEmpty());
button.setEnabled(anyRowSelected);
}
});
button.addActionListener( new ActionListener() {
public void actionPerformed(ActionEvent e) {
table.getSelectionModel().clearSelection();
}
});
button.setEnabled(false);
setLayout(new BorderLayout());
add(new JScrollPane(table), BorderLayout.CENTER);
add(btnPanel, BorderLayout.PAGE_END);
}
private static void createAndShowUI() {
JFrame frame = new JFrame("TableAndButton");
frame.getContentPane().add(new TableAndButton());
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
public static void main(String[] args) {
java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
createAndShowUI();
}
});
}
}
最佳答案
不,JButton本身不应该是ListSelectionListener,但是JTable需要添加一个单独的ListSelectionListener来启用/禁用JButton。不要认为按钮好像在监听JTable,因为它不是。取而代之的是,一个单独的实体进行监听并根据是否选择了行来更改程序的状态。
例如。,
import java.awt.BorderLayout;
import javax.swing.*;
import javax.swing.event.ListSelectionEvent;
import javax.swing.event.ListSelectionListener;
import javax.swing.table.DefaultTableModel;
public class TableAndButton extends JPanel {
private static final String[] COLUMN_NAMES = {"Mon", "Tues", "Wed", "Thurs", "Fri"};
private JButton button = new JButton("Button");
private DefaultTableModel model = new DefaultTableModel(COLUMN_NAMES, 10);
private JTable table = new JTable(model);
public TableAndButton() {
JPanel btnPanel = new JPanel();
btnPanel.add(button);
table.getSelectionModel().addListSelectionListener(new ListSelectionListener() {
public void valueChanged(ListSelectionEvent e) {
ListSelectionModel lsm = (ListSelectionModel)e.getSource();
boolean anyRowSelected = !(lsm.isSelectionEmpty());
button.setEnabled(anyRowSelected);
}
});
button.setEnabled(false);
setLayout(new BorderLayout());
add(new JScrollPane(table), BorderLayout.CENTER);
add(btnPanel, BorderLayout.PAGE_END);
}
private static void createAndShowUI() {
JFrame frame = new JFrame("TableAndButton");
frame.getContentPane().add(new TableAndButton());
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
public static void main(String[] args) {
java.awt.EventQueue.invokeLater(new Runnable() {
public void run() {
createAndShowUI();
}
});
}
}