java中如何把JTable设置为不可编辑
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java中如何把JTable设置为不可编辑相关的知识,希望对你有一定的参考价值。
在java中把表格设置为不可编辑有两种办法1.自己做一个JTable类:如下 import javax.swing.JTable;public class MyTable extends JTable public MyTable()super(); //默认构造,可有可无&nb...
可以将表格直接设置为不可选择,table.setEnable(false);
编写自定义的表格,继承JTable,重写boolean isCellEditable(int row,int column)方法,直接在方法中返回false。
javax.swing.table.DefaultTableModel t = new javax.swing.table.DefaultTableModel(columnName,0)
public boolean isCellEditable(int row, int column)
return false;
;
jTable.setModel(t);
一、java简介:Java是一种可以撰写跨平台应用软件的面向对象的程序设计语言。Java 技术具有卓越的通用性、高效性、平台移植性和安全性,广泛应用于PC、数据中心、游戏控制台、科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
二、java主要组成:
Java编程语言,即语法。
Java文件格式,即各种文件夹、文件的后缀。
Java虚拟机(JVM),即处理*.class文件的解释器。
Java应用程序接口(Java API)。
三、基本语法:
大小写敏感:Java是大小写敏感的,这就意味着标识符Hello与hello是不同的。
类名:对于所有的类来说,类名的首字母应该大写。如果类名由若干单词组成,那么每个单词的首字母应该大写,例如 MyFirstJavaClass。
方法名:所有的方法名都应该以小写字母开头。如果方法名含有若干单词,则后面的每个单词首字母大写,例如myFirstJavaClass。
源文件名:源文件名必须和类名相同。当保存文件的时候,你应该使用类名作为文件名保存(切记Java是大小写敏感的),文件名的后缀为.java。(如果文件名和类名不相同则会导致编译错误)。
主方法入口:所有的Java 程序由public static void main(String[]args)方法开始执行。
使用上面得到代码就可以做到了.
如果要设置为可编辑, 只需要把参数设置为true就可以了
jtable.setEnabled(true);//设置表格为可编辑 参考技术C JTable类本身就有方法可以实现不可编辑功能例如:
Table =new JTable(int numRows, int numColumns);
Table.setEnabled(false); 参考技术D 每次获得焦点时就输入无效或跳开焦点
Java JTable改变单元格颜色
我想制作一个可编辑的表,然后检查数据以确保其有效。我不知道如何改变一个细胞的颜色。我想获得一个单元格,例如(0,0)并将前景颜色设置为红色。我已经阅读了SO以及Oracle关于自定义ColorRenderer的其他帖子,但我只是不知道如何使用它。
谢谢。
假设您要使用不同颜色渲染的单元格表示状态(我将以“拒绝和已批准”为例)。然后我在我的表模型中实现一个名为getStatus(int row)的方法,它返回任何给定行的状态。
然后,当它到位时,我将创建一个单元格渲染器,负责渲染单元格所属的列。单元格渲染器将在下面的代码行中。
public class StatusColumnCellRenderer extends DefaultTableCellRenderer {
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int col) {
//Cells are by default rendered as a JLabel.
JLabel l = (JLabel) super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, col);
//Get the status for the current row.
CustomTableModel tableModel = (CustomTableModel) table.getModel();
if (tableModel.getStatus(row) == CustomTableModel.APPROVED) {
l.setBackground(Color.GREEN);
} else {
l.setBackground(Color.RED);
}
//Return the JLabel which renders the cell.
return l;
}
然后,当渲染器到位时,只需使用以下代码“将”渲染器“应用”到表中:
Table.getColumnModel().getColumn(columnIndex).setCellRenderer(new StatusColumnCellRenderer());
关于使单元格可编辑,只需在表模型中实现isCellEditable(int rowIndex,int columnIndex)方法。如果你想保留用户提供的值(我假设你这样做),你还需要实现方法setValueAt(Object value,int rowIndex,int columnIndex)。
我想制作一个可编辑的表,然后检查数据以确保其有效。
另一种方法是在将数据保存到表模型之前编辑数据,以防止输入无效数据。
import java.awt.*;
import java.awt.event.*;
import javax.swing.*;
import javax.swing.text.*;
import javax.swing.event.*;
import javax.swing.border.*;
import javax.swing.table.*;
public class TableEdit extends JFrame
{
TableEdit()
{
JTable table = new JTable(5,5);
table.setPreferredScrollableViewportSize(table.getPreferredSize());
JScrollPane scrollpane = new JScrollPane(table);
getContentPane().add(scrollpane);
// Use a custom editor
TableCellEditor fce = new FiveCharacterEditor();
table.setDefaultEditor(Object.class, fce);
}
class FiveCharacterEditor extends DefaultCellEditor
{
FiveCharacterEditor()
{
super( new JTextField() );
}
public boolean stopCellEditing()
{
try
{
String editingValue = (String)getCellEditorValue();
if(editingValue.length() != 5)
{
JTextField textField = (JTextField)getComponent();
textField.setBorder(new LineBorder(Color.red));
textField.selectAll();
textField.requestFocusInWindow();
JOptionPane.showMessageDialog(
null,
"Please enter string with 5 letters.",
"Alert!",JOptionPane.ERROR_MESSAGE);
return false;
}
}
catch(ClassCastException exception)
{
return false;
}
return super.stopCellEditing();
}
public Component getTableCellEditorComponent(
JTable table, Object value, boolean isSelected, int row, int column)
{
Component c = super.getTableCellEditorComponent(
table, value, isSelected, row, column);
((JComponent)c).setBorder(new LineBorder(Color.black));
return c;
}
}
public static void main(String [] args)
{
JFrame frame = new TableEdit();
frame.setDefaultCloseOperation(EXIT_ON_CLOSE);
frame.pack();
frame.setLocationRelativeTo( null );
frame.setVisible(true);
}
}
最直接的方法是通过扩展TableCellRenderer
并将DefaultTableCellRenderer
方法覆盖到getTableCellRendererComponent
来编写一个简单的setBackground( Color.RED )
。例如:
final JTable table = new JTable(...);
table.setCellRenderer( new DefaultTableCellRenderer() {
public Component getTableCellRenderer(JTable table, Object value, ...) {
super.getTableCellRenderer(...);
if ( value should be highlighted ) {
setBackground( Color.RED );
}
return this;
}
});
这是为jTable中的特定列或单元着色的最简单方法。
首先,只需创建一个简单的CustomRenderer
类
class CustomRenderer extends DefaultTableCellRenderer <br />
{
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column)
{
Component c = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
setForeground(Color.blue); >
return c;
}
}
此代码获取要呈现的单元格列
TableColumn col = tblExamHistoryAll.getColumnModel().getColumn(5);
DefaultTableModel model3 = (DefaultTableModel)tblExamHistoryAll.getModel();
col.setCellRenderer(new CustomRenderer());
这是为了清除表中的所有先前行。如果您不想要它们,只需删除这些行
model3.getDataVector().removeAllElements();
model3.fireTableDataChanged();
我相信在表格中进行着色的正确方法是通过ColorHighlighter
。表格渲染器在同一列中呈现不同颜色存在问题。
这是一个如何使用荧光笔的例子。在这种情况下,它用于突出显示不可编辑的单元格。
public class IsCellEditablePredicate implements HighlightPredicate {
private JXTable table;
public IsCellEditablePredicate (final JXTable table) {
this.table = table;
}
@Override
public boolean isHighlighted(Component component, ComponentAdapter componentAdapter) {
return !table.isCellEditable(componentAdapter.row,
componentAdapter.column);
}
}
然后在您设置表格的代码中添加突出显示及其颜色参数:
ColorHighlighter grayHighlighter = new ColorHighlighter(new IsCellEditablePredicate(table));
grayHighlighter.setBackground(Color.LIGHT_GRAY);
grayHighlighter.setForeground(table.getForeground());
grayHighlighter.setSelectedBackground(table.getSelectionBackground().darker());
grayHighlighter.setSelectedForeground(table.getSelectionForeground().darker());
table.setHighlighters(grayHighlighter);
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus,
int row, int col) {
Component c = super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, col);
int control = row;
control = control % 2;
control = (control == 0) ? 1 : 0;
if (control == 1) {
c.setBackground(Color.green);
} else {
c.setBackground(Color.cyan);
}
return c;
}
您可以扩展DefaultTableCellRenderer,覆盖getTableCellRendererComponent并调用类似的东西
if (myConditions) setBackground(myColor);
在条件适用时返回“this”之前,由于DefaultTableCellRenderer.setBackGround的编码方式,它有一个非常烦人的副作用,即改变默认的背景颜色。
我发现的技巧是在名为HackedDefaultTableCellRenderer的类中完全复制DefaultTableCellRenderer的代码,添加一个直接调用Component的setBackground实现的方法:
public void setComponentBackground(Color c) {
super.setBackground(c);
}
然后从这个被黑客的类而不是DefaultTableCellRenderer派生我自定义的渲染,最后在我的自定义getTableCellRendererComponent中调用setComponentBackground而不是setBackground。
缺点是这个HackedDefaultTableCellRenderer依赖于DefaultTableCell
以上是关于java中如何把JTable设置为不可编辑的主要内容,如果未能解决你的问题,请参考以下文章
你好,我看你关于jtable的编辑列改为非编辑列, 你知道jqgrid的编辑列如何停止编辑吗?