DefaultTableModel.java
上传用户:haobig99
上传日期:2022-06-15
资源大小:369k
文件大小:3k
源码类别:

J2ME

开发平台:

Java

  1. /*
  2.  * Copyright 2008 Sun Microsystems, Inc.  All Rights Reserved.
  3.  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
  4.  *
  5.  * This code is free software; you can redistribute it and/or modify it
  6.  * under the terms of the GNU General Public License version 2 only, as
  7.  * published by the Free Software Foundation.  Sun designates this
  8.  * particular file as subject to the "Classpath" exception as provided
  9.  * by Sun in the LICENSE file that accompanied this code.
  10.  *
  11.  * This code is distributed in the hope that it will be useful, but WITHOUT
  12.  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  13.  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  14.  * version 2 for more details (a copy is included in the LICENSE file that
  15.  * accompanied this code).
  16.  *
  17.  * You should have received a copy of the GNU General Public License version
  18.  * 2 along with this work; if not, write to the Free Software Foundation,
  19.  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  20.  *
  21.  * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
  22.  * CA 95054 USA or visit www.sun.com if you need additional information or
  23.  * have any questions.
  24.  */
  25. package com.sun.lwuit.table;
  26. import com.sun.lwuit.events.DataChangedListener;
  27. import com.sun.lwuit.util.EventDispatcher;
  28. /**
  29.  * A default implementation of the table model based on a two dimensional array.
  30.  *
  31.  * @author Shai Almog
  32.  */
  33. public class DefaultTableModel implements TableModel {
  34.     private Object[][] data;
  35.     private String[] columnNames;
  36.     private EventDispatcher dispatcher = new EventDispatcher();
  37.     private boolean editable;
  38.     /**
  39.      * Constructs a new table with a 2 dimensional array for row/column data
  40.      *
  41.      * @param columnNames the names of the columns
  42.      * @param data the data within the table
  43.      */
  44.     public DefaultTableModel(String[] columnNames, Object[][] data) {
  45.         this(columnNames, data, false);
  46.     }
  47.     /**
  48.      * Constructs a new table with a 2 dimensional array for row/column data
  49.      *
  50.      * @param columnNames the names of the columns
  51.      * @param data the data within the table
  52.      * @param editable indicates whether table cells are editable or not by default
  53.      * @see isCellEditable
  54.      */
  55.     public DefaultTableModel(String[] columnNames, Object[][] data, boolean editable) {
  56.         this.data = data;
  57.         this.columnNames = columnNames;
  58.         this.editable = editable;
  59.     }
  60.     /**
  61.      * @inheritDoc
  62.      */
  63.     public int getRowCount() {
  64.         return data.length;
  65.     }
  66.     /**
  67.      * @inheritDoc
  68.      */
  69.     public int getColumnCount() {
  70.         return columnNames.length;
  71.     }
  72.     /**
  73.      * @inheritDoc
  74.      */
  75.     public String getColumnName(int i) {
  76.         return columnNames[i];
  77.     }
  78.     /**
  79.      * @inheritDoc
  80.      */
  81.     public boolean isCellEditable(int row, int column) {
  82.         return editable;
  83.     }
  84.     /**
  85.      * @inheritDoc
  86.      */
  87.     public Object getValueAt(int row, int column) {
  88.         return data[row][column];
  89.     }
  90.     /**
  91.      * @inheritDoc
  92.      */
  93.     public void setValueAt(int row, int column, Object o) {
  94.         data[row][column] = o;
  95.         dispatcher.fireDataChangeEvent(column, row);
  96.     }
  97.     /**
  98.      * @inheritDoc
  99.      */
  100.     public void addDataChangeListener(DataChangedListener d) {
  101.         dispatcher.addListener(d);
  102.     }
  103.     /**
  104.      * @inheritDoc
  105.      */
  106.     public void removeDataChangeListener(DataChangedListener d) {
  107.         dispatcher.removeListener(d);
  108.     }
  109. }