| 
 | JavaTM 2 Platform Standard Ed. 5.0 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectjava.awt.Component
java.awt.Container
javax.swing.JComponent
javax.swing.JLabel
javax.swing.table.DefaultTableCellRenderer
public class DefaultTableCellRenderer
The standard class for rendering (displaying) individual cells
 in a JTable.
 
 Implementation Note:
 This class inherits from JLabel, a standard component class. 
 However JTable employs a unique mechanism for rendering
 its cells and therefore requires some slightly modified behavior
 from its cell renderer.  
 The table class defines a single cell renderer and uses it as a 
 as a rubber-stamp for rendering all cells in the table; 
 it renders the first cell,
 changes the contents of that cell renderer, 
 shifts the origin to the new location, re-draws it, and so on.
 The standard JLabel component was not
 designed to be used this way and we want to avoid 
 triggering a revalidate each time the
 cell is drawn. This would greatly decrease performance because the
 revalidate message would be
 passed up the hierarchy of the container to determine whether any other
 components would be affected.  
 As the renderer is only parented for the lifetime of a painting operation
 we similarly want to avoid the overhead associated with walking the
 hierarchy for painting operations.
 So this class
 overrides the validate, invalidate,
 revalidate, repaint, and
 firePropertyChange methods to be 
 no-ops and override the isOpaque method solely to improve
 performance.  If you write your own renderer,
 please keep this performance consideration in mind.
 
 Warning:
 Serialized objects of this class will not be compatible with
 future Swing releases. The current serialization support is
 appropriate for short term storage or RMI between applications running
 the same version of Swing.  As of 1.4, support for long term storage
 of all JavaBeansTM
 has been added to the java.beans package.
 Please see XMLEncoder.
JTable| Nested Class Summary | |
|---|---|
| static class | DefaultTableCellRenderer.UIResourceA subclass of DefaultTableCellRendererthat
 implementsUIResource. | 
| Nested classes/interfaces inherited from class javax.swing.JLabel | 
|---|
| JLabel.AccessibleJLabel | 
| Nested classes/interfaces inherited from class javax.swing.JComponent | 
|---|
| JComponent.AccessibleJComponent | 
| Nested classes/interfaces inherited from class java.awt.Container | 
|---|
| Container.AccessibleAWTContainer | 
| Nested classes/interfaces inherited from class java.awt.Component | 
|---|
| Component.AccessibleAWTComponent, Component.BltBufferStrategy, Component.FlipBufferStrategy | 
| Field Summary | |
|---|---|
| protected static Border | noFocusBorder | 
| Fields inherited from class javax.swing.JLabel | 
|---|
| labelFor | 
| Fields inherited from class javax.swing.JComponent | 
|---|
| accessibleContext, listenerList, TOOL_TIP_TEXT_KEY, ui, UNDEFINED_CONDITION, WHEN_ANCESTOR_OF_FOCUSED_COMPONENT, WHEN_FOCUSED, WHEN_IN_FOCUSED_WINDOW | 
| Fields inherited from class java.awt.Component | 
|---|
| BOTTOM_ALIGNMENT, CENTER_ALIGNMENT, LEFT_ALIGNMENT, RIGHT_ALIGNMENT, TOP_ALIGNMENT | 
| Fields inherited from interface javax.swing.SwingConstants | 
|---|
| BOTTOM, CENTER, EAST, HORIZONTAL, LEADING, LEFT, NEXT, NORTH, NORTH_EAST, NORTH_WEST, PREVIOUS, RIGHT, SOUTH, SOUTH_EAST, SOUTH_WEST, TOP, TRAILING, VERTICAL, WEST | 
| Fields inherited from interface java.awt.image.ImageObserver | 
|---|
| ABORT, ALLBITS, ERROR, FRAMEBITS, HEIGHT, PROPERTIES, SOMEBITS, WIDTH | 
| Constructor Summary | |
|---|---|
| DefaultTableCellRenderer()Creates a default table cell renderer. | |
| Method Summary | |
|---|---|
|  void | firePropertyChange(String propertyName,
                   boolean oldValue,
                   boolean newValue)Overridden for performance reasons. | 
| protected  void | firePropertyChange(String propertyName,
                   Object oldValue,
                   Object newValue)Overridden for performance reasons. | 
