java.awt
Class Choice

java.lang.Object
  |
  +--java.awt.Component
        |
        +--java.awt.Choice

public class Choice
extends Component
implements ItemSelectable

The Choice class presents a pop-up menu of choices. The current choice is displayed as the title of the menu.

The following code example produces a pop-up menu:


 Choice ColorChooser = new Choice();
 ColorChooser.add("Green");
 ColorChooser.add("Red");
 ColorChooser.add("Blue");
 

After this choice menu has been added to a panel, it appears as follows in its normal state:

In the picture, "Green" is the current choice. Pushing the mouse button down on the object causes a menu to appear with the current choice highlighted.

Since:
JDK1.0
See Also:
Serialized Form

Inner classes inherited from class java.awt.Component
Component.AWTTreeLock, Component.NativeInLightFixer
 
Field Summary
private static String base
           
private  int choiceSerializedDataVersion
           
(package private)  ItemListener itemListener
           
private static int nameCounter
           
(package private)  Vector pItems
          The items for the Choice.
(package private)  int selectedIndex
          The index of the current choice for this Choice.
private static long serialVersionUID
           
 
Fields inherited from class java.awt.Component
actionListenerK, adjustmentListenerK, appContext, assert, background, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, changeSupport, componentListener, componentListenerK, componentOrientation, componentSerializedDataVersion, containerListenerK, cursor, dropTarget, enabled, eventMask, focusListener, focusListenerK, font, foreground, hasFocus, height, incRate, inputMethodListener, inputMethodListenerK, isInc, isPacked, itemListenerK, keyListener, keyListenerK, LEFT_ALIGNMENT, locale, LOCK, minSize, mouseListener, mouseListenerK, mouseMotionListener, mouseMotionListenerK, name, nameExplicitlySet, newEventsOnly, ownedWindowK, parent, peer, peerFont, popups, prefSize, RIGHT_ALIGNMENT, serialVersionUID, textListenerK, TOP_ALIGNMENT, valid, visible, width, windowListenerK, x, y
 
Constructor Summary
Choice()
          Creates a new choice menu.
 
Method Summary
 void add(String item)
          Adds an item to this Choice menu.
 void addItem(String item)
          Adds an item to this Choice.
 void addItemListener(ItemListener l)
          Adds the specified item listener to receive item events from this Choice menu.
private  void addItemNoInvalidate(String item)
          Adds an item to this Choice, but does not invalidate the Choice.
 void addNotify()
          Creates the Choice's peer.
(package private)  String constructComponentName()
          Construct a name for this component.
 int countItems()
          Deprecated. As of JDK version 1.1, replaced by getItemCount().
(package private)  boolean eventEnabled(AWTEvent e)
           
 String getItem(int index)
          Gets the string at the specified index in this Choice menu.
 int getItemCount()
          Returns the number of items in this Choice menu.
(package private)  String getItemImpl(int index)
           
 int getSelectedIndex()
          Returns the index of the currently selected item.
 String getSelectedItem()
          Gets a representation of the current choice as a string.
 Object[] getSelectedObjects()
          Returns an array (length 1) containing the currently selected item.
 void insert(String item, int index)
          Inserts the item into this choice at the specified position.
protected  String paramString()
          Returns the parameter string representing the state of this choice menu.
protected  void processEvent(AWTEvent e)
          Processes events on this choice.
protected  void processItemEvent(ItemEvent e)
          Processes item events occurring on this Choice menu by dispatching them to any registered ItemListener objects.
private  void readObject(ObjectInputStream s)
           
 void remove(int position)
          Removes an item from the choice menu at the specified position.
 void remove(String item)
          Remove the first occurrence of item from the Choice menu.
 void removeAll()
          Removes all items from the choice menu.
 void removeItemListener(ItemListener l)
          Removes the specified item listener so that it no longer receives item events from this Choice menu.
private  void removeNoInvalidate(int position)
          Removes an item from the Choice at the specified position, but does not invalidate the Choice.
 void select(int pos)
          Sets the selected item in this Choice menu to be the item at the specified position.
 void select(String str)
          Sets the selected item in this Choice menu to be the item whose name is equal to the specified string.
private  void writeObject(ObjectOutputStream s)
          Writes default serializable fields to stream.
 
