public class Choice extends Component implements ItemSelectable, Accessible
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.
 
 Some native platforms do not support arbitrary resizing of
 Choice components and the behavior of
 setSize()/getSize() is bound by
 such limitations.
 Native GUI Choice components' size are often bound by such
 attributes as font size and length of items contained within
 the Choice.
 
| Modifier and Type | Class and Description | 
|---|---|
| protected class  | Choice.AccessibleAWTChoiceThis class implements accessibility support for the
  Choiceclass. | 
Component.AccessibleAWTComponent, Component.BaselineResizeBehavior, Component.BltBufferStrategy, Component.FlipBufferStrategyaccessibleContext, BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENTABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH| Constructor and Description | 
|---|
| Choice()Creates a new choice menu. | 
| Modifier and Type | Method and Description | 
|---|---|
| void | add(String item)Adds an item to this  Choicemenu. | 
| void | addItem(String item)Obsolete as of Java 2 platform v1.1. | 
| void | addItemListener(ItemListener l)Adds the specified item listener to receive item events from
 this  Choicemenu. | 
| void | addNotify()Creates the  Choice's peer. | 
| int | countItems()Deprecated. 
 As of JDK version 1.1,
 replaced by  getItemCount(). | 
| AccessibleContext | getAccessibleContext()Gets the  AccessibleContextassociated with thisChoice. | 
| String | getItem(int index)Gets the string at the specified index in this
  Choicemenu. | 
| int | getItemCount()Returns the number of items in this  Choicemenu. | 
| ItemListener[] | getItemListeners()Returns an array of all the item listeners
 registered on this choice. | 
| <T extends EventListener> | getListeners(Class<T> listenerType)Returns an array of all the objects currently registered
 as  FooListeners
 upon thisChoice. | 
| 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 a string representing the state of this  Choicemenu. | 
| protected void | processEvent(AWTEvent e)Processes events on this choice. | 
| protected void | processItemEvent(ItemEvent e)Processes item events occurring on this  Choicemenu by dispatching them to any registeredItemListenerobjects. | 
| void | remove(int position)Removes an item from the choice menu
 at the specified position. | 
| void | remove(String item)Removes the first occurrence of  itemfrom theChoicemenu. | 
| 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  Choicemenu. | 
| void | select(int pos)Sets the selected item in this  Choicemenu to be the
 item at the specified position. | 
| void | select(String str)Sets the selected item in this  Choicemenu
 to be the item whose name is equal to the specified string. | 