|  Component | getTableCellRendererComponent(JTable table,
                              Object value,
                              boolean isSelected,
                              boolean hasFocus,
                              int row,
                              int column)Returns the default table cell renderer. | 
|  void | invalidate()Overridden for performance reasons. | 
|  boolean | isOpaque()Overridden for performance reasons. | 
|  void | repaint()Overridden for performance reasons. | 
|  void | repaint(long tm,
        int x,
        int y,
        int width,
        int height)Overridden for performance reasons. | 
|  void | repaint(Rectangle r)Overridden for performance reasons. | 
|  void | revalidate()Overridden for performance reasons. | 
|  void | setBackground(Color c)Overrides JComponent.setBackgroundto assign
 the unselected-background color to the specified color. | 
|  void | setForeground(Color c)Overrides JComponent.setForegroundto assign
 the unselected-foreground color to the specified color. | 
| protected  void | setValue(Object value)Sets the Stringobject for the cell being rendered tovalue. | 
|  void | updateUI()Notification from the UIManagerthat the look and feel
 [L&F] has changed. | 
|  void | validate()Overridden for performance reasons. | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Field Detail | 
|---|
protected static Border noFocusBorder
| Constructor Detail | 
|---|
public DefaultTableCellRenderer()
| Method Detail | 
|---|
public void setForeground(Color c)
JComponent.setForeground to assign
 the unselected-foreground color to the specified color.
setForeground in class JComponentc - set the foreground color to this valueComponent.getForeground()public void setBackground(Color c)
JComponent.setBackground to assign
 the unselected-background color to the specified color.
setBackground in class JComponentc - set the background color to this valueComponent.getBackground()public void updateUI()
UIManager that the look and feel
 [L&F] has changed.
 Replaces the current UI object with the latest version from the 
 UIManager.
updateUI in class JLabelJComponent.updateUI()
public Component getTableCellRendererComponent(JTable table,
                                               Object value,
                                               boolean isSelected,
                                               boolean hasFocus,
                                               int row,
                                               int column)
getTableCellRendererComponent in interface TableCellRenderertable - the JTablevalue - the value to assign to the cell at
                        [row, column]isSelected - true if cell is selectedhasFocus - true if cell has focusrow - the row of the cell to rendercolumn - the column of the cell to render
public boolean isOpaque()
isOpaque in class JComponentJComponent.setOpaque(boolean)public void invalidate()
invalidate in class ContainerContainer.validate(), 
Container.layout(), 
LayoutManagerpublic void validate()
validate in class ContainerContainer.add(java.awt.Component), 
Component.invalidate(), 
JComponent.revalidate()public void revalidate()
revalidate in class JComponentComponent.invalidate(), 
Container.validate(), 
JComponent.isValidateRoot(), 
RepaintManager.addInvalidComponent(javax.swing.JComponent)
public void repaint(long tm,
                    int x,
                    int y,
                    int width,
                    int height)
repaint in class JComponenttm - this parameter is not usedx - the x value of the dirty regiony - the y value of the dirty regionwidth - the width of the dirty regionheight - the height of the dirty regionComponent.isShowing(), 
RepaintManager.addDirtyRegion(javax.swing.JComponent, int, int, int, int)public void repaint(Rectangle r)
repaint in class JComponentr - a Rectangle containing the dirty regionComponent.isShowing(), 
RepaintManager.addDirtyRegion(javax.swing.JComponent, int, int, int, int)public void repaint()
repaint in class ComponentComponent.update(Graphics)
protected void firePropertyChange(String propertyName,
                                  Object oldValue,
                                  Object newValue)
firePropertyChange in class ComponentpropertyName - the property whose value has changedoldValue - the property's previous valuenewValue - the property's new value
public void firePropertyChange(String propertyName,
                               boolean oldValue,
                               boolean newValue)
firePropertyChange in class JComponentpropertyName - the property whose value has changedoldValue - the property's previous valuenewValue - the property's new valueprotected void setValue(Object value)
String object for the cell being rendered to
 value.
value - the string value for this cell; if value is
                null it sets the text value to an empty stringJLabel.setText(java.lang.String)| 
 | JavaTM 2 Platform Standard Ed. 5.0 | |||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
Copyright 2004 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.