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

de.javagl.common.ui.tree.renderer.GenericTreeCellRenderer Maven / Gradle / Ivy

/*
 * www.javagl.de - Common - UI
 *
 * Copyright (c) 2013-2018 Marco Hutter - http://www.javagl.de
 * 
 * Permission is hereby granted, free of charge, to any person
 * obtaining a copy of this software and associated documentation
 * files (the "Software"), to deal in the Software without
 * restriction, including without limitation the rights to use,
 * copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following
 * conditions:
 * 
 * The above copyright notice and this permission notice shall be
 * included in all copies or substantial portions of the Software.
 * 
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
 * OTHER DEALINGS IN THE SOFTWARE.
 */
package de.javagl.common.ui.tree.renderer;

import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Component;
import java.awt.Graphics;
import java.awt.GridLayout;

import javax.swing.BorderFactory;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTree;
import javax.swing.tree.DefaultTreeCellRenderer;
import javax.swing.tree.TreeCellRenderer;

/**
 * Base implementation of a {@link TreeCellRenderer} that allows
 * adding arbitrary components to the tree cells. 
 */
public abstract class GenericTreeCellRenderer implements TreeCellRenderer
{
    /**
     * The delegate {@link TreeCellRenderer}
     */
    private final DefaultTreeCellRenderer delegate = 
        new DefaultTreeCellRenderer();

    @Override
    public Component getTreeCellRendererComponent(
        JTree tree, Object value, boolean selected, boolean expanded, 
        boolean leaf, int row, boolean hasFocus) 
    {
        delegate.getTreeCellRendererComponent(
            tree, value, selected, expanded, leaf, row, hasFocus);
        JPanel component = new JPanel(new BorderLayout(5, 0));
        component.setOpaque(false);

        JLabel iconLabel = new JLabel();
        iconLabel.setIcon(delegate.getIcon());
        component.add(iconLabel, BorderLayout.WEST);

        JPanel container = new JPanel(new GridLayout(1,1))
        {
            /**
             * Serial UID
             */
            private static final long serialVersionUID = -7852184126192862958L;

            @Override
            protected void paintComponent(Graphics g) 
            {
                super.paintComponent(g);
                g.setColor(getBackgroundColor());
                g.fillRect(0, 0, getWidth(), getHeight());
            }
        
            /**
             * Returns the background color based on selection and focus
             * 
             * @return The background color
             */
            private Color getBackgroundColor()
            {
                if (selected || hasFocus)
                {
                    return delegate.getBackgroundSelectionColor();
                }
                Color color = delegate.getBackgroundNonSelectionColor();
                if (color == null)
                {
                    return delegate.getBackground();
                }
                return color;
            }
        };
        component.add(container, BorderLayout.CENTER);
        
        prepare(value, container);

        if (selected || hasFocus)
        {
            container.setBorder(BorderFactory.createLineBorder(
                delegate.getBorderSelectionColor()));
            container.setBackground(
                delegate.getBackgroundSelectionColor());
        }
        else
        {
            container.setBorder(
                BorderFactory.createEmptyBorder(1, 1, 1, 1));
            container.setBackground(null);
        }

        return component;
    }

    /**
     * This method will be called in order to prepare the returned cell 
     * renderer component for displaying the given object. The given
     * container will initially be empty. Arbitrary components may be
     * added to this container, in order to display the given 
     * tree node object or its contents in the tree cell. 
     * 
     * @param nodeObject The tree node object
     * @param container The target container
     */
    protected void prepare(Object nodeObject, JPanel container)
    {
        // Empty default implementation
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy