TableModelListener и проверка нескольких столбцов - PullRequest
2 голосов
/ 22 августа 2010

Я впервые здесь пишу, извините, если я допустил ошибку.

Я работаю над 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);
        }
    }

Проблема этого кода в том, что он возвращает переполнение стека, и я не знаю, как с этим справиться.

Есть ли какой-нибудь другой способ реализации некоторого верификатора в таблице, который подразумевает наличие нескольких ячеек?

Заранее спасибо.

Ответы [ 2 ]

3 голосов
/ 22 августа 2010

Проблема этого кода в том, что он возвращает переполнение стека, и я не знаю, как с этим справиться.

Проблема в том, что ваш код устанавливает значение в моделислушатель, поэтому генерируется другое событие 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);
    }
}
1 голос
/ 22 августа 2010

Возможно, вы получили ошибку из-за вызова getFirstRow. Я считаю плохой идеей проверять структуру таблицы в JTable.tableChanged - откуда вы знаете, что таблица полностью заполнена и готова к проверке? Я бы предложил сначала заполнить всю таблицу, а затем вызвать проверку. Возможно, было бы также неплохо использовать отдельную таблицу для отображения результатов проверки

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...