这是我第一次在这里发帖,如果我出错了,抱歉。
我正在处理一个JTable,其中的列数据必须验证一些参数,例如:
第3列的值> 30
第4列的值> 10
第5列的值> 4
另外,前2列也被“自动”填充,其余的列则为0。
如果该数据是正确的,则在第5栏中,我将显示一个勾号图像,否则,我将显示一个警告图像。
为了验证这一点,我使用以下代码
ImageIcon accept = new javax.swing.ImageIcon(getClass().getResource("/resources/accept.png"));
ImageIcon deny = new javax.swing.ImageIcon(getClass().getResource("/resources/exclamation.png"));
public void tableChanged(TableModelEvent e) {
int row = e.getFirstRow();
double d1 = Double.valueOf(jTable.getValueAt(row, 2).toString());
double d2 = Double.valueOf(jT.getValueAt(row, 3).toString());
double d3 = Double.valueOf(jT.getValueAt(row, 4).toString());
if(d1>MAX_A||d2>MAX_B||d3>MAX_C){
jTable.setValueAt(deny, row, 5);
}
else{
jTable.setValueAt(accept, row, 5);
}
}
此代码的问题是返回堆栈溢出,我不知道该如何处理。
提前致谢。
此代码的问题是返回堆栈溢出,我不知道该如何处理。
问题是您的代码在模型侦听器中设置了一个值,因此生成了另一个tableChanged事件。您的代码应类似于:
if (e.getColumn() != 5)
// do your code
我没有看到使用TableModelListener来基于另一列中的数据动态设置列的值的问题。这是一个简单的示例:
import java.awt.*;
import javax.swing.*;
import javax.swing.event.*;
import javax.swing.table.*;
public class TableProcessing extends JFrame implements TableModelListener
{
JTable table;
public TableProcessing()
{
super("Table");
String[] columnNames = {"Item", "Quantity", "Price", "Cost"};
Object[][] data =
{
{"Bread", new Integer(1), new Double(1.11), new Double(1.11)},
{"Milk", new Integer(1), new Double(2.22), new Double(2.22)},
{"Tea", new Integer(1), new Double(3.33), new Double(3.33)},
{"Cofee", new Integer(1), new Double(4.44), new Double(4.44)}
};
DefaultTableModel model = new DefaultTableModel(data, columnNames);
model.addTableModelListener( this );
//
table = new JTable( model )
{
// Returning the Class of each column will allow different
// renderers to be used based on Class
public Class getColumnClass(int column)
{
return getValueAt(0, column).getClass();
}
// The Cost is not editable
public boolean isCellEditable(int row, int column)
{
int modelColumn = convertColumnIndexToModel( column );
return (modelColumn == 3) ? false : true;
}
};
table.setPreferredScrollableViewportSize(table.getPreferredSize());
//
JScrollPane scrollPane = new JScrollPane( table );
getContentPane().add( scrollPane );
String[] items = { "Bread", "Milk", "Tea", "Coffee" };
JComboBox editor = new JComboBox( items );
DefaultCellEditor dce = new DefaultCellEditor( editor );
table.getColumnModel().getColumn(0).setCellEditor(dce);
}
/*
* The cost is recalculated whenever the quantity or price is changed
*/
public void tableChanged(TableModelEvent e)
{
if (e.getType() == TableModelEvent.UPDATE)
{
int row = e.getFirstRow();
int column = e.getColumn();
if (column == 1 || column == 2)
{
TableModel model = table.getModel();
int quantity = ((Integer)model.getValueAt(row, 1)).intValue();
double price = ((Double)model.getValueAt(row, 2)).doubleValue();
Double value = new Double(quantity * price);
model.setValueAt(value, row, 3);
}
}
}
public static void main(String[] args)
{
TableProcessing frame = new TableProcessing();
frame.setDefaultCloseOperation( EXIT_ON_CLOSE );
frame.pack();
frame.setLocationRelativeTo( null );
frame.setVisible(true);
}
}
嗨,我希望我的JTable实现TableModelListener,这样如果TableModel的数据发生变化,它就可以做出反应。但是,一旦我在JTable子类中实现了TableModelListener,该表就不再显示在框架中了。 但是如果我让我的JTable子类像这样实现一个TableModelListener: 该表不再显示在框架中。为什么?我能做些什么来解决这个问题?
我正在使用JSR303,并编写了大量注释,因此我熟悉使用自定义约束的过程。 我刚刚遇到了一个问题,我不确定我能否优雅地解决。这里的对象是为了说明!所以我有一个祖父母对象,它有一个孩子的列表。每个孩子都有自己的孩子列表(显然是祖父母的孙子)。此列表的大小可以用@size约束。但我需要限制祖父母的(孙子)总数,这样,如果我验证祖父母实例,他们在所有子女中的孙子数量限制为50个。举个奇怪的例子,我知道:
我正在努力定义JSR303验证规则,即重新定义容器bean的默认组。 我想验证容器bean的大小,当且仅当: def属性有效 使用elem集合的任何元素bean都没有验证错误 如果我使用默认组验证容器: 即使内部元素bean存在验证错误,也会触发大小验证器。 如果我从容器类中删除@GroupSequence(跳过为容器重新定义默认组),并将自己的GroupSequence定义为: 然后使用AllV
问题内容: 请帮我这个: 我想按列TestType分组,但如果它们具有相同的TestType,则应将Result拆分为colunms 我希望SQL以这种格式返回数据 Result#列应该是动态的,因为每个TestType都有很多结果 问题答案: 正如我在评论中所提到的,这里您需要的是或交叉标签;我更喜欢后者,所以我将要使用的东西。 对此的非动态解决方案如下: 但是,问题在于这会将您“锁定”到3个结
问题内容: 我在表服务器中有2列。 我有专栏和。 我有验证: 这仅适用于列。但是如何做到这一点并适用于专栏呢? 我想列验证data.ip 和。因为在用户写入ip时,ip和主机名列中可以重复。 问题答案: 您可以用来实现验证规则
我已经使用extend from创建了自定义规则。所以我有这个 当为false且为true时,从上述代码中,它会被上一条规则覆盖,因此结果始终被视为true而不是false 那么我如何才能做到这一点呢? 规则: