All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jdesktop.swingx.renderer.DefaultVisuals Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2006 Sun Microsystems, Inc., 4150 Network Circle,
 * Santa Clara, California 95054, U.S.A. All rights reserved.
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 * 
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */
package org.jdesktop.swingx.renderer;

import java.awt.Color;
import java.io.Serializable;

import javax.swing.JComponent;

/**
 * Encapsulates the default visual configuration of renderering components,
 * respecting the state of the passed-in CellContext. 
 * It's basically re-usable across all types of renderees (JTable, JList, JTree).
 * 

* * Guarantees to completely configure * the default visual properties (listed below) of a given component. * As a consequence, client code (f.i. in Highlighters) can safely change them * without long-lasting visual artefacts. * *

    *
  • foreground and background, depending on selected and focused state *
  • border *
  • font *
  • Painter (if applicable) *
  • enabled *
  • componentOrientation *
  • toolTipText *
  • minimum-, maximum-, preferredSize *
  • name *
* * Client code will rarely need to be aware of this class. It's the single * place to change on introduction of new properties considered as belonging * to the "default visuals" of rendering components.

* * PENDING: allow mutators for overruling the CellContexts defaults? * Would prefer not to, as in the context of SwingX visual config on the renderer level is discouraged * (the way to go are Highlighters.

* * PENDING: not yet quite decided whether the toolTipText property belongs into the visual default config. * Doing so gives client code the choice to set it either in a Highlighter or a custom ComponentProvider. * * @author Jeanette Winzenburg * * @param a generic renderingComponent (subclass of JComponent), * for example JRendererLabel or WrappingIconPanel * * @see JRendererLabel * @see WrappingIconPanel * @see CellContext */ public class DefaultVisuals implements Serializable { private static final long serialVersionUID = -2590817387758753406L; private Color unselectedForeground; private Color unselectedBackground; DefaultVisuals() { // System.out.println("DefaultVisuals.ctor <<<<<<<<<<<<"); } /** * Sets the renderer's unselected-foreground color to the specified color. * If not null this color will overrule the default color of * the CellContext. * * @param c set the foreground color to this value */ public void setForeground(Color c) { unselectedForeground = c; } /** * Sets the renderer's unselected-background color to the specified color. * If not null this color will overrule the default color of * the CellContext. * * @param c set the background color to this value */ public void setBackground(Color c) { unselectedBackground = c; } //---------------- subclass configuration /** * Configures all default visual state of the rendering component from the * given cell context. * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null * @throws NullPointerException if either renderingComponent or cellContext * is null */ public void configureVisuals(T renderingComponent, CellContext context) { configureState(renderingComponent, context); configureColors(renderingComponent, context); configureBorder(renderingComponent, context); configurePainter(renderingComponent, context); } /** * Configures the default Painter if applicable. Here: set's to null. * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null */ protected void configurePainter(T renderingComponent, CellContext context) { if (renderingComponent instanceof PainterAware pa) { // TODO PainterAware is deprecated ??? oder doch nicht // System.out.println("DefaultVisuals.configurePainter renderingComponent "+renderingComponent.getClass()+" is of deprecated type PainterAware!"); pa.setPainter(null); } } /** * Configure "divers" visual state of the rendering component from the given * cell context. *

* * Here: synch Font, ComponentOrientation and enabled * to context's component. * Resets toolTipText to null. * Calls configureSizes to reset xxSize if appropriate. * Resets the component's name property. *

* * PENDING: not fully defined - "divers" means everything that's not * Colors * nor Border * nor Painter. * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null */ protected void configureState(T renderingComponent, CellContext context) { renderingComponent.setName(context.getCellRendererName()); renderingComponent.setToolTipText(null); configureSizes(renderingComponent, context); // PENDING JW: as of Issue #1269 this was changed to query the // CellContext for the font - should move out off the else? // context takes care of null component renderingComponent.setFont(context.getFont()); if (context.getComponent() == null) { // what to do? // we guarantee to cleanup completely - what are the defaults? // leave the decistion to the context? } else { renderingComponent.setEnabled(context.getComponent().isEnabled()); renderingComponent.applyComponentOrientation(context.getComponent().getComponentOrientation()); } } /** * Configures min-, max, preferredSize properties of the renderingComponent. * * Here: set all to null. * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null */ protected void configureSizes(T renderingComponent, CellContext context) { renderingComponent.setPreferredSize(null); renderingComponent.setMinimumSize(null); renderingComponent.setMaximumSize(null); } /** * Configures colors of rendering component from the given cell context. * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null */ protected void configureColors(T renderingComponent, CellContext context) { if (context.isSelected()) { renderingComponent.setForeground(context.getSelectionForeground()); renderingComponent.setBackground(context.getSelectionBackground()); } else { renderingComponent.setForeground(getForeground(context)); renderingComponent.setBackground(getBackground(context)); } if (context.isFocused()) { configureFocusColors(renderingComponent, context); } } /** * Configures focus-related colors form given cell context.

* * PENDING: move to context as well? - it's the only comp * with focus specifics? Problem is the parameter type... * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null */ protected void configureFocusColors(T renderingComponent, CellContext context) { if (!context.isSelected() && context.isEditable()) { Color col = context.getFocusForeground(); if (col != null) { renderingComponent.setForeground(col); } col = context.getFocusBackground(); if (col != null) { renderingComponent.setBackground(col); } } } /** * Configures the rendering component's border from the given cell context. * * @param renderingComponent the component to configure, must not be null * @param context the cell context to configure from, must not be null */ protected void configureBorder(T renderingComponent, CellContext context) { renderingComponent.setBorder(context.getBorder()); } /** * Returns the unselected foreground to use for the rendering * component.

* * Here: returns this renderer's unselected foreground is not null, * returns the foreground from the given context. In other words: * the renderer's foreground takes precedence if set. * * @param context the cell context. * @return the unselected foreground. */ protected Color getForeground(CellContext context) { if (unselectedForeground != null) return unselectedForeground; return context.getForeground(); } /** * Returns the unselected background to use for the rendering * component.

* * Here: returns this renderer's unselected background is not null, * returns the background from the given context. In other words: * the renderer's background takes precedence if set. * * @param context the cell context. * @return the unselected background. */ protected Color getBackground(CellContext context) { if (unselectedBackground != null) return unselectedBackground; return context.getBackground(); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy