[英]javax.swing.JCheckBox setSelected is not calling from GUI
[英]Why does setSelected on JCheckBox lose effect?
有人可以向我解釋為什么當我將JOptionPane
放入ItemListener
時會丟失對JCheckBox
的選擇(由setSelected()
設置setSelected()
的原因嗎? 這是一個錯誤嗎?
很好奇的是,如果此過程因invokeLater()
而延遲,則setSelected()
按我預期的那樣正常工作。
來自SSCCE
import javax.swing.*;
import java.awt.*;
import java.awt.event.*;
public class ComponentEventDemo extends JPanel
implements ComponentListener, ItemListener {
private static final long serialVersionUID = 1L;
private JFrame frame;
private JTextArea display;
private String newline = "\n";
private JTextField field1;
public ComponentEventDemo() {
super(new BorderLayout());
display = new JTextArea(10, 25);
display.setEditable(false);
JPanel panel = new JPanel(new GridLayout(0, 2));
field1 = new JTextField();
field1.setDisabledTextColor(Color.red);
JCheckBox checkbox = new JCheckBox("Label visible", true);
checkbox.addItemListener(this);
panel.add(checkbox);
panel.add(field1);
panel.addComponentListener(this);
JScrollPane scrollPane = new JScrollPane(display);
frame = new JFrame("ComponentEventDemo");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.add(scrollPane, BorderLayout.CENTER);
frame.add(panel, BorderLayout.SOUTH);
frame.addComponentListener(this);
frame.setLocation(200, 200);
frame.pack();
frame.setVisible(true);
}
public void itemStateChanged(ItemEvent evt) {
System.out.println("STATE CHANGED!");
if (evt.getStateChange() == ItemEvent.SELECTED) {
//javax.swing.SwingUtilities.invokeLater(new Runnable() {
//public void run() {
int returnVal = JOptionPane.showConfirmDialog(display,
"Bla Bla Bla Text");
if (returnVal == JOptionPane.OK_OPTION) {
field1.setText("SELECTED - OK btn");
} else if (returnVal == JOptionPane.NO_OPTION) {
field1.setText("SELECTED - NO btn");
} else if (returnVal == JOptionPane.CANCEL_OPTION) {
field1.setText("SELECTED - Cancel btn");
} else if (returnVal == JOptionPane.CLOSED_OPTION) {
field1.setText("SELECTED - Close btn");
}
//}
//});
} else if (evt.getStateChange() == ItemEvent.DESELECTED) {
field1.setText("DESELECTED");
}
}
protected void displayMessage(String message) {
display.append(message + newline);
display.setCaretPosition(display.getDocument().getLength());
}
public void componentHidden(ComponentEvent e) {
displayMessage(e.getComponent().getClass().getName() + " ---> Hidden");
}
public void componentMoved(ComponentEvent e) {
displayMessage(e.getComponent().getClass().getName() + " ---> Moved");
}
public void componentResized(ComponentEvent e) {
displayMessage(e.getComponent().getClass().getName() + " ---> Resized ");
}
public void componentShown(ComponentEvent e) {
displayMessage(e.getComponent().getClass().getName() + " ---> Shown");
}
public static void main(String[] args) {
javax.swing.SwingUtilities.invokeLater(new Runnable() {
public void run() {
ComponentEventDemo ced = new ComponentEventDemo();
}
});
}
}
它是一種已知的錯誤通過為已確認Oracle錯誤ID:6924233的JOptionPane
顯然會導致與復選框值=假來生成另一事件。
推薦的修復方法是使用invokeLater
實例化JOptionPane
。
Submitted On 09-MAR-2010
The change is in the BasicButtonListener - Method focusLost()
In 1.6.0_18 it is
...
ButtonModel model = b.getModel();
model.setPressed(false);
model.setArmed(false);
in 1.6.0_10 it was
...
ButtonModel model = b.getModel();
model.setArmed(false);
model.setPressed(false);
(The order of the statements changed)
And a setPressed(false) with armed==true leads on an ToggleButton like
the JCheckBox to a change of the selection (see ToggleButtonModel)
在Mac OS X和Ubuntu上,我看不到任何區別:從DESELECTED
狀態開始,單擊復選框。 我看到復選標記立即出現,然后出現選項窗格。 無論是否使用Runnable
我都會得到相同的結果。
在Windows上,結果如前所述,但是隨着選項窗格的出現,我看到了復選標記的微小閃爍。 在仿真器(如VirtualBox )中更容易看到效果,這會使速度變慢。 對Runnable
排隊可以恢復正常操作。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.