2 Copyright (C) 2002, 2004, 2005, 2006, Free Software Foundation, Inc.
4 This file is part of GNU Classpath.
6 GNU Classpath is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2, or (at your option)
11 GNU Classpath is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GNU Classpath; see the file COPYING. If not, write to the
18 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21 Linking this library statically or dynamically with other modules is
22 making a combined work based on this library. Thus, the terms and
23 conditions of the GNU General Public License cover the whole
26 As a special exception, the copyright holders of this library give you
27 permission to link this library with independent modules to produce an
28 executable, regardless of the license terms of these independent
29 modules, and to copy and distribute the resulting executable under
30 terms of your choice, provided that you also meet, for each linked
31 independent module, the terms and conditions of the license of that
32 module. An independent module is a module which is not derived from
33 or based on this library. If you modify this library, you may extend
34 this exception to your version of the library, but you are not
35 obligated to do so. If you do not wish to do so, delete this
36 exception statement from your version. */
41 import gnu
.java
.lang
.CPStringBuilder
;
43 import java
.awt
.Component
;
45 import java
.awt
.FontMetrics
;
46 import java
.awt
.Image
;
47 import java
.awt
.Insets
;
48 import java
.awt
.Point
;
49 import java
.awt
.Rectangle
;
50 import java
.awt
.Shape
;
51 import java
.awt
.event
.KeyEvent
;
52 import java
.beans
.PropertyChangeEvent
;
54 import javax
.accessibility
.Accessible
;
55 import javax
.accessibility
.AccessibleContext
;
56 import javax
.accessibility
.AccessibleExtendedComponent
;
57 import javax
.accessibility
.AccessibleRole
;
58 import javax
.accessibility
.AccessibleText
;
59 import javax
.swing
.plaf
.LabelUI
;
60 import javax
.swing
.plaf
.basic
.BasicHTML
;
61 import javax
.swing
.text
.AttributeSet
;
62 import javax
.swing
.text
.BadLocationException
;
63 import javax
.swing
.text
.Position
;
64 import javax
.swing
.text
.SimpleAttributeSet
;
65 import javax
.swing
.text
.View
;
68 * A component that displays a static text message and/or an icon.
70 public class JLabel
extends JComponent
implements Accessible
, SwingConstants
74 * Provides the accessibility features for the <code>JLabel</code>
77 protected class AccessibleJLabel
78 extends JComponent
.AccessibleJComponent
79 implements AccessibleText
, AccessibleExtendedComponent
83 * Returns the accessible name.
85 * @return The accessible name.
87 public String
getAccessibleName()
89 if (accessibleName
!= null)
90 return accessibleName
;
94 return super.getAccessibleName();
98 * Returns the accessible role for the <code>JLabel</code> component.
100 * @return {@link AccessibleRole#LABEL}.
102 public AccessibleRole
getAccessibleRole()
104 return AccessibleRole
.LABEL
;
108 * Returns the selected text. This is null since JLabels
109 * are not selectable.
111 * @return <code>null</code> because JLabels cannot have selected text
113 public String
getSelectedText()
115 // We return null here since JLabel's text is not selectable.
120 * Returns the start index of the selected text.
122 * @return the start index of the selected text
124 public int getSelectionStart()
126 // JLabel don't have selected text, so we return -1 here.
131 * Returns the end index of the selected text.
133 * @return the end index of the selected text
135 public int getSelectionEnd()
137 // JLabel don't have selected text, so we return -1 here.
142 * Returns an {@link AttributeSet} that reflects the text attributes of
143 * the specified character. We return an empty
144 * <code>AttributeSet</code> here, because JLabels don't support text
145 * attributes (at least not yet).
147 * @param index the index of the character
149 * @return an {@link AttributeSet} that reflects the text attributes of
150 * the specified character
152 public AttributeSet
getCharacterAttribute(int index
)
154 // FIXME: Return null here for simple labels, and query the HTML
155 // view for HTML labels.
156 return new SimpleAttributeSet();
160 * Returns the character, word or sentence at the specified index. The
161 * <code>part</code> parameter determines what is returned, the character,
162 * word or sentence after the index.
164 * @param part one of {@link AccessibleText#CHARACTER},
165 * {@link AccessibleText#WORD} or
166 * {@link AccessibleText#SENTENCE}, specifying what is returned
167 * @param index the index
169 * @return the character, word or sentence after <code>index</code>
171 public String
getAtIndex(int part
, int index
)
178 case AccessibleText
.CHARACTER
:
179 result
= String
.valueOf(text
.charAt(index
));
181 case AccessibleText
.WORD
:
182 startIndex
= text
.lastIndexOf(' ', index
);
183 endIndex
= text
.indexOf(' ', startIndex
+ 1);
185 endIndex
= startIndex
+ 1;
186 result
= text
.substring(startIndex
+ 1, endIndex
);
188 case AccessibleText
.SENTENCE
:
190 startIndex
= text
.lastIndexOf('.', index
);
191 endIndex
= text
.indexOf('.', startIndex
+ 1);
193 endIndex
= startIndex
+ 1;
194 result
= text
.substring(startIndex
+ 1, endIndex
);
201 * Returns the character, word or sentence after the specified index. The
202 * <code>part</code> parameter determines what is returned, the character,
203 * word or sentence after the index.
205 * @param part one of {@link AccessibleText#CHARACTER},
206 * {@link AccessibleText#WORD} or
207 * {@link AccessibleText#SENTENCE}, specifying what is returned
208 * @param index the index
210 * @return the character, word or sentence after <code>index</code>
212 public String
getAfterIndex(int part
, int index
)
219 case AccessibleText
.CHARACTER
:
220 result
= String
.valueOf(text
.charAt(index
+ 1));
222 case AccessibleText
.WORD
:
223 startIndex
= text
.indexOf(' ', index
);
224 endIndex
= text
.indexOf(' ', startIndex
+ 1);
226 endIndex
= startIndex
+ 1;
227 result
= text
.substring(startIndex
+ 1, endIndex
);
229 case AccessibleText
.SENTENCE
:
231 startIndex
= text
.indexOf('.', index
);
232 endIndex
= text
.indexOf('.', startIndex
+ 1);
234 endIndex
= startIndex
+ 1;
235 result
= text
.substring(startIndex
+ 1, endIndex
);
242 * Returns the character, word or sentence before the specified index. The
243 * <code>part</code> parameter determines what is returned, the character,
244 * word or sentence before the index.
246 * @param part one of {@link AccessibleText#CHARACTER},
247 * {@link AccessibleText#WORD} or
248 * {@link AccessibleText#SENTENCE}, specifying what is returned
249 * @param index the index
251 * @return the character, word or sentence before <code>index</code>
253 public String
getBeforeIndex(int part
, int index
)
260 case AccessibleText
.CHARACTER
:
261 result
= String
.valueOf(text
.charAt(index
- 1));
263 case AccessibleText
.WORD
:
264 endIndex
= text
.lastIndexOf(' ', index
);
267 startIndex
= text
.lastIndexOf(' ', endIndex
- 1);
268 result
= text
.substring(startIndex
+ 1, endIndex
);
270 case AccessibleText
.SENTENCE
:
272 endIndex
= text
.lastIndexOf('.', index
);
275 startIndex
= text
.lastIndexOf('.', endIndex
- 1);
276 result
= text
.substring(startIndex
+ 1, endIndex
);
283 * Returns the caret position. This method returns -1 because JLabel don't
286 * @return the caret position
288 public int getCaretPosition()
294 * Returns the number of characters that are displayed by the JLabel.
296 * @return the number of characters that are displayed by the JLabel
298 public int getCharCount()
300 // FIXME: Query HTML view for HTML labels.
301 return text
.length();
305 * Returns the bounding box of the character at the specified index.
307 * @param index the index of the character that we return the
310 * @return the bounding box of the character at the specified index
312 public Rectangle
getCharacterBounds(int index
)
314 Rectangle bounds
= null;
315 View view
= (View
) getClientProperty(BasicHTML
.propertyKey
);
318 Rectangle textR
= getTextRectangle();
321 Shape s
= view
.modelToView(index
, textR
, Position
.Bias
.Forward
);
322 bounds
= s
.getBounds();
324 catch (BadLocationException ex
)
326 // Can't return something reasonable in this case.
333 * Returns the rectangle inside the JLabel, in which the actual text is
334 * rendered. This method has been adopted from the Mauve testcase
335 * gnu.testlet.javax.swing.JLabel.AccessibleJLabel.getCharacterBounds.
337 * @return the rectangle inside the JLabel, in which the actual text is
340 private Rectangle
getTextRectangle()
342 JLabel l
= JLabel
.this;
343 Rectangle textR
= new Rectangle();
344 Rectangle iconR
= new Rectangle();
345 Insets i
= l
.getInsets();
346 int w
= l
.getWidth();
347 int h
= l
.getHeight();
348 Rectangle viewR
= new Rectangle(i
.left
, i
.top
, w
- i
.left
- i
.right
,
349 h
- i
.top
- i
.bottom
);
350 FontMetrics fm
= l
.getFontMetrics(l
.getFont());
351 SwingUtilities
.layoutCompoundLabel(l
, fm
, l
.getText(), l
.getIcon(),
352 l
.getVerticalAlignment(),
353 l
.getHorizontalAlignment(),
354 l
.getVerticalTextPosition(),
355 l
.getHorizontalTextPosition(),
362 * Returns the index of the character that is located at the specified
365 * @param point the location that we lookup the character for
367 * @return the index of the character that is located at the specified
370 public int getIndexAtPoint(Point point
)
373 View view
= (View
) getClientProperty(BasicHTML
.propertyKey
);
376 Rectangle r
= getTextRectangle();
377 index
= view
.viewToModel(point
.x
, point
.y
, r
, new Position
.Bias
[0]);
383 private static final long serialVersionUID
= 5496508283662221534L;
385 static final String LABEL_PROPERTY
= "labeledBy";
388 * The Component the label will give focus to when its mnemonic is
391 protected Component labelFor
;
393 /** The label's text. */
394 transient String text
;
396 /** Where the label will be positioned horizontally. */
397 private transient int horizontalAlignment
= LEADING
;
399 /** Where the label text will be placed horizontally relative to the icon. */
400 private transient int horizontalTextPosition
= TRAILING
;
402 /** Where the label will be positioned vertically. */
403 private transient int verticalAlignment
= CENTER
;
405 /** Where the label text will be place vertically relative to the icon. */
406 private transient int verticalTextPosition
= CENTER
;
408 /** The icon painted when the label is enabled. */
409 private transient Icon icon
;
411 /** The icon painted when the label is disabled. */
412 private transient Icon disabledIcon
;
414 /** The label's mnemnonic key. */
415 private transient int displayedMnemonic
= KeyEvent
.VK_UNDEFINED
;
417 /** The index of the mnemonic character in the text. */
418 private transient int displayedMnemonicIndex
= -1;
420 /** The gap between the icon and the text. */
421 private transient int iconTextGap
= 4;
424 * Creates a new vertically centered, horizontally on the leading edge
425 * JLabel object with text and no icon.
429 this("", null, LEADING
);
433 * Creates a new vertically and horizontally centered
434 * JLabel object with no text and the given icon.
436 * @param image The icon to use with the label, <code>null</code> permitted.
438 public JLabel(Icon image
)
440 this(null, image
, CENTER
);
444 * Creates a new vertically centered JLabel object with no text and the
445 * given icon and horizontal alignment. By default, the text is TRAILING
448 * @param image The icon to use with the label, <code>null</code> premitted.
449 * @param horizontalAlignment The horizontal alignment of the label, must be
450 * either <code>CENTER</code>, <code>LEFT</code>, <code>RIGHT</code>,
451 * <code>LEADING</code> or <code>TRAILING</code>.
453 public JLabel(Icon image
, int horizontalAlignment
)
455 this(null, image
, horizontalAlignment
);
459 * Creates a new horizontally leading and vertically centered JLabel
460 * object with no icon and the given text.
462 * @param text The text to use with the label, <code>null</code> permitted.
464 public JLabel(String text
)
466 this(text
, null, LEADING
);
470 * Creates a new vertically centered JLabel object with no icon and the
471 * given text and horizontal alignment.
473 * @param text The text to use with the label, <code>null</code> permitted.
474 * @param horizontalAlignment The horizontal alignment of the label, must be
475 * either <code>CENTER</code>, <code>LEFT</code>, <code>RIGHT</code>,
476 * <code>LEADING</code> or <code>TRAILING</code>.
478 public JLabel(String text
, int horizontalAlignment
)
480 this(text
, null, horizontalAlignment
);
484 * Creates a new vertically centered JLabel object with the given text,
485 * icon, and horizontal alignment.
487 * @param text The text to use with the label, <code>null</code> permitted.
488 * @param icon The icon to use with the label, <code>null</code> premitted.
489 * @param horizontalAlignment The horizontal alignment of the label, must be
490 * either <code>CENTER</code>, <code>LEFT</code>, <code>RIGHT</code>,
491 * <code>LEADING</code> or <code>TRAILING</code>.
493 public JLabel(String text
, Icon icon
, int horizontalAlignment
)
495 if (horizontalAlignment
!= SwingConstants
.LEFT
496 && horizontalAlignment
!= SwingConstants
.RIGHT
497 && horizontalAlignment
!= SwingConstants
.CENTER
498 && horizontalAlignment
!= SwingConstants
.LEADING
499 && horizontalAlignment
!= SwingConstants
.TRAILING
)
500 throw new IllegalArgumentException();
504 this.horizontalAlignment
= horizontalAlignment
;
506 setInheritsPopupMenu(true);
511 * Returns the label's UI delegate.
513 * @return The label's UI delegate.
515 public LabelUI
getUI()
521 * Sets the label's UI delegate.
523 * @param ui The label's UI delegate (<code>null</code> not permitted).
525 public void setUI(LabelUI ui
)
531 * Resets the label's UI delegate to the default UI for the current look and
534 public void updateUI()
536 setUI((LabelUI
) UIManager
.getUI(this));
540 * Returns a name to identify which look and feel class will be
541 * the UI delegate for this label.
543 * @return <code>"LabelUI"</code>
545 public String
getUIClassID()
551 * Returns a string describing the attributes for the <code>JLabel</code>
552 * component, for use in debugging. The return value is guaranteed to be
553 * non-<code>null</code>, but the format of the string may vary between
556 * @return A string describing the attributes of the <code>JLabel</code>.
558 protected String
paramString()
560 CPStringBuilder sb
= new CPStringBuilder(super.paramString());
561 sb
.append(",defaultIcon=");
564 sb
.append(",disabledIcon=");
565 if (disabledIcon
!= null)
566 sb
.append(disabledIcon
);
567 sb
.append(",horizontalAlignment=");
568 sb
.append(SwingUtilities
.convertHorizontalAlignmentCodeToString(
569 horizontalAlignment
));
570 sb
.append(",horizontalTextPosition=");
571 sb
.append(SwingUtilities
.convertHorizontalAlignmentCodeToString(
572 horizontalTextPosition
));
573 sb
.append(",iconTextGap=").append(iconTextGap
);
574 sb
.append(",labelFor=");
575 if (labelFor
!= null)
580 sb
.append(",verticalAlignment=");
581 sb
.append(SwingUtilities
.convertVerticalAlignmentCodeToString(
583 sb
.append(",verticalTextPosition=");
584 sb
.append(SwingUtilities
.convertVerticalAlignmentCodeToString(
585 verticalTextPosition
));
586 return sb
.toString();
590 * Returns the text displayed by the label.
592 * @return The label text (possibly <code>null</code>).
594 * @see #setText(String)
596 public String
getText()
602 * Sets the text for the label and sends a {@link PropertyChangeEvent} (with
603 * the name 'text') to all registered listeners. This method will also
604 * update the <code>displayedMnemonicIndex</code>, if necessary.
606 * @param newText The text (<code>null</code> permitted).
609 * @see #getDisplayedMnemonicIndex()
611 public void setText(String newText
)
613 if (text
== null && newText
== null)
615 if (text
!= null && text
.equals(newText
))
618 String oldText
= text
;
620 firePropertyChange("text", oldText
, newText
);
623 setDisplayedMnemonicIndex(text
.toUpperCase().indexOf(displayedMnemonic
));
625 setDisplayedMnemonicIndex(-1);
631 * Returns the active icon. The active icon is painted when the label is
634 * @return The active icon.
636 * @see #setIcon(Icon)
637 * @see #getDisabledIcon()
639 public Icon
getIcon()
645 * Sets the icon for the label (this is a bound property with the name
646 * 'icon'). This icon will be displayed when the label is enabled.
648 * @param newIcon The icon (<code>null</code> permitted).
651 * @see #setDisabledIcon(Icon)
653 public void setIcon(Icon newIcon
)
659 firePropertyChange("icon", oldIcon
, newIcon
);
665 * Returns the disabled icon. The disabled icon is painted when the label is
666 * disabled. If the disabled icon is <code>null</code> and the active icon
667 * is an {@link ImageIcon}, this method returns a grayed version of the icon.
668 * The grayed version of the icon becomes the <code>disabledIcon</code>.
670 * @return The disabled icon.
672 * @see #setDisabledIcon(Icon)
674 public Icon
getDisabledIcon()
676 if (disabledIcon
== null && icon
instanceof ImageIcon
)
677 disabledIcon
= new ImageIcon(
678 GrayFilter
.createDisabledImage(((ImageIcon
) icon
).getImage()));
684 * Sets the icon displayed when the label is disabled (this is a bound
685 * property with the name 'disabledIcon').
687 * @param newIcon The disabled icon (<code>null</code> permitted).
689 * @see #getDisabledIcon()
691 public void setDisabledIcon(Icon newIcon
)
693 if (disabledIcon
!= newIcon
)
695 Icon oldIcon
= disabledIcon
;
696 disabledIcon
= newIcon
;
697 firePropertyChange("disabledIcon", oldIcon
, newIcon
);
702 * Sets the keycode that will be the label's mnemonic (this is a bound
703 * property with the name 'displayedMnemonic'). If the label is used as a
704 * label for another component, the label will give focus to that component
705 * when the mnemonic is activated.
707 * @param mnemonic The keycode to use for the mnemonic.
709 * @see #getDisplayedMnemonic()
711 public void setDisplayedMnemonic(int mnemonic
)
713 if (displayedMnemonic
!= mnemonic
)
715 int old
= displayedMnemonic
;
716 displayedMnemonic
= mnemonic
;
717 firePropertyChange("displayedMnemonic", old
, displayedMnemonic
);
719 setDisplayedMnemonicIndex(text
.toUpperCase().indexOf(mnemonic
));
724 * Sets the character that will be the label's mnemonic. If the
725 * label is used as a label for another component, the label will give
726 * focus to that component when the mnemonic is activated via the keyboard.
728 * @param mnemonic The character to use for the mnemonic (this will be
729 * converted to the equivalent upper case character).
731 * @see #getDisplayedMnemonic()
733 public void setDisplayedMnemonic(char mnemonic
)
735 setDisplayedMnemonic((int) Character
.toUpperCase(mnemonic
));
739 * Returns the keycode that is used for the label's mnemonic.
741 * @return The keycode that is used for the label's mnemonic.
743 * @see #setDisplayedMnemonic(int)
745 public int getDisplayedMnemonic()
747 return displayedMnemonic
;
751 * Sets the index of the character in the text that will be underlined to
752 * indicate that it is the mnemonic character for the label. You only need
753 * to call this method if you wish to override the automatically calculated
754 * character index. For instance, for a label "Find Next" with the mnemonic
755 * character 'n', you might wish to underline the second occurrence of 'n'
756 * rather than the first (which is the default).
758 * Note that this method does not validate the character at the specified
759 * index to ensure that it matches the key code returned by
760 * {@link #getDisplayedMnemonic()}.
762 * @param newIndex The index of the character to underline.
764 * @throws IllegalArgumentException If index less than -1 or index is greater
765 * than or equal to the label length.
767 * @see #getDisplayedMnemonicIndex()
770 public void setDisplayedMnemonicIndex(int newIndex
)
771 throws IllegalArgumentException
775 maxValid
= text
.length() - 1;
776 if (newIndex
< -1 || newIndex
> maxValid
)
777 throw new IllegalArgumentException();
779 if (newIndex
!= displayedMnemonicIndex
)
781 int oldIndex
= displayedMnemonicIndex
;
782 displayedMnemonicIndex
= newIndex
;
783 firePropertyChange("displayedMnemonicIndex", oldIndex
, newIndex
);
788 * Returns the index of the character in the label's text that will be
789 * underlined (to indicate that it is the mnemonic character), or -1 if no
790 * character is to be underlined.
792 * @return The index of the character that will be underlined.
794 * @see #setDisplayedMnemonicIndex(int)
797 public int getDisplayedMnemonicIndex()
799 return displayedMnemonicIndex
;
803 * Checks the specified key to ensure that it is valid as a horizontal
804 * alignment, throwing an {@link IllegalArgumentException} if the key is
805 * invalid. Valid keys are {@link #LEFT}, {@link #CENTER}, {@link #RIGHT},
806 * {@link #LEADING} and {@link #TRAILING}.
808 * @param key The key to check.
809 * @param message The message of the exception to be thrown if the key is
812 * @return The key if it is valid.
814 * @throws IllegalArgumentException If the key is invalid.
816 protected int checkHorizontalKey(int key
, String message
)
818 if (key
!= LEFT
&& key
!= CENTER
&& key
!= RIGHT
&& key
!= LEADING
820 throw new IllegalArgumentException(message
);
826 * Checks the specified key to ensure that it is valid as a vertical
827 * alignment, throwing an {@link IllegalArgumentException} if the key is
828 * invalid. Valid keys are {@link #TOP}, {@link #CENTER} and {@link #BOTTOM}.
830 * @param key The key to check.
831 * @param message The message of the exception to be thrown if the key is
834 * @return The key if it is valid.
836 * @throws IllegalArgumentException If the key is invalid.
838 protected int checkVerticalKey(int key
, String message
)
840 if (key
!= TOP
&& key
!= BOTTOM
&& key
!= CENTER
)
841 throw new IllegalArgumentException(message
);
847 * Returns the gap between the icon and the text.
849 * @return The gap between the icon and the text.
851 * @see #setIconTextGap(int)
853 public int getIconTextGap()
859 * Sets the gap between the icon and the text, in the case that both are
860 * visible (this is a bound property with the name 'iconTextGap').
862 * @param newGap The gap (in pixels).
864 * @see #getIconTextGap()
866 public void setIconTextGap(int newGap
)
868 if (iconTextGap
!= newGap
)
870 firePropertyChange("iconTextGap", iconTextGap
, newGap
);
871 iconTextGap
= newGap
;
876 * Returns the vertical alignment of the label (one of
877 * {@link #TOP}, {@link #CENTER} and {@link #BOTTOM}). The default value
878 * depends on the installed look and feel, but is usually {@link #CENTER}.
880 * @return The vertical alignment.
882 * @see #setVerticalAlignment(int)
884 public int getVerticalAlignment()
886 return verticalAlignment
;
890 * Sets the vertical alignment for the label (this is a bound property with
891 * the name 'verticalAlignment'). The vertical alignment determines where
892 * the label (icon and text) will be placed vertically within the component
893 * bounds. Valid alignment codes are {@link #TOP}, {@link #CENTER} and
896 * @param alignment The vertical alignment of the label.
898 * @throws IllegalArgumentException if <code>alignment</code> is not one of
899 * the specified values.
901 * @see #getVerticalAlignment()
903 public void setVerticalAlignment(int alignment
)
905 if (alignment
== verticalAlignment
)
908 int oldAlignment
= verticalAlignment
;
909 verticalAlignment
= checkVerticalKey(alignment
, "verticalAlignment");
910 firePropertyChange("verticalAlignment", oldAlignment
, verticalAlignment
);
914 * Returns the horizontal alignment of the label (one of {@link #LEFT},
915 * {@link #CENTER}, {@link #RIGHT}, {@link #LEADING} and {@link #TRAILING}).
916 * The default value depends on the installed look and feel, but is usually
919 * @return The horizontal alignment.
921 * @see #setHorizontalAlignment(int)
923 public int getHorizontalAlignment()
925 return horizontalAlignment
;
929 * Sets the horizontal alignment for the label (this is a bound property with
930 * the name 'horizontalAlignment'). The horizontal alignment determines where
931 * the label (icon and text) will be placed horizontally within the
932 * component bounds. Valid alignment codes are {@link #LEFT},
933 * {@link #CENTER}, {@link #RIGHT}, {@link #LEADING} and {@link #TRAILING}.
935 * @param alignment The horizontal alignment of the label.
937 * @throws IllegalArgumentException if <code>alignment</code> is not one of
938 * the specified values.
940 * @see #getHorizontalAlignment()
942 public void setHorizontalAlignment(int alignment
)
944 if (horizontalAlignment
== alignment
)
947 int oldAlignment
= horizontalAlignment
;
948 horizontalAlignment
= checkHorizontalKey(alignment
, "horizontalAlignment");
949 firePropertyChange("horizontalAlignment", oldAlignment
,
950 horizontalAlignment
);
954 * Returns the vertical position of the label's text relative to the icon.
955 * This will be one of {@link #TOP}, {@link #CENTER} and {@link #BOTTOM}.
957 * @return The vertical position of the label's text relative to the icon.
959 * @see #setVerticalTextPosition(int)
961 public int getVerticalTextPosition()
963 return verticalTextPosition
;
967 * Sets the vertical position of the label's text relative to the icon (this
968 * is a bound property with the name 'verticalTextPosition'). Valid
969 * positions are {@link #TOP}, {@link #CENTER} and {@link #BOTTOM}.
971 * @param textPosition The vertical text position.
973 * @throws IllegalArgumentException if <code>textPosition</code> is not one
974 * of the specified values.
976 public void setVerticalTextPosition(int textPosition
)
978 if (textPosition
!= verticalTextPosition
)
980 int oldPos
= verticalTextPosition
;
981 verticalTextPosition
= checkVerticalKey(textPosition
,
982 "verticalTextPosition");
983 firePropertyChange("verticalTextPosition", oldPos
,
984 verticalTextPosition
);
989 * Returns the horizontal position of the label's text relative to the icon.
990 * This will be one of {@link #LEFT}, {@link #CENTER}, {@link #RIGHT},
991 * {@link #LEADING} and {@link #TRAILING}.
993 * @return The horizontal position of the label's text relative to the icon.
995 * @see #setHorizontalTextPosition(int)
997 public int getHorizontalTextPosition()
999 return horizontalTextPosition
;
1003 * Sets the horizontal position of the label's text relative to the icon (this
1004 * is a bound property with the name 'horizontalTextPosition'). Valid
1005 * positions are {@link #LEFT}, {@link #CENTER}, {@link #RIGHT},
1006 * {@link #LEADING} and {@link #TRAILING}.
1008 * @param textPosition The horizontal text position.
1010 * @throws IllegalArgumentException if <code>textPosition</code> is not one
1011 * of the specified values.
1013 public void setHorizontalTextPosition(int textPosition
)
1015 if (textPosition
!= horizontalTextPosition
)
1017 int oldPos
= horizontalTextPosition
;
1018 horizontalTextPosition
= checkHorizontalKey(textPosition
,
1019 "horizontalTextPosition");
1020 firePropertyChange("horizontalTextPosition", oldPos
,
1021 horizontalTextPosition
);
1026 * Returns false if the current icon image (current icon will depend on
1027 * whether the label is enabled) is not equal to the passed in image.
1029 * @param img The image to check.
1030 * @param infoflags The bitwise inclusive OR of ABORT, ALLBITS, ERROR,
1031 * FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, and WIDTH
1032 * @param x The x position
1033 * @param y The y position
1034 * @param w The width
1035 * @param h The height
1037 * @return Whether the current icon image is equal to the image given.
1039 public boolean imageUpdate(Image img
, int infoflags
, int x
, int y
, int w
,
1042 Icon currIcon
= isEnabled() ? icon
: disabledIcon
;
1044 // XXX: Is this the correct way to check for image equality?
1045 if (currIcon
!= null && currIcon
instanceof ImageIcon
)
1046 return (((ImageIcon
) currIcon
).getImage() == img
);
1052 * Returns the component that this <code>JLabel</code> is providing the label
1053 * for. This component will typically receive the focus when the label's
1054 * mnemonic key is activated via the keyboard.
1056 * @return The component (possibly <code>null</code>).
1058 public Component
getLabelFor()
1064 * Sets the component that this <code>JLabel</code> is providing the label
1065 * for (this is a bound property with the name 'labelFor'). This component
1066 * will typically receive the focus when the label's mnemonic key is
1067 * activated via the keyboard.
1069 * @param c the component (<code>null</code> permitted).
1071 * @see #getLabelFor()
1073 public void setLabelFor(Component c
)
1077 Component oldLabelFor
= labelFor
;
1079 firePropertyChange("labelFor", oldLabelFor
, labelFor
);
1081 // We put the label into the client properties for the labeled
1082 // component so that it can be read by the AccessibleJComponent.
1083 // The other option would be to reserve a default visible field
1084 // in JComponent, but since this is relatively seldomly used, it
1085 // would be unnecessary waste of memory to do so.
1086 if (oldLabelFor
instanceof JComponent
)
1088 ((JComponent
) oldLabelFor
).putClientProperty(LABEL_PROPERTY
, null);
1091 if (labelFor
instanceof JComponent
)
1093 ((JComponent
) labelFor
).putClientProperty(LABEL_PROPERTY
, this);
1100 * Sets the font for the label (this a bound property with the name 'font').
1102 * @param f The font (<code>null</code> permitted).
1104 public void setFont(Font f
)
1111 * Returns the object that provides accessibility features for this
1112 * <code>JLabel</code> component.
1114 * @return The accessible context (an instance of {@link AccessibleJLabel}).
1116 public AccessibleContext
getAccessibleContext()
1118 if (accessibleContext
== null)
1119 accessibleContext
= new AccessibleJLabel();
1120 return accessibleContext
;