[英]TableModelListener and multiple column validation
這是我第一次在這里發帖,對不起,如果我出錯了。
我正在處理一個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);
}
}
您可能由於getFirstRow
調用而收到錯誤。 我認為在JTable.tableChanged
驗證表結構不是一個好主意-您如何知道表已完全填充並准備進行驗證? 我建議先填寫整個表格,然后再進行驗證。 也許最好使用單獨的表格來顯示驗證結果
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.