java.lang.Object
javax.swing.plaf.ComponentUI
javax.swing.plaf.LabelUI
javax.swing.plaf.basic.BasicLabelUI
- All Implemented Interfaces:
PropertyChangeListener
,EventListener
- Direct Known Subclasses:
MetalLabelUI
,SynthLabelUI
public class BasicLabelUI extends LabelUI implements PropertyChangeListener
A Windows L&F implementation of LabelUI. This implementation
is completely static, i.e. there's only one UIView implementation
that's shared by all JLabel objects.
-
Field Summary
Fields Modifier and Type Field Description protected static BasicLabelUI
labelUI
The defaultBasicLabelUI
instance. -
Constructor Summary
Constructors Constructor Description BasicLabelUI()
-
Method Summary
Modifier and Type Method Description static ComponentUI
createUI(JComponent c)
Returns an instance ofBasicLabelUI
.int
getBaseline(JComponent c, int width, int height)
Returns the baseline.Component.BaselineResizeBehavior
getBaselineResizeBehavior(JComponent c)
Returns an enum indicating how the baseline of the component changes as the size changes.Dimension
getMaximumSize(JComponent c)
Returns the specified component's maximum size appropriate for the look and feel.Dimension
getMinimumSize(JComponent c)
Returns the specified component's minimum size appropriate for the look and feel.protected void
installComponents(JLabel c)
Registers components.protected void
installDefaults(JLabel c)
Installs default properties.protected void
installKeyboardActions(JLabel l)
Registers keyboard actions.protected void
installListeners(JLabel c)
Registers listeners.protected String
layoutCL(JLabel label, FontMetrics fontMetrics, String text, Icon icon, Rectangle viewR, Rectangle iconR, Rectangle textR)
Forwards the call to SwingUtilities.layoutCompoundLabel().void
paint(Graphics g, JComponent c)
Paints the label text with the foreground color, if the label is opaque then paints the entire background with the background color.protected void
paintDisabledText(JLabel l, Graphics g, String s, int textX, int textY)
Paint clippedText at textX, textY with background.lighter() and then shifted down and to the right by one pixel with background.darker().protected void
paintEnabledText(JLabel l, Graphics g, String s, int textX, int textY)
Paint clippedText at textX, textY with the labels foreground color.protected void
uninstallComponents(JLabel c)
Unregisters components.protected void
uninstallDefaults(JLabel c)
Uninstalls default properties.protected void
uninstallKeyboardActions(JLabel c)
Unregisters keyboard actions.protected void
uninstallListeners(JLabel c)
Unregisters listeners.Methods declared in class javax.swing.plaf.ComponentUI
contains, getAccessibleChild, getAccessibleChildrenCount, getPreferredSize, installUI, uninstallUI, update
Methods declared in class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods declared in interface java.beans.PropertyChangeListener
propertyChange
-
Field Details
-
labelUI
The defaultBasicLabelUI
instance. This field might not be used. To change the default instance use a subclass which overrides thecreateUI
method, and place that class name in defaults table under the key "LabelUI".
-
-
Constructor Details
-
BasicLabelUI
public BasicLabelUI()
-
-
Method Details
-
layoutCL
protected String layoutCL(JLabel label, FontMetrics fontMetrics, String text, Icon icon, Rectangle viewR, Rectangle iconR, Rectangle textR)Forwards the call to SwingUtilities.layoutCompoundLabel(). This method is here so that a subclass could do Label specific layout and to shorten the method name a little.- Parameters:
label
- an instance ofJLabel
fontMetrics
- a font metricstext
- a texticon
- an iconviewR
- a bounding rectangle to lay out labeliconR
- a bounding rectangle to lay out icontextR
- a bounding rectangle to lay out text- Returns:
- a possibly clipped version of the compound labels string
- See Also:
SwingUtilities.layoutCompoundLabel(javax.swing.JComponent, java.awt.FontMetrics, java.lang.String, javax.swing.Icon, int, int, int, int, java.awt.Rectangle, java.awt.Rectangle, java.awt.Rectangle, int)
-
paintEnabledText
Paint clippedText at textX, textY with the labels foreground color.- Parameters:
l
- an instance ofJLabel
g
- an instance ofGraphics
s
- a texttextX
- an X coordinatetextY
- an Y coordinate- See Also:
paint(java.awt.Graphics, javax.swing.JComponent)
,paintDisabledText(javax.swing.JLabel, java.awt.Graphics, java.lang.String, int, int)
-
paintDisabledText
Paint clippedText at textX, textY with background.lighter() and then shifted down and to the right by one pixel with background.darker().- Parameters:
l
- an instance ofJLabel
g
- an instance ofGraphics
s
- a texttextX
- an X coordinatetextY
- an Y coordinate- See Also:
paint(java.awt.Graphics, javax.swing.JComponent)
,paintEnabledText(javax.swing.JLabel, java.awt.Graphics, java.lang.String, int, int)
-
paint
Paints the label text with the foreground color, if the label is opaque then paints the entire background with the background color. The Label text is drawn bypaintEnabledText(javax.swing.JLabel, java.awt.Graphics, java.lang.String, int, int)
orpaintDisabledText(javax.swing.JLabel, java.awt.Graphics, java.lang.String, int, int)
. The locations of the label parts are computed bylayoutCL(javax.swing.JLabel, java.awt.FontMetrics, java.lang.String, javax.swing.Icon, java.awt.Rectangle, java.awt.Rectangle, java.awt.Rectangle)
.- Overrides:
paint
in classComponentUI
- Parameters:
g
- theGraphics
context in which to paintc
- the component being painted; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components- See Also:
paintEnabledText(javax.swing.JLabel, java.awt.Graphics, java.lang.String, int, int)
,paintDisabledText(javax.swing.JLabel, java.awt.Graphics, java.lang.String, int, int)
,layoutCL(javax.swing.JLabel, java.awt.FontMetrics, java.lang.String, javax.swing.Icon, java.awt.Rectangle, java.awt.Rectangle, java.awt.Rectangle)
-
getMinimumSize
Description copied from class:ComponentUI
Returns the specified component's minimum size appropriate for the look and feel. Ifnull
is returned, the minimum size will be calculated by the component's layout manager instead (this is the preferred approach for any component with a specific layout manager installed). The default implementation of this method invokesgetPreferredSize
and returns that value.- Overrides:
getMinimumSize
in classComponentUI
- Parameters:
c
- the component whose minimum size is being queried; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components- Returns:
- getPreferredSize(c)
- See Also:
JComponent.getMinimumSize()
,LayoutManager.minimumLayoutSize(java.awt.Container)
,ComponentUI.getPreferredSize(javax.swing.JComponent)
-
getMaximumSize
Description copied from class:ComponentUI
Returns the specified component's maximum size appropriate for the look and feel. Ifnull
is returned, the maximum size will be calculated by the component's layout manager instead (this is the preferred approach for any component with a specific layout manager installed). The default implementation of this method invokesgetPreferredSize
and returns that value.- Overrides:
getMaximumSize
in classComponentUI
- Parameters:
c
- the component whose maximum size is being queried; this argument is often ignored, but might be used if the UI object is stateless and shared by multiple components- Returns:
- getPreferredSize(c)
- See Also:
JComponent.getMaximumSize()
,LayoutManager2.maximumLayoutSize(java.awt.Container)
-
getBaseline
Returns the baseline.- Overrides:
getBaseline
in classComponentUI
- Parameters:
c
-JComponent
baseline is being requested forwidth
- the width to get the baseline forheight
- the height to get the baseline for- Returns:
- baseline or a value < 0 indicating there is no reasonable baseline
- Throws:
NullPointerException
- ifc
isnull
IllegalArgumentException
- if width or height is < 0- Since:
- 1.6
- See Also:
JComponent.getBaseline(int, int)
-
getBaselineResizeBehavior
Returns an enum indicating how the baseline of the component changes as the size changes.- Overrides:
getBaselineResizeBehavior
in classComponentUI
- Parameters:
c
-JComponent
to return baseline resize behavior for- Returns:
- an enum indicating how the baseline changes as the component size changes
- Throws:
NullPointerException
- ifc
isnull
- Since:
- 1.6
- See Also:
JComponent.getBaseline(int, int)
-
installDefaults
Installs default properties.- Parameters:
c
- an instance ofJLabel
-
installListeners
Registers listeners.- Parameters:
c
- an instance ofJLabel
-
installComponents
Registers components.- Parameters:
c
- an instance ofJLabel
-
installKeyboardActions
Registers keyboard actions.- Parameters:
l
- an instance ofJLabel
-
uninstallDefaults
Uninstalls default properties.- Parameters:
c
- an instance ofJLabel
-
uninstallListeners
Unregisters listeners.- Parameters:
c
- an instance ofJLabel
-
uninstallComponents
Unregisters components.- Parameters:
c
- an instance ofJLabel
-
uninstallKeyboardActions
Unregisters keyboard actions.- Parameters:
c
- an instance ofJLabel
-
createUI
Returns an instance ofBasicLabelUI
.- Parameters:
c
- a component- Returns:
- an instance of
BasicLabelUI
-