action, add, addComponentListener, addFocusListener, addHierarchyBoundsListener, addHierarchyListener, addInputMethodListener, addKeyListener, addMouseListener, addMouseMotionListener, addMouseWheelListener, addPropertyChangeListener, addPropertyChangeListener, applyComponentOrientation, areFocusTraversalKeysSet, bounds, checkImage, checkImage, coalesceEvents, contains, contains, createImage, createImage, createVolatileImage, createVolatileImage, deliverEvent, disable, disableEvents, dispatchEvent, doLayout, enable, enable, enableEvents, enableInputMethods, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, firePropertyChange, getAlignmentX, getAlignmentY, getBackground, getBaseline, getBaselineResizeBehavior, getBounds, getBounds, getColorModel, getComponentAt, getComponentAt, getComponentListeners, getComponentOrientation, getCursor, getDropTarget, getFocusCycleRootAncestor, getFocusListeners, getFocusTraversalKeys, getFocusTraversalKeysEnabled, getFont, getFontMetrics, getForeground, getGraphics, getGraphicsConfiguration, getHeight, getHierarchyBoundsListeners, getHierarchyListeners, getIgnoreRepaint, getInputContext, getInputMethodListeners, getInputMethodRequests, getKeyListeners, getLocale, getLocation, getLocation, getLocationOnScreen, getMaximumSize, getMinimumSize, getMouseListeners, getMouseMotionListeners, getMousePosition, getMouseWheelListeners, getName, getParent, getPeer, getPreferredSize, getPropertyChangeListeners, getPropertyChangeListeners, getSize, getSize, getToolkit, getTreeLock, getWidth, getX, getY, gotFocus, handleEvent, hasFocus, hide, imageUpdate, inside, invalidate, isBackgroundSet, isCursorSet, isDisplayable, isDoubleBuffered, isEnabled, isFocusable, isFocusCycleRoot, isFocusOwner, isFocusTraversable, isFontSet, isForegroundSet, isLightweight, isMaximumSizeSet, isMinimumSizeSet, isOpaque, isPreferredSizeSet, isShowing, isValid, isVisible, keyDown, keyUp, layout, list, list, list, list, list, locate, location, lostFocus, minimumSize, mouseDown, mouseDrag, mouseEnter, mouseExit, mouseMove, mouseUp, move, nextFocus, paint, paintAll, postEvent, preferredSize, prepareImage, prepareImage, print, printAll, processComponentEvent, processFocusEvent, processHierarchyBoundsEvent, processHierarchyEvent, processInputMethodEvent, processKeyEvent, processMouseEvent, processMouseMotionEvent, processMouseWheelEvent, remove, removeComponentListener, removeFocusListener, removeHierarchyBoundsListener, removeHierarchyListener, removeInputMethodListener, removeKeyListener, removeMouseListener, removeMouseMotionListener, removeMouseWheelListener, removeNotify, removePropertyChangeListener, removePropertyChangeListener, repaint, repaint, repaint, repaint, requestFocus, requestFocus, requestFocusInWindow, requestFocusInWindow, reshape, resize, resize, revalidate, setBackground, setBounds, setBounds, setComponentOrientation, setCursor, setDropTarget, setEnabled, setFocusable, setFocusTraversalKeys, setFocusTraversalKeysEnabled, setFont, setForeground, setIgnoreRepaint, setLocale, setLocation, setLocation, setMaximumSize, setMinimumSize, setName, setPreferredSize, setSize, setSize, setVisible, show, show, size, toString, transferFocus, transferFocusBackward, transferFocusUpCycle, update, validatepublic Choice()
       throws HeadlessException
 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.
HeadlessException - if GraphicsEnvironment.isHeadless()
 returns trueGraphicsEnvironment.isHeadless(), 
select(int), 
select(java.lang.String)public void addNotify()
Choice's peer.  This peer allows us
 to change the look
 of the Choice without changing its functionality.addNotify in class ComponentToolkit.createChoice(java.awt.Choice), 
Component.getToolkit()public int getItemCount()
Choice menu.Choice menugetItem(int)@Deprecated public int countItems()
getItemCount().public String getItem(int index)
Choice menu.index - the index at which to begingetItemCount()public void add(String item)
Choice menu.item - the item to be addedNullPointerException - if the item's value is
                  nullpublic void addItem(String item)
add method instead.
 
 Adds an item to this Choice menu.
item - the item to be addedNullPointerException - if the item's value is equal to
          nullpublic void insert(String item, int index)
index are shifted up by one to accommodate
 the new item.  If index is greater than or
 equal to the number of items in this choice,
 item is added to the end of this choice.
 If the item is the first one being added to the choice, then the item becomes selected. Otherwise, if the selected item was one of the items shifted, the first item in the choice becomes the selected item. If the selected item was no among those shifted, it remains the selected item.
item - the non-null item to be insertedindex - the position at which the item should be insertedIllegalArgumentException - if index is less than 0public void remove(String item)
item
 from the Choice menu.  If the item
 being removed is the currently selected item,
 then the first item in the choice becomes the
 selected item.  Otherwise, the currently selected
 item remains selected (and the selected index is
 updated accordingly).item - the item to remove from this Choice menuIllegalArgumentException - if the item doesn't
                     exist in the choice menupublic void remove(int position)
position - the position of the itemIndexOutOfBoundsException - if the specified
          position is out of boundspublic void removeAll()
