Java 执行一次actionListener,然后转到另一个actionListener

Java 执行一次actionListener,然后转到另一个actionListener,java,swing,jbutton,actionlistener,Java,Swing,Jbutton,Actionlistener,有人对这个问题有其他看法吗 我需要这部分代码的帮助,我只想执行一次actionListener(将白色边框添加到按下的Jbutton),然后继续执行另一个actionListener(将蓝色边框添加到另一个(不同的)按下的Jbutton)。这是我的代码,它只连续执行白色边框。 非常感谢您的反馈 for(int c = 0; c< 10; c++) { for (int r = 0; r< 10; r++) {

有人对这个问题有其他看法吗

我需要这部分代码的帮助,我只想执行一次actionListener(将白色边框添加到按下的Jbutton),然后继续执行另一个actionListener(将蓝色边框添加到另一个(不同的)按下的Jbutton)。这是我的代码,它只连续执行白色边框。 非常感谢您的反馈

for(int c = 0; c< 10; c++) 
        {
            for (int r = 0; r< 10; r++)
            {
                bu1[c][r] = new JButton(); //Insert Into List
                panel.add(bu1[c][r]);

                final int i = c;
                final int j = r;

                bu1[i][j].addActionListener(new ActionListener()
                {

                @Override
                public void actionPerformed(ActionEvent e) 
                    {
                        if  (e.getSource() == bu1[i][j])
                        {
                            bu1[i][j].setBorder(BorderFactory.createLineBorder(Color.WHITE, 2));
                            bu1[i][j].removeActionListener(this);
                        }

                    }    

            });

                bu1[i][j].addActionListener(new ActionListener()
                {

                @Override
                public void actionPerformed(ActionEvent e) 
                    {
                        if  (e.getSource() == bu1[i][j])
                        {
                            bu1[i][j].setBorder(BorderFactory.createLineBorder(Color.BLUE, 2));
                        }

                    }    

            });
for(int c=0;c<10;c++)
{
对于(int r=0;r<10;r++)
{
bu1[c][r]=new JButton();//插入列表
小组委员会增补(bu1[c][r]);
最终积分i=c;
最终int j=r;
bu1[i][j].addActionListener(新ActionListener()
{
@凌驾
已执行的公共无效操作(操作事件e)
{
如果(e.getSource()==bu1[i][j])
{
bu1[i][j].setboorder(BorderFactory.createLineBorder(Color.WHITE,2));
bu1[i][j].removeActionListener(this);
}
}    
});
bu1[i][j].addActionListener(新ActionListener()
{
@凌驾
已执行的公共无效操作(操作事件e)
{
如果(e.getSource()==bu1[i][j])
{
bu1[i][j].setboorder(BorderFactory.createLineBorder(Color.BLUE,2));
}
}    
});

如果我理解你的问题,那么最简单的解决方案就是在你的
ActionListener
中保留一个
计数。因为这样你只需要一个
ActionListener
和以下内容

private int count = 0;
@Override
public void actionPerformed(ActionEvent e) {
  JButton obj = bu1[i][j]; // <-- save the typing.
  if (e.getSource() == obj) {
    if (count == 0) { 
      obj.setBorder(BorderFactory.createLineBorder(
          Color.WHITE, 2)); // <-- set to white on 0.
    } else if (count == 1) {
      obj.setBorder(BorderFactory.createLineBorder(
          Color.BLUE, 2)); // <-- set to blue on 1.
    }
    count++;
  }
}
private int count=0;
@凌驾
已执行的公共无效操作(操作事件e){

JButton obj=bu1[i][j];//谢谢你的回答……我正在尝试,但在对象上设置顺序时遇到问题。@user3693592抱歉。已编辑。一点问题也没有!!……但它仍然不起作用。可能是因为我已将你的代码插入嵌套循环。我必须这样做,因为我需要“bu1[i][j”。是否仍在删除侦听器?是否可以尝试调试程序?