Methods inherited from class java.awt.Component
, action, add, addComponentListener, addFocusListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addPropertyChangeListener, addPropertyChangeListener, areInputMethodsEnabled, bounds, checkImage, checkImage, coalesceEvents, contains, contains, createImage, createImage, deliverEvent, disable, disableEvents, dispatchEvent, dispatchEventImpl, doLayout, enable, enable, enableEvents, enableInputMethods, firePropertyChange, getAlignmentX, getAlignmentY, getBackground, getBounds, getBounds, getColorModel, getComponentAt, getComponentAt, getComponentOrientation, getCursor, getDropTarget, getFont_NoClientCode, getFont, getFontMetrics, getForeground, getGraphics, getHeight, getInputContext, getInputMethodRequests, getLocale, getLocation, getLocation, getLocationOnScreen, getMaximumSize, getMinimumSize, getName, getNativeContainer, getParent_NoClientCode, getParent, getPeer, getPreferredSize, getSize, getSize, getToolkit, getToolkitImpl, getTreeLock, getWidth, getWindowForObject, getX, getY, gotFocus, handleEvent, hasFocus, hide, imageUpdate, initIDs, inside, invalidate, isDisplayable, isDoubleBuffered, isEnabled, isEnabledImpl, isFocusTraversable, isLightweight, isOpaque, isShowing, isValid, isVisible, keyDown, keyUp, layout, lightweightPrint, list, list, list, list, list, locate, location, lostFocus, minimumSize, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paint, paintAll, postEvent, postsOldMouseEvents, preferredSize, prepareImage, prepareImage, print, printAll, processComponentEvent, processFocusEvent, processInputMethodEvent, processKeyEvent, processMouseEvent, processMouseMotionEvent, remove, removeComponentListener, removeFocusListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeNotify, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, repaint, requestFocus, reshape, resize, resize, setBackground, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setEnabled, setFont, setForeground, setLocale, setLocation, setLocation, setName, setSize, setSize, setVisible, show, show, size, toString, transferFocus, update, validate
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, registerNatives, wait, wait, wait
 

Field Detail

pItems

Vector pItems
The items for the Choice. This can be a null value.
See Also:
add(), addItem(), getItem(), getItemCount(), insert(), remove()

selectedIndex

int selectedIndex
The index of the current choice for this Choice.
See Also:
getSelectedItem, select()

itemListener

transient ItemListener itemListener

base

private static final String base

nameCounter

private static int nameCounter

serialVersionUID

private static final long serialVersionUID

choiceSerializedDataVersion

private int choiceSerializedDataVersion
Constructor Detail

Choice

public Choice()
Creates a new choice menu. The menu initially has no items in it.

By default, the first item added to the choice menu becomes the selected item, until a different selection is made by the user by calling one of the select methods.

See Also:
select(int), select(java.lang.String)
Method Detail

constructComponentName

String constructComponentName()
Construct a name for this component. Called by getName() when the name is null.
Overrides:
constructComponentName in class Component

addNotify

public void addNotify()
Creates the Choice's peer. This peer allows us to change the look of the Choice without changing its functionality.
Overrides:
addNotify in class Component
See Also:
Toolkit.createChoice(java.awt.Choice), Component.getToolkit()

getItemCount

public int getItemCount()
Returns the number of items in this Choice menu.
Since:
JDK1.1
See Also:
getItem(int)

countItems

public int countItems()
Deprecated. As of JDK version 1.1, replaced by getItemCount().

getItem

public String getItem(int index)
Gets the string at the specified index in this Choice menu.
Parameters:
index - the index at which to begin.
See Also:
getItemCount()

getItemImpl

final String getItemImpl(int index)

add

public void add(String item)
Adds an item to this Choice menu.
Parameters:
item - the item to be added
Throws:
NullPointerException - if the item's value is null.
Since:
JDK1.1

addItem

public void addItem(String item)
Adds an item to this Choice.
Parameters:
item - the item to be added
Throws:
NullPointerException - If the item's value is equal to null.

addItemNoInvalidate

private void addItemNoInvalidate(String item)
Adds an item to this Choice, but does not invalidate the Choice. Client methods must provide their own synchronization before invoking this method.
Parameters:
item - the item to be added
Throws:
NullPointerException - If the item's value is equal to null.

insert

public void insert(String item,
                   int index)
Inserts the item into this choice at the specified position.
Parameters:
item - the item to be inserted
index - the position at which the item should be inserted
Throws:
IllegalArgumentException - if index is less than 0.

