Java Swing第二个窗口在被处理后两次调用事件监听器

时间:2013-08-05 18:55:30

标签: java swing jbutton windowlistener

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

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);
    }
});

1 个答案:

答案 0 :(得分:2)

@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);
            }
        });
    }
}