remove(java.lang.String)public String getSelectedItem()
getSelectedIndex()public Object[] getSelectedObjects()
null.getSelectedObjects in interface ItemSelectableItemSelectablepublic int getSelectedIndex()
getSelectedItem()public void select(int pos)
Choice menu to be the
 item at the specified position.
 Note that this method should be primarily used to
 initially select an item in this component.
 Programmatically calling this method will not trigger
 an ItemEvent.  The only way to trigger an
 ItemEvent is by user interaction.
pos - the position of the selected itemIllegalArgumentException - if the specified
                            position is greater than the
                            number of items or less than zerogetSelectedItem(), 
getSelectedIndex()public void select(String str)
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.
 Note that this method should be primarily used to
 initially select an item in this component.
 Programmatically calling this method will not trigger
 an ItemEvent.  The only way to trigger an
 ItemEvent is by user interaction.
str - the specified stringgetSelectedItem(), 
getSelectedIndex()public void addItemListener(ItemListener l)
Choice menu.  Item events are sent in response
 to user input, but not in response to calls to select.
 If l is null, no exception is thrown and no action
 is performed.
 Refer to AWT Threading Issues for details on AWT's threading model.
addItemListener in interface ItemSelectablel - the item listenerremoveItemListener(java.awt.event.ItemListener), 
getItemListeners(), 
select(int), 
ItemEvent, 
ItemListenerpublic void removeItemListener(ItemListener l)
Choice menu.
 If l is null, no exception is thrown and no
 action is performed.
 Refer to AWT Threading Issues for details on AWT's threading model.
removeItemListener in interface ItemSelectablel - the item listeneraddItemListener(java.awt.event.ItemListener), 
getItemListeners(), 
ItemEvent, 
ItemListenerpublic ItemListener[] getItemListeners()
ItemListeners
         or an empty array if no item
         listeners are currently registeredaddItemListener(java.awt.event.ItemListener), 
removeItemListener(java.awt.event.ItemListener), 
ItemEvent, 
ItemListenerpublic <T extends EventListener> T[] getListeners(Class<T> listenerType)
FooListeners
 upon this Choice.
 FooListeners are registered using the
 addFooListener method.
 
 You can specify the listenerType argument
 with a class literal, such as
 FooListener.class.
 For example, you can query a
 Choice c
 for its item listeners with the following code:
 
ItemListener[] ils = (ItemListener[])(c.getListeners(ItemListener.class));If no such listeners exist, this method returns an empty array.
getListeners in class ComponentlistenerType - the type of listeners requested; this parameter
          should specify an interface that descends from
          java.util.EventListenerFooListeners on this choice,
          or an empty array if no such
          listeners have been addedClassCastException - if listenerType
          doesn't specify a class or interface that implements
          java.util.EventListenergetItemListeners()protected void processEvent(AWTEvent e)
ItemEvent, it invokes the
 processItemEvent method. Otherwise, it calls its
 superclass's processEvent method.
 Note that if the event parameter is null
 the behavior is unspecified and may result in an
 exception.
processEvent in class Componente - the eventItemEvent, 
processItemEvent(java.awt.event.ItemEvent)protected void processItemEvent(ItemEvent e)
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:
ItemListener object is registered
 via addItemListener.
 enableEvents.
 Note that if the event parameter is null
 the behavior is unspecified and may result in an
 exception.
e - the item eventItemEvent, 
ItemListener, 
addItemListener(ItemListener), 
Component.enableEvents(long)protected String paramString()
Choice
 menu. This method is intended to be used only for debugging purposes,
 and the content and format of the returned string may vary between
 implementations. The returned string may be empty but may not be
 null.paramString in class ComponentChoice menupublic AccessibleContext getAccessibleContext()
AccessibleContext associated with this
 Choice. For Choice components,
 the AccessibleContext takes the form of an
 AccessibleAWTChoice. A new AccessibleAWTChoice
 instance is created if necessary.getAccessibleContext in interface AccessiblegetAccessibleContext in class ComponentAccessibleAWTChoice that serves as the
         AccessibleContext of this Choice Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2023, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.