Java Swing第二个窗口在被释放后两次调用事件侦听器



所以我有一个swing应用程序,其中一个按钮打开一个窗口。这很简单,打开它我使用:

private static logPicker logWindow;
static boolean logViewerOpen = false;
if (!logViewerOpen) {
    logWindow = new logPicker();
    logWindow.frmOpenLog.setVisible(true);
    logViewerOpen = true;
}
else {
    logWindow.frmOpenLog.requestFocus();
}

我还有一个窗口监听器,可以知道查看器何时关闭:

frmOpenLog.addWindowListener(new WindowAdapter() {
    @Override
    public void windowClosing(WindowEvent arg0) {
        indexPage.logViewerOpen = false;
        frmOpenLog.dispose();
    }
});

我这样做是因为我想跟踪窗口是否已经打开,因为如果已经打开,我必须更新信息。我打开的窗口有一个日志列表,用户可以双击它来查看有关该日志的信息。现在的问题是,当用户双击列表时,无论我打开和关闭该窗口多少次,它都会被调用。示例:我打开日志选择器窗口,然后关闭它。我再次打开它,双击我想查看的日志,它会打开其中的2个。我在打开日志按钮上双击简单的做一个.doClick()。奇怪的是,当我使用按钮打开日志时,它并没有这样做。它只会打开日志一次。这是双击事件和打开日志按钮的代码。

@Override
public void mouseClicked(MouseEvent arg0) {
    if (arg0.getClickCount() == 2) {
        btnOpenLog.doClick();
    }
}
btnOpenLog.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
        logViewer window = new logViewer(log.getSelectedValue());
        window.frmLogViewer.setVisible(true);
    }
});

@LiverpoolFTW:请提供一份SSCCE来证明问题。由于没有足够的代码,我推测您每次打开窗口时都会(重新)添加MouseListener/MouseAdapter。以下示例按原样工作,每次按下按钮或双击标签都会增加clickCount一次。但是,如果您取消注释所示的部分,您会看到当您双击标签时,doClick()被执行了两次。例如,如果您有某个组件,每次打开窗口时都要向该组件添加一个侦听器,那么每个侦听器都将被执行。

package example.stackoverflow;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import javax.swing.BoxLayout;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.SwingUtilities;
public class ClickCheck extends JFrame
{
    private static final long serialVersionUID = -6446528001976145548L;
    private static final JButton btnOpenLog = new JButton("Open Log");
    public ClickCheck()
    {
        JLabel label = new JLabel("Double-Click Me");
        label.addMouseListener(new MouseAdapter()
        {
            @Override
            public void mouseClicked(MouseEvent arg0) {
                if (arg0.getClickCount() == 2) {
                    btnOpenLog.doClick();
                }
            }
        });
        // Uncomment to demonstrate the effect of multiple listeners
//        label.addMouseListener(new MouseAdapter()
//        {
//            @Override
//            public void mouseClicked(MouseEvent arg0) {
//                if (arg0.getClickCount() == 2) {
//                    btnOpenLog.doClick();
//                }
//            }
//        });
        btnOpenLog.addActionListener(new ActionListener() {
            private int clickCount = 0;
            public void actionPerformed(ActionEvent e) {
                    System.out.println(++clickCount + ": Button clicked");
                }
            });

        setSize(200, 200);
        setLayout(new BoxLayout(getContentPane(), BoxLayout.Y_AXIS));
        add(btnOpenLog);
        add(label);
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    }
    public static void main(String[] args)
    {
        SwingUtilities.invokeLater(new Runnable()
        {
            public void run()
            {
                ClickCheck c = new ClickCheck();
                c.setVisible(true);
            }
        });
    }
}

最新更新