Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Java Swing: How to remove an anonymous ActionListener from a component

Tags:

java

swing

I created an array of JButtons with anonymous ActionListeners and under certain conditions I want to remove all the ActionListeners, but the .removeActionListeners method requires an ActionListener as an argument. How would I go about removing the action listeners?

for (int i=0; i < button.length; i++){
    button[i] = new JButton();
    button[i].addActionListener(listener.new ButtonListener());
}
like image 850
comp sci balla Avatar asked Oct 28 '10 23:10

comp sci balla


2 Answers

You can get them with: getActionListeners method:

for( JButton currentButton: button ) {
    for( ActionListener al : currentButton.getActionListeners() ) {
        currentButton.removeActionListener( al );
    }
}

I'm not sure if it will thrown a ConcurrentModificationException though.

like image 61
OscarRyz Avatar answered Sep 23 '22 16:09

OscarRyz


I understand your question, and as others have suggested, iterating through all the actions listeners from the client class may solve your immediate problem.

  1. H/w in this case, what you are really trying to do is extend the functionality of a JButton, and that is one way to tackle this problem - extend JButton and add a method called removeAllActionListeners() (which does not take any parameters).

    • Inside this method you can iterate through all action listeners and remove them. I think it is better design if you do this here than in the client class.
  2. If you don't want to do that, then I think Tom Hawtin's suggestion to use state within your ButtonListener is a good idea.

  3. Failing which, you always have the option of falling back on a very "hacky" way, which is to store a collection of the action listeners in your client class.

    • Map<JButton, ButtonListener> (if there's always only going to be one listener per button), or
    • Map<JButton, List<ButtonListener>> (if there can be multiple listeners per button) is what I might use.

I think methods 1 and 2 are preferable, and method 3 indicates poor design (but is much easier to hack together).

Note that, if you do indeed use method 1, or something similar, check that the methods or attributes you are accessing are thread safe (as mentioned by OscarRyz), and if not, use synchronized to ensure thread safety.

like image 34
bguiz Avatar answered Sep 22 '22 16:09

bguiz