remove

public void remove(String item)
Remove the first occurrence of item from the Choice menu.
Parameters:
item - the item to remove from this Choice menu.
Throws:
IllegalArgumentException - if the item doesn't exist in the choice menu.
Since:
JDK1.1

remove

public void remove(int position)
Removes an item from the choice menu at the specified position.
Parameters:
position - the position of the item.
Since:
JDK1.1

removeNoInvalidate

private void removeNoInvalidate(int position)
Removes an item from the Choice at the specified position, but does not invalidate the Choice. Client methods must provide their own synchronization before invoking this method.
Parameters:
position - the position of the item.

removeAll

public void removeAll()
Removes all items from the choice menu.
Since:
JDK1.1
See Also:
remove(java.lang.String)

getSelectedItem

public String getSelectedItem()
Gets a representation of the current choice as a string.
Returns:
a string representation of the currently selected item in this choice menu.
See Also:
getSelectedIndex()

getSelectedObjects

public Object[] getSelectedObjects()
Returns an array (length 1) containing the currently selected item. If this choice has no items, returns null.
Specified by:
getSelectedObjects in interface ItemSelectable
See Also:
ItemSelectable

getSelectedIndex

public int getSelectedIndex()
Returns the index of the currently selected item.
See Also:
getSelectedItem()

select

public void select(int pos)
Sets the selected item in this Choice menu to be the item at the specified position.
Parameters:
pos - the positon of the selected item.
Throws:
IllegalArgumentException - if the specified position is invalid.
See Also:
getSelectedItem(), getSelectedIndex()

select

public void select(String str)
Sets the selected item in this Choice menu to be the item whose name is equal to the specified string. If more than one item matches (is equal to) the specified string, the one with the smallest index is selected.
Parameters:
str - the specified string
See Also:
getSelectedItem(), getSelectedIndex()

addItemListener

public void addItemListener(ItemListener l)
Adds the specified item listener to receive item events from this Choice menu. If l is null, no exception is thrown and no action is performed.
Specified by:
addItemListener in interface ItemSelectable
Parameters:
l - the item listener.
Since:
JDK1.1
See Also:
ItemEvent, ItemListener, removeItemListener(java.awt.event.ItemListener)

removeItemListener

public void removeItemListener(ItemListener l)
Removes the specified item listener so that it no longer receives item events from this Choice menu. If l is null, no exception is thrown and no action is performed.
Specified by:
removeItemListener in interface ItemSelectable
Parameters:
l - the item listener.
Since:
JDK1.1
See Also:
ItemEvent, ItemListener, addItemListener(java.awt.event.ItemListener)

eventEnabled

boolean eventEnabled(AWTEvent e)
Overrides:
eventEnabled in class Component

processEvent

protected void processEvent(AWTEvent e)
Processes events on this choice. If the event is an instance of ItemEvent, it invokes the processItemEvent method. Otherwise, it calls its superclass's processEvent method.
Parameters:
e - the event.
Overrides:
processEvent in class Component
Since:
JDK1.1
See Also:
ItemEvent, processItemEvent(java.awt.event.ItemEvent)

processItemEvent

protected void processItemEvent(ItemEvent e)
Processes item events occurring on this Choice menu by dispatching them to any registered ItemListener objects.

This method is not called unless item events are enabled for this component. Item events are enabled when one of the following occurs:

Parameters:
e - the item event.
Since:
JDK1.1
See Also:
ItemEvent, ItemListener, addItemListener(java.awt.event.ItemListener), Component.enableEvents(long)

paramString

protected String paramString()
Returns the parameter string representing the state of this choice menu. This string is useful for debugging.
Returns:
the parameter string of this Choice menu.
Overrides:
paramString in class Component

writeObject

private void writeObject(ObjectOutputStream s)
                  throws IOException
Writes default serializable fields to stream. Writes a list of serializable ItemListener(s) as optional data. The non-serializable ItemListner(s) are detected and no attempt is made to serialize them.
Overrides:
writeObject in class Component
See Also:
AWTEventMulticaster.save(ObjectOutputStream, String, EventListener), java.awt.Component.itemListenerK

readObject

private void readObject(ObjectInputStream s)
                 throws ClassNotFoundException,
                        IOException
Overrides:
readObject in class Component