Mercurial > hg > ltpda
view src/MPipeline2/src/mpipeline/plisttable/JPlistDoubleRenderer.java @ 0:f0afece42f48
Import.
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Wed, 23 Nov 2011 19:22:13 +0100 |
parents | |
children |
line wrap: on
line source
/* * Class JPlistDoubleRenderer <one line to give the program's name and a brief idea of what it does.> * * Copyright (c) 2009 Max-Planck-Gesellschaft, Martin Hewitson <martin.hewitson at aei.mpg.de> * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU 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 Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. * */ package mpipeline.plisttable; import java.awt.Color; import java.awt.Component; import javax.swing.BorderFactory; import javax.swing.JTable; import javax.swing.JTextField; import javax.swing.UIManager; import javax.swing.table.DefaultTableCellRenderer; /** * * @author Martin Hewitson <martin.hewitson at aei.mpg.de> */ public class JPlistDoubleRenderer extends DefaultTableCellRenderer { public JTextField textarea = new JTextField(); private final static int MAX_LINES = 3; /** * Returns the component used for drawing the cell. This method is * used to configure the renderer appropriately before drawing. * * @param table the <code>JTable</code> that is asking the * renderer to draw. * @param value the value of the cell to be rendered. * @param isSelected true if the cell is to be rendered with the * selection highlighted; otherwise false * @param hasFocus if true, render cell appropriately. * @param row the row index of the cell being drawn. * @param col the column index of the cell being drawn * * @return Component */ @Override public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int col) { /* Set default values from table object and UI manager*/ if (isSelected) { textarea.setBackground(table.getSelectionBackground()); textarea.setForeground(Color.blue); } else { textarea.setBackground(table.getBackground()); textarea.setForeground(Color.blue); } textarea.setEnabled(table.isEnabled()); textarea.setFont(table.getFont()); if (hasFocus) { textarea.setBorder(UIManager.getBorder("Table.focusCellHighlightBorder")); } else { textarea.setBorder(BorderFactory.createEmptyBorder(1, 1, 1, 1)); } textarea.setHorizontalAlignment(JTextField.RIGHT); /* Compute the text string */ String str = ""; if (value != null) { if (value instanceof Double) { str += value; } } textarea.setText(str); return textarea; } }