1. /*
  2. * @(#)ItemEvent.java 1.26 03/01/23
  3. *
  4. * Copyright 2003 Sun Microsystems, Inc. All rights reserved.
  5. * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
  6. */
  7. package java.awt.event;
  8. import java.awt.Component;
  9. import java.awt.AWTEvent;
  10. import java.awt.Event;
  11. import java.awt.ItemSelectable;
  12. /**
  13. * A semantic event which indicates that an item was selected or deselected.
  14. * This high-level event is generated by an ItemSelectable object (such as a
  15. * List) when an item is selected or deselected by the user.
  16. * The event is passed to every <code>ItemListener</code> object which
  17. * registered to receive such events using the component's
  18. * <code>addItemListener</code> method.
  19. * <P>
  20. * The object that implements the <code>ItemListener</code> interface gets
  21. * this <code>ItemEvent</code> when the event occurs. The listener is
  22. * spared the details of processing individual mouse movements and mouse
  23. * clicks, and can instead process a "meaningful" (semantic) event like
  24. * "item selected" or "item deselected".
  25. *
  26. * @version 1.26 01/23/03
  27. * @author Carl Quinn
  28. *
  29. * @see java.awt.ItemSelectable
  30. * @see ItemListener
  31. * @see <a href="http://java.sun.com/docs/books/tutorial/post1.0/ui/itemlistener.html">Tutorial: Writing an Item Listener</a>
  32. * @see <a href="http://www.awl.com/cp/javaseries/jcl1_2.html">Reference: The Java Class Libraries (update file)</a>
  33. *
  34. * @since 1.1
  35. */
  36. public class ItemEvent extends AWTEvent {
  37. /**
  38. * The first number in the range of ids used for item events.
  39. */
  40. public static final int ITEM_FIRST = 701;
  41. /**
  42. * The last number in the range of ids used for item events.
  43. */
  44. public static final int ITEM_LAST = 701;
  45. /**
  46. * This event id indicates that an item's state changed.
  47. */
  48. public static final int ITEM_STATE_CHANGED = ITEM_FIRST; //Event.LIST_SELECT
  49. /**
  50. * This state-change value indicates that an item was selected.
  51. */
  52. public static final int SELECTED = 1;
  53. /**
  54. * This state-change-value indicates that a selected item was deselected.
  55. */
  56. public static final int DESELECTED = 2;
  57. /**
  58. * The item whose selection state has changed.
  59. *
  60. * @serial
  61. * @see #getItem()
  62. */
  63. Object item;
  64. /**
  65. * <code>stateChange</code> indicates whether the <code>item</code>
  66. * was selected or deselected.
  67. *
  68. * @serial
  69. * @see #getStateChange()
  70. */
  71. int stateChange;
  72. /*
  73. * JDK 1.1 serialVersionUID
  74. */
  75. private static final long serialVersionUID = -608708132447206933L;
  76. /**
  77. * Constructs an <code>ItemEvent</code> object.
  78. * <p>Note that passing in an invalid <code>id</code> results in
  79. * unspecified behavior.
  80. *
  81. * @param source the <code>ItemSelectable</code> object
  82. * that originated the event
  83. * @param id an integer that identifies the event type
  84. * @param item an object -- the item affected by the event
  85. * @param stateChange
  86. * an integer that indicates whether the item was
  87. * selected or deselected
  88. */
  89. public ItemEvent(ItemSelectable source, int id, Object item, int stateChange) {
  90. super(source, id);
  91. this.item = item;
  92. this.stateChange = stateChange;
  93. }
  94. /**
  95. * Returns the originator of the event.
  96. *
  97. * @return the ItemSelectable object that originated the event.
  98. */
  99. public ItemSelectable getItemSelectable() {
  100. return (ItemSelectable)source;
  101. }
  102. /**
  103. * Returns the item affected by the event.
  104. *
  105. * @return the item (object) that was affected by the event
  106. */
  107. public Object getItem() {
  108. return item;
  109. }
  110. /**
  111. * Returns the type of state change (selected or deselected).
  112. *
  113. * @return an integer that indicates whether the item was selected
  114. * or deselected
  115. *
  116. * @see #SELECTED
  117. * @see #DESELECTED
  118. */
  119. public int getStateChange() {
  120. return stateChange;
  121. }
  122. /**
  123. * Returns a parameter string identifying this item event.
  124. * This method is useful for event-logging and for debugging.
  125. *
  126. * @return a string identifying the event and its attributes
  127. */
  128. public String paramString() {
  129. String typeStr;
  130. switch(id) {
  131. case ITEM_STATE_CHANGED:
  132. typeStr = "ITEM_STATE_CHANGED";
  133. break;
  134. default:
  135. typeStr = "unknown type";
  136. }
  137. String stateStr;
  138. switch(stateChange) {
  139. case SELECTED:
  140. stateStr = "SELECTED";
  141. break;
  142. case DESELECTED:
  143. stateStr = "DESELECTED";
  144. break;
  145. default:
  146. stateStr = "unknown type";
  147. }
  148. return typeStr + ",item="+item + ",stateChange="+stateStr;
  149. }
  150. }