jdk/src/share/classes/javax/swing/Action.java
author malenkov
Wed, 07 May 2008 23:20:32 +0400
changeset 466 6acd5ec503a8
parent 2 90ce3da70b43
child 2473 3f4bbd3be2f1
permissions -rw-r--r--
4935607: RFE: LTP: Should be possible to set the TRANSIENT attribute of propertiies to FALSE Summary: Add the Transient annotation and support it (JSR-273) Reviewed-by: peterz, loneid
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
90ce3da70b43 Initial load
duke
parents:
diff changeset
     2
 * Copyright 1997-2006 Sun Microsystems, Inc.  All Rights Reserved.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 * published by the Free Software Foundation.  Sun designates this
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 * by Sun in the LICENSE file that accompanied this code.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    21
 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 * CA 95054 USA or visit www.sun.com if you need additional information or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
 * have any questions.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
package javax.swing;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
import java.awt.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
import java.awt.event.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
import java.beans.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
/**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    32
 * The <code>Action</code> interface provides a useful extension to the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
 * <code>ActionListener</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    34
 * interface in cases where the same functionality may be accessed by
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
 * several controls.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    37
 * In addition to the <code>actionPerformed</code> method defined by the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
 * <code>ActionListener</code> interface, this interface allows the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
 * application to define, in a single place:
90ce3da70b43 Initial load
duke
parents:
diff changeset
    40
 * <ul>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
 * <li>One or more text strings that describe the function. These strings
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
 *     can be used, for example, to display the flyover text for a button
90ce3da70b43 Initial load
duke
parents:
diff changeset
    43
 *     or to set the text in a menu item.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
 * <li>One or more icons that depict the function. These icons can be used
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
 *     for the images in a menu control, or for composite entries in a more
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
 *     sophisticated user interface.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
 * <li>The enabled/disabled state of the functionality. Instead of having
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
 *     to separately disable the menu item and the toolbar button, the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
 *     application can disable the function that implements this interface.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
 *     All components which are registered as listeners for the state change
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
 *     then know to disable event generation for that item and to modify the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
 *     display accordingly.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
 * </ul>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
 * This interface can be added to an existing class or used to create an
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
 * adapter (typically, by subclassing <code>AbstractAction</code>).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
 * The <code>Action</code> object
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
 * can then be added to multiple <code>Action</code>-aware containers
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
 * and connected to <code>Action</code>-capable
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
 * components. The GUI controls can then be activated or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
 * deactivated all at once by invoking the <code>Action</code> object's
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
 * <code>setEnabled</code> method.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
 * Note that <code>Action</code> implementations tend to be more expensive
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
 * in terms of storage than a typical <code>ActionListener</code>,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
 * which does not offer the benefits of centralized control of
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
 * functionality and broadcast of property changes.  For this reason,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
 * you should take care to only use <code>Action</code>s where their benefits
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
 * are desired, and use simple <code>ActionListener</code>s elsewhere.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
 * <h4><a name="buttonActions"></a>Swing Components Supporting <code>Action</code></h4>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
 * Many of Swing's components have an <code>Action</code> property.  When
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
 * an <code>Action</code> is set on a component, the following things
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
 * happen:
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
 * <ul>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
 * <li>The <code>Action</code> is added as an <code>ActionListener</code> to
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
 *     the component.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
 * <li>The component configures some of its properties to match the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
 *      <code>Action</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
 * <li>The component installs a <code>PropertyChangeListener</code> on the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
 *     <code>Action</code> so that the component can change its properties
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
 *     to reflect changes in the <code>Action</code>'s properties.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
 * </ul>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
 * The following table describes the properties used by
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
 * <code>Swing</code> components that support <code>Actions</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
 * In the table, <em>button</em> refers to any
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
 * <code>AbstractButton</code> subclass, which includes not only
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
 * <code>JButton</code> but also classes such as
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
 * <code>JMenuItem</code>. Unless otherwise stated, a
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
 * <code>null</code> property value in an <code>Action</code> (or a
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
 * <code>Action</code> that is <code>null</code>) results in the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
 * button's corresponding property being set to <code>null</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
 * <table border="1" cellpadding="1" cellspacing="0"
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
 *         summary="Supported Action properties"
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
 *         valign="top" >
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
 *    <th bgcolor="#CCCCFF" align="left">Component Property
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
 *    <th bgcolor="#CCCCFF" align="left">Components
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
 *    <th bgcolor="#CCCCFF" align="left">Action Key
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
 *    <th bgcolor="#CCCCFF" align="left">Notes
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
 *      <td><b><code>enabled</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
 *      <td>All
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
 *      <td>The <code>isEnabled</code> method
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
 *      <td>&nbsp;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
 *      <td><b><code>toolTipText</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
 *      <td>All
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
 *      <td><code>SHORT_DESCRIPTION</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
 *      <td>&nbsp;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
 *      <td><b><code>actionCommand</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
 *      <td>All
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
 *      <td><code>ACTION_COMMAND_KEY</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
 *      <td>&nbsp;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
 *      <td><b><code>mnemonic</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   122
 *      <td>All buttons
90ce3da70b43 Initial load
duke
parents:
diff changeset
   123
 *      <td><code>MNEMONIC_KEY</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   124
 *      <td>A <code>null</code> value or <code>Action</code> results in the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   125
 *          button's <code>mnemonic</code> property being set to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   126
 *          <code>'\0'</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   128
 *      <td><b><code>text</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   129
 *      <td>All buttons
90ce3da70b43 Initial load
duke
parents:
diff changeset
   130
 *      <td><code>NAME</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   131
 *      <td>If you do not want the text of the button to mirror that
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
 *          of the <code>Action</code>, set the property
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
 *          <code>hideActionText</code> to <code>true</code>.  If
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
 *          <code>hideActionText</code> is <code>true</code>, setting the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
 *          <code>Action</code> changes the text of the button to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
 *          <code>null</code> and any changes to <code>NAME</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
 *          are ignored.  <code>hideActionText</code> is useful for
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
 *          tool bar buttons that typically only show an <code>Icon</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
 *          <code>JToolBar.add(Action)</code> sets the property to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
 *          <code>true</code> if the <code>Action</code> has a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
 *          non-<code>null</code> value for <code>LARGE_ICON_KEY</code> or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
 *          <code>SMALL_ICON</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
 *      <td><b><code>displayedMnemonicIndex</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
 *      <td>All buttons
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
 *      <td><code>DISPLAYED_MNEMONIC_INDEX_KEY</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
 *      <td>If the value of <code>DISPLAYED_MNEMONIC_INDEX_KEY</code> is
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
 *          beyond the bounds of the text, it is ignored.  When
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
 *          <code>setAction</code> is called, if the value from the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
 *          <code>Action</code> is <code>null</code>, the displayed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
 *          mnemonic index is not updated.  In any subsequent changes to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
 *          <code>DISPLAYED_MNEMONIC_INDEX_KEY</code>, <code>null</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
 *          is treated as -1.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
 *      <td><b><code>icon</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
 *      <td>All buttons except of <code>JCheckBox</code>,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
 *      <code>JToggleButton</code> and <code>JRadioButton</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
 *      <td>either <code>LARGE_ICON_KEY</code> or
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
 *          <code>SMALL_ICON</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
 *     <td>The <code>JMenuItem</code> subclasses only use
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
 *         <code>SMALL_ICON</code>.  All other buttons will use
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
 *         <code>LARGE_ICON_KEY</code>; if the value is <code>null</code> they
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
 *         use <code>SMALL_ICON</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
 *      <td><b><code>accelerator</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
 *      <td>All <code>JMenuItem</code> subclasses, with the exception of
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
 *          <code>JMenu</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
 *      <td><code>ACCELERATOR_KEY</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
 *      <td>&nbsp;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
 *  <tr valign="top"  align="left">
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
 *      <td><b><code>selected</code></b>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
 *      <td><code>JToggleButton</code>, <code>JCheckBox</code>,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
 *          <code>JRadioButton</code>, <code>JCheckBoxMenuItem</code> and
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
 *          <code>JRadioButtonMenuItem</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
 *      <td><code>SELECTED_KEY</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
 *      <td>Components that honor this property only use
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
 *          the value if it is {@code non-null}. For example, if
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
 *          you set an {@code Action} that has a {@code null}
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
 *          value for {@code SELECTED_KEY} on a {@code JToggleButton}, the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
 *          {@code JToggleButton} will not update it's selected state in
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
 *          any way. Similarly, any time the {@code JToggleButton}'s
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
 *          selected state changes it will only set the value back on
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
 *          the {@code Action} if the {@code Action} has a {@code non-null}
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
 *          value for {@code SELECTED_KEY}.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
 *          <br>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
 *          Components that honor this property keep their selected state
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
 *          in sync with this property. When the same {@code Action} is used
90ce3da70b43 Initial load
duke
parents:
diff changeset
   188
 *          with multiple components, all the components keep their selected
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
 *          state in sync with this property. Mutually exclusive
90ce3da70b43 Initial load
duke
parents:
diff changeset
   190
 *          buttons, such as {@code JToggleButton}s in a {@code ButtonGroup},
90ce3da70b43 Initial load
duke
parents:
diff changeset
   191
 *          force only one of the buttons to be selected. As such, do not
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
 *          use the same {@code Action} that defines a value for the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
 *          {@code SELECTED_KEY} property with multiple mutually
90ce3da70b43 Initial load
duke
parents:
diff changeset
   194
 *          exclusive buttons.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   195
 * </table>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   196
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   197
 * <code>JPopupMenu</code>, <code>JToolBar</code> and <code>JMenu</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   198
 * all provide convenience methods for creating a component and setting the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   199
 * <code>Action</code> on the corresponding component.  Refer to each of
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
 * these classes for more information.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   201
 * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   202
 * <code>Action</code> uses <code>PropertyChangeListener</code> to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   203
 * inform listeners the <code>Action</code> has changed.  The beans
90ce3da70b43 Initial load
duke
parents:
diff changeset
   204
 * specification indicates that a <code>null</code> property name can
90ce3da70b43 Initial load
duke
parents:
diff changeset
   205
 * be used to indicate multiple values have changed.  By default Swing
90ce3da70b43 Initial load
duke
parents:
diff changeset
   206
 * components that take an <code>Action</code> do not handle such a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   207
 * change.  To indicate that Swing should treat <code>null</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   208
 * according to the beans specification set the system property
90ce3da70b43 Initial load
duke
parents:
diff changeset
   209
 * <code>swing.actions.reconfigureOnNull</code> to the <code>String</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   210
 * value <code>true</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   211
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   212
 * @author Georges Saab
90ce3da70b43 Initial load
duke
parents:
diff changeset
   213
 * @see AbstractAction
90ce3da70b43 Initial load
duke
parents:
diff changeset
   214
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   215
public interface Action extends ActionListener {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   216
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   217
     * Useful constants that can be used as the storage-retrieval key
90ce3da70b43 Initial load
duke
parents:
diff changeset
   218
     * when setting or getting one of this object's properties (text
90ce3da70b43 Initial load
duke
parents:
diff changeset
   219
     * or icon).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   220
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   221
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   222
     * Not currently used.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   223
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   224
    public static final String DEFAULT = "Default";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   225
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   226
     * The key used for storing the <code>String</code> name
90ce3da70b43 Initial load
duke
parents:
diff changeset
   227
     * for the action, used for a menu or button.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   228
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   229
    public static final String NAME = "Name";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   230
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   231
     * The key used for storing a short <code>String</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   232
     * description for the action, used for tooltip text.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   233
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   234
    public static final String SHORT_DESCRIPTION = "ShortDescription";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   235
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   236
     * The key used for storing a longer <code>String</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   237
     * description for the action, could be used for context-sensitive help.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   238
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   239
    public static final String LONG_DESCRIPTION = "LongDescription";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   240
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   241
     * The key used for storing a small <code>Icon</code>, such
90ce3da70b43 Initial load
duke
parents:
diff changeset
   242
     * as <code>ImageIcon</code>.  This is typically used with
90ce3da70b43 Initial load
duke
parents:
diff changeset
   243
     * menus such as <code>JMenuItem</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   244
     * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   245
     * If the same <code>Action</code> is used with menus and buttons you'll
90ce3da70b43 Initial load
duke
parents:
diff changeset
   246
     * typically specify both a <code>SMALL_ICON</code> and a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   247
     * <code>LARGE_ICON_KEY</code>.  The menu will use the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   248
     * <code>SMALL_ICON</code> and the button will use the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   249
     * <code>LARGE_ICON_KEY</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   250
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   251
    public static final String SMALL_ICON = "SmallIcon";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   252
90ce3da70b43 Initial load
duke
parents:
diff changeset
   253
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   254
     * The key used to determine the command <code>String</code> for the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   255
     * <code>ActionEvent</code> that will be created when an
90ce3da70b43 Initial load
duke
parents:
diff changeset
   256
     * <code>Action</code> is going to be notified as the result of
90ce3da70b43 Initial load
duke
parents:
diff changeset
   257
     * residing in a <code>Keymap</code> associated with a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   258
     * <code>JComponent</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   259
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   260
    public static final String ACTION_COMMAND_KEY = "ActionCommandKey";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   261
90ce3da70b43 Initial load
duke
parents:
diff changeset
   262
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   263
     * The key used for storing a <code>KeyStroke</code> to be used as the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   264
     * accelerator for the action.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   265
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   266
     * @since 1.3
90ce3da70b43 Initial load
duke
parents:
diff changeset
   267
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   268
    public static final String ACCELERATOR_KEY="AcceleratorKey";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   269
90ce3da70b43 Initial load
duke
parents:
diff changeset
   270
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   271
     * The key used for storing an <code>Integer</code> that corresponds to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   272
     * one of the <code>KeyEvent</code> key codes.  The value is
90ce3da70b43 Initial load
duke
parents:
diff changeset
   273
     * commonly used to specify a mnemonic.  For example:
90ce3da70b43 Initial load
duke
parents:
diff changeset
   274
     * <code>myAction.putValue(Action.MNEMONIC_KEY, KeyEvent.VK_A)</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   275
     * sets the mnemonic of <code>myAction</code> to 'a'.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   276
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   277
     * @since 1.3
90ce3da70b43 Initial load
duke
parents:
diff changeset
   278
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   279
    public static final String MNEMONIC_KEY="MnemonicKey";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   280
90ce3da70b43 Initial load
duke
parents:
diff changeset
   281
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   282
     * The key used for storing a <code>Boolean</code> that corresponds
90ce3da70b43 Initial load
duke
parents:
diff changeset
   283
     * to the selected state.  This is typically used only for components
90ce3da70b43 Initial load
duke
parents:
diff changeset
   284
     * that have a meaningful selection state.  For example,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   285
     * <code>JRadioButton</code> and <code>JCheckBox</code> make use of
90ce3da70b43 Initial load
duke
parents:
diff changeset
   286
     * this but instances of <code>JMenu</code> don't.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   287
     * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   288
     * This property differs from the others in that it is both read
90ce3da70b43 Initial load
duke
parents:
diff changeset
   289
     * by the component and set by the component.  For example,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   290
     * if an <code>Action</code> is attached to a <code>JCheckBox</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   291
     * the selected state of the <code>JCheckBox</code> will be set from
90ce3da70b43 Initial load
duke
parents:
diff changeset
   292
     * that of the <code>Action</code>.  If the user clicks on the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   293
     * <code>JCheckBox</code> the selected state of the <code>JCheckBox</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   294
     * <b>and</b> the <code>Action</code> will <b>both</b> be updated.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   295
     * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   296
     * Note: the value of this field is prefixed with 'Swing' to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   297
     * avoid possible collisions with existing <code>Actions</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   298
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   299
     * @since 1.6
90ce3da70b43 Initial load
duke
parents:
diff changeset
   300
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   301
    public static final String SELECTED_KEY = "SwingSelectedKey";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   302
90ce3da70b43 Initial load
duke
parents:
diff changeset
   303
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   304
     * The key used for storing an <code>Integer</code> that corresponds
90ce3da70b43 Initial load
duke
parents:
diff changeset
   305
     * to the index in the text (identified by the <code>NAME</code>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   306
     * property) that the decoration for a mnemonic should be rendered at.  If
90ce3da70b43 Initial load
duke
parents:
diff changeset
   307
     * the value of this property is greater than or equal to the length of
90ce3da70b43 Initial load
duke
parents:
diff changeset
   308
     * the text, it will treated as -1.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   309
     * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   310
     * Note: the value of this field is prefixed with 'Swing' to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   311
     * avoid possible collisions with existing <code>Actions</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   312
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   313
     * @see AbstractButton#setDisplayedMnemonicIndex
90ce3da70b43 Initial load
duke
parents:
diff changeset
   314
     * @since 1.6
90ce3da70b43 Initial load
duke
parents:
diff changeset
   315
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   316
    public static final String DISPLAYED_MNEMONIC_INDEX_KEY =
90ce3da70b43 Initial load
duke
parents:
diff changeset
   317
                                 "SwingDisplayedMnemonicIndexKey";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   318
90ce3da70b43 Initial load
duke
parents:
diff changeset
   319
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   320
     * The key used for storing an <code>Icon</code>.  This is typically
90ce3da70b43 Initial load
duke
parents:
diff changeset
   321
     * used by buttons, such as <code>JButton</code> and
90ce3da70b43 Initial load
duke
parents:
diff changeset
   322
     * <code>JToggleButton</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   323
     * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   324
     * If the same <code>Action</code> is used with menus and buttons you'll
90ce3da70b43 Initial load
duke
parents:
diff changeset
   325
     * typically specify both a <code>SMALL_ICON</code> and a
90ce3da70b43 Initial load
duke
parents:
diff changeset
   326
     * <code>LARGE_ICON_KEY</code>.  The menu will use the
90ce3da70b43 Initial load
duke
parents:
diff changeset
   327
     * <code>SMALL_ICON</code> and the button the <code>LARGE_ICON_KEY</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   328
     * <p>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   329
     * Note: the value of this field is prefixed with 'Swing' to
90ce3da70b43 Initial load
duke
parents:
diff changeset
   330
     * avoid possible collisions with existing <code>Actions</code>.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   331
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   332
     * @since 1.6
90ce3da70b43 Initial load
duke
parents:
diff changeset
   333
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   334
    public static final String LARGE_ICON_KEY = "SwingLargeIconKey";
90ce3da70b43 Initial load
duke
parents:
diff changeset
   335
90ce3da70b43 Initial load
duke
parents:
diff changeset
   336
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   337
     * Gets one of this object's properties
90ce3da70b43 Initial load
duke
parents:
diff changeset
   338
     * using the associated key.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   339
     * @see #putValue
90ce3da70b43 Initial load
duke
parents:
diff changeset
   340
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   341
    public Object getValue(String key);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   342
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   343
     * Sets one of this object's properties
90ce3da70b43 Initial load
duke
parents:
diff changeset
   344
     * using the associated key. If the value has
90ce3da70b43 Initial load
duke
parents:
diff changeset
   345
     * changed, a <code>PropertyChangeEvent</code> is sent
90ce3da70b43 Initial load
duke
parents:
diff changeset
   346
     * to listeners.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   347
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   348
     * @param key    a <code>String</code> containing the key
90ce3da70b43 Initial load
duke
parents:
diff changeset
   349
     * @param value  an <code>Object</code> value
90ce3da70b43 Initial load
duke
parents:
diff changeset
   350
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   351
    public void putValue(String key, Object value);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   352
90ce3da70b43 Initial load
duke
parents:
diff changeset
   353
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   354
     * Sets the enabled state of the <code>Action</code>.  When enabled,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   355
     * any component associated with this object is active and
90ce3da70b43 Initial load
duke
parents:
diff changeset
   356
     * able to fire this object's <code>actionPerformed</code> method.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   357
     * If the value has changed, a <code>PropertyChangeEvent</code> is sent
90ce3da70b43 Initial load
duke
parents:
diff changeset
   358
     * to listeners.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   359
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   360
     * @param  b true to enable this <code>Action</code>, false to disable it
90ce3da70b43 Initial load
duke
parents:
diff changeset
   361
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   362
    public void setEnabled(boolean b);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   363
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   364
     * Returns the enabled state of the <code>Action</code>. When enabled,
90ce3da70b43 Initial load
duke
parents:
diff changeset
   365
     * any component associated with this object is active and
90ce3da70b43 Initial load
duke
parents:
diff changeset
   366
     * able to fire this object's <code>actionPerformed</code> method.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   367
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   368
     * @return true if this <code>Action</code> is enabled
90ce3da70b43 Initial load
duke
parents:
diff changeset
   369
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   370
    public boolean isEnabled();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   371
90ce3da70b43 Initial load
duke
parents:
diff changeset
   372
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   373
     * Adds a <code>PropertyChange</code> listener. Containers and attached
90ce3da70b43 Initial load
duke
parents:
diff changeset
   374
     * components use these methods to register interest in this
90ce3da70b43 Initial load
duke
parents:
diff changeset
   375
     * <code>Action</code> object. When its enabled state or other property
90ce3da70b43 Initial load
duke
parents:
diff changeset
   376
     * changes, the registered listeners are informed of the change.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   377
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   378
     * @param listener  a <code>PropertyChangeListener</code> object
90ce3da70b43 Initial load
duke
parents:
diff changeset
   379
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   380
    public void addPropertyChangeListener(PropertyChangeListener listener);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   381
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   382
     * Removes a <code>PropertyChange</code> listener.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   383
     *
90ce3da70b43 Initial load
duke
parents:
diff changeset
   384
     * @param listener  a <code>PropertyChangeListener</code> object
90ce3da70b43 Initial load
duke
parents:
diff changeset
   385
     * @see #addPropertyChangeListener
90ce3da70b43 Initial load
duke
parents:
diff changeset
   386
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   387
    public void removePropertyChangeListener(PropertyChangeListener listener);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   388
90ce3da70b43 Initial load
duke
parents:
diff changeset
   389
}