|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object uic.model.UICSimpleAction uic.action.SwingAction uic.action.ListSelectionAction
public class ListSelectionAction
When your users select an item from a List or JTable component a method of your choosing will be invoked.
Notice that the default version uses the OnlyLastPolicy
.
Using this class is easy; just call:
new ListSelectionAction(this, "selectedSlot").add(myList);This has the result that when the user clicks on the list the method 'selectedSlot' on object 'this' will be called.
ARGUMENT_SOURCE
ARGUMENT_SELECTEDROW
ARGUMENT_SELECTEDCOL
Nested Class Summary |
---|
Nested classes/interfaces inherited from class uic.model.UICSimpleAction |
---|
UICSimpleAction.Arguments, UICSimpleAction.DirectMultiThreadingPolicy, UICSimpleAction.DirectPolicy, UICSimpleAction.ExecutePolicy, UICSimpleAction.OnlyLastPolicy, UICSimpleAction.QueuedPolicy, UICSimpleAction.SimpleQueuedPolicy |
Field Summary | |
---|---|
static String |
ARGUMENT_SELECTEDCOL
an int: the selected column. |
static String |
ARGUMENT_SELECTEDROW
an int: the selected row. |
static String |
ARGUMENT_SOURCE
an Object: the source object that threw the event (a ListSelectionModel). |
Fields inherited from class uic.action.SwingAction |
---|
updateUICommmand |
Fields inherited from class uic.model.UICSimpleAction |
---|
currentPolicy, target, targetObject |
Constructor Summary | |
---|---|
ListSelectionAction(Object targetObject,
String targetMethod)
Create a new ListSelectionAction |
|
ListSelectionAction(Object targetObject,
String targetMethod,
UICSimpleAction.Arguments arguments)
Create a new ListSelectionAction. |
Method Summary | |
---|---|
ListSelectionAction |
add(JList list)
Add an ItemSelectable object to this action |
ListSelectionAction |
add(JTable table)
Add an ItemSelectable object to this action |
protected Class |
getArgumentClass(String argumentType)
For the uniquely defined argumentType (as also used in UICSimpleAction.getTargetSignatures() ) return the Class. |
protected Object |
getArgumentValue(EventObject source,
String argumentType)
For the uniquely defined argumentType (as also used in UICSimpleAction.getTargetSignatures() ) return the value. |
protected List |
getTargetSignatures()
Return a List object with instances of the Arguments class. |
void |
mouseClicked(MouseEvent e)
Implementation of MouseListener interface. |
void |
mouseEntered(MouseEvent e)
Implementation of MouseListener interface. |
void |
mouseExited(MouseEvent e)
Implementation of MouseListener interface. |
void |
mousePressed(MouseEvent e)
Implementation of MouseListener interface. |
void |
mouseReleased(MouseEvent e)
Implementation of MouseListener interface. |
void |
selectionChanged()
This method is called directly after all events which come from one action are handled. |
void |
valueChanged(ListSelectionEvent e)
Implementation of ListSelectionListener interface. |
Methods inherited from class uic.action.SwingAction |
---|
doAction, getComponentsIterator, registerComponent, setEnabled, setUIUpdateCommand, setUIUpdateCommand |
Methods inherited from class uic.model.UICSimpleAction |
---|
createArguments, equals, execute, execute, execute, execute, isEnabled, setDirect, setExecutionPolicy, setTarget, setTarget |
Methods inherited from class java.lang.Object |
---|
clone, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final String ARGUMENT_SOURCE
public static final String ARGUMENT_SELECTEDROW
public static final String ARGUMENT_SELECTEDCOL
Constructor Detail |
---|
public ListSelectionAction(Object targetObject, String targetMethod)
targetObject
- on which object should the target method be invokedtargetMethod
- wich method on the targetObject should be invokedpublic ListSelectionAction(Object targetObject, String targetMethod, UICSimpleAction.Arguments arguments)
targetObject
- on which object should the target method be invokedtargetMethod
- wich method on the targetObject should be invokedarguments
- to be used in finding the targetMethod signatureUICSimpleAction.setTarget(Object,String,uic.model.UICSimpleAction.Arguments)
Method Detail |
---|
public ListSelectionAction add(JList list)
list
- the list that triggers this actionpublic ListSelectionAction add(JTable table)
table
- the table that triggers this actionprotected List getTargetSignatures()
UICSimpleAction
An example implementation could be this:
List result = new ArrayList(1); result.add( new Arguments().addArgument("Source") ); return result;This will result in a call to
UICSimpleAction.getArgumentClass(java.lang.String)
with the string
"Source"
which returns a Class instance. In our example
that would be java.lang.Object
.
The result of this would be that a call to setTarget
will try to find a method with an argument of type Object, and will search again
if that is not found without any arguments.
getTargetSignatures
in class UICSimpleAction
UICSimpleAction.getArgumentValue(java.util.EventObject, java.lang.String)
,
UICSimpleAction.getArgumentClass(java.lang.String)
protected Object getArgumentValue(EventObject source, String argumentType)
UICSimpleAction
UICSimpleAction.getTargetSignatures()
) return the value.
This method will always return 'null';
Extending actions can define various argumentType strings that can be used as an
argument in the call to the target method of this action.
The user decides on construction of the action which argumentTypes are to be used,
if a certain value is requested to be sent to the targetMethod a call is made to this
method to find its value based on the source event.
Note that base types can not be returned, since they are instances of object; you should wrap these in their object re-presentation (an Integer object for an int).
getArgumentValue
in class UICSimpleAction
source
- the event that caused the action to be fired. This is the event that
the extending class passed to the execute
method; so casting is fine.argumentType
- the uniquely defined name specifying the type of argument.
protected Class getArgumentClass(String argumentType)
UICSimpleAction
UICSimpleAction.getTargetSignatures()
) return the Class.
This method will always return 'null';
Extending actions can define various argumentType strings that can be used as an
argument in the call to the target method of this action.
The user decides on construction of the action which argumentTypes are to be used,
if a certain value is requested to be sent to the targetMethod a call is made to this
method to find the Class of the type.
Note that basetypes have a class of their own and you should return the correct
one you expect the targetMethod to implement. returning Integer.class
will search for an Integer
; returing int.class
will search
for an int
. This is important to note since the UICSimpleAction.getArgumentValue(java.util.EventObject, java.lang.String)
method should return an Integer object in both cases.
getArgumentClass
in class UICSimpleAction
argumentType
- the uniquely defined name specifying the type of argument.
public void valueChanged(ListSelectionEvent e)
valueChanged
in interface ListSelectionListener
IllegalStateException
- if the event is not dispatched on the AWT event thread.public void mouseClicked(MouseEvent e)
mouseClicked
in interface MouseListener
public void mouseEntered(MouseEvent e)
mouseEntered
in interface MouseListener
public void mouseExited(MouseEvent e)
mouseExited
in interface MouseListener
public void mousePressed(MouseEvent e)
mousePressed
in interface MouseListener
public void mouseReleased(MouseEvent e)
mouseReleased
in interface MouseListener
IllegalStateException
- if the event is not coming from the AWT event thread.public void selectionChanged()
IllegalStateException
- if the event is not coming from the AWT event thread.
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |