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());
}
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.
I understand your question, and as others have suggested, iterating through all the actions listeners from the client class may solve your immediate problem.
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).
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.
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), orMap<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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With