JTable计算最后一列的总和

时间:2015-01-05 18:13:07

标签: java swing event-handling jtable

我有一个JTable巫婆实现了TableModelListener,我已经实现了tableChanged(TableModelEvent事件)方法,但是我无法检测到被修改的右列。我得到col -1,而我正在编辑第二列或特定列。

这是我执行tableChanged(TableModelEvent事件)的方法:

import java.awt.BorderLayout;
import java.awt.EventQueue;
import javax.swing.JDialog;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.table.AbstractTableModel;


public class JTableTest extends JDialog{
    private JTable myTable ; 

    public JTableTest() {
        super();

        myTable = new JTable(new myTableModel());
        getContentPane().add(new JScrollPane(myTable),BorderLayout.CENTER);
        pack();
    }

    class myTableModel extends AbstractTableModel implements TableModelListener{

        Object[][] donnees = {
                {"Johnathan", "Sykes","Natation"},
                {"Nicolas", "Van de Kampf","FOOTBALL" },
                {"Damien", "Cuthbert","TENNIS" },
                {"Corinne", "Valance","NATATION"},
                {"Emilie", "Schrödinger","FOOTBALL"},
                {"Delphine", "Duke","TENNIS"},
                {"Eric", "Trump","TENNIS"},
        };

        String[] entetes = {"Prénom", "Nom","SPORT"};

        public myTableModel() {
            addTableModelListener(this);
        }

         public int getRowCount() {
        return donnees.length;

    }

    public int getColumnCount() {
        return entetes.length;
    }

    public String getColumnName(int columnIndex) {
        return entetes[columnIndex];
    }

    public Object getValueAt(int rowIndex, int columnIndex) {
        return donnees[rowIndex][columnIndex];
    }

        @Override
        public void tableChanged(TableModelEvent me) {
            // I wanna get the right column not -1
            System.out.println(me.getColumn());
            switch(me.getType()){
                case TableModelEvent.UPDATE:
                    System.out.println("Updating...");break;
                case TableModelEvent.INSERT:
                    System.out.println("Inserting...");break; 
                case TableModelEvent.DELETE:
                    System.out.println("Delete...");break;
                default :break ;
            }

         }

        @Override
        public void setValueAt(Object value, int row, int col) {
            donnees[row][col] = (String) value;
            fireTableDataChanged();
         }


        @Override
        public boolean isCellEditable(int row, int col) {
            return true; 
         }



}

    public static void main(String[] args)
    {
        EventQueue.invokeLater(new Runnable()
        {
            public void run()
            {
                new JTableTest().setVisible(true);
            }
        });
    }








}

2 个答案:

答案 0 :(得分:2)

根据您的原始问题,我们如何猜测您正在使用自定义TableModel?这就是为什么你应该总是在问题上加上适当的SSCCE,这样我们就不必猜测你可能会做什么或不做什么。

为什么使用自定义TableModel?无需创建自定义模型。 DefaultTableModel将执行您的自定义模型所做的事情。

无论如何,问题确实在于您的自定义TableModel:

//fireTableDataChanged();
fireTableCellUpdated(row, col);

您没有更改所有数据。您只更改了一个单元格的数据,因此触发了正确的事件。

答案 1 :(得分:0)

方法BigDecimal.add(BigDecimal)返回 BigDecimal 。它没有重新分配价值。

您应该使用以下代码重新分配somme值:

somme = somme.add((BigDecimal) getValueAt(i, 3));