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

xdev.ui.table.CellStyleTableRenderer Maven / Gradle / Ivy

There is a newer version: 6.0.2
Show newest version
package xdev.ui.table;

/*-
 * #%L
 * XDEV Component Suite
 * %%
 * Copyright (C) 2011 - 2021 XDEV Software
 * %%
 * This program 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 3 of the
 * License, or (at your option) any later version.
 * 
 * This program 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 General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public
 * License along with this program.  If not, see
 * .
 * #L%
 */


import java.awt.Component;

import javax.swing.JTable;
import javax.swing.table.TableCellRenderer;


/**
 * This implementation of {@link TableCellRenderer} is meant to provide visual
 * cell styling of individual table cells based on the value and/or properties
 * of a field from a Virtual Table instance.
 * 

* This class decorates other TableCellRenderers and modifies the cell component * after those other renderer's, building a renderer chain. *

* * @author XDEV Software * */ public class CellStyleTableRenderer implements TableCellRenderer { /** * The previous renderer responsible for doing the initial rendering. */ private TableCellRenderer previousRenderer; /** * Creates a new instance. * * @param previousRenderer * the previous TableCellRenderer. */ public CellStyleTableRenderer(TableCellRenderer previousRenderer) { this.previousRenderer = previousRenderer; } @Override public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) { Component component = previousRenderer.getTableCellRendererComponent(table,value, isSelected,hasFocus,row,column); /* * TODO: Currently this renderer doesn't modify the appearance of the * cell. Implementation of vt cell specific modifications should be done * here... */ // VirtualTableModel vtm = // (VirtualTableModel)TableModelWrapperUtils.getActualTableModel(table.getModel(), // VirtualTableModel.class); return component; } /** * @return the previous {@link TableCellRenderer}. */ public TableCellRenderer getPreviousRenderer() { return previousRenderer; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy