□ Конструктор JTable (Object[] [] data, Object[] colNames) создает таблицу, заполненную объектами data. Параметр colNames содержит имена столбцов таблицы. Все строки массива data должны содержать столько же элементов, сколько существует в массиве colNames. Пример создания таблицы этим конструктором приведен в листинге 13.1.
□ Конструктор JTable (Vector data, Vector colNames) делает то же самое, но параметры заданы векторами. Пример его использования представлен в листинге 13.3.
Надо заметить, что заголовки столбцов автоматически появляются на экране, только
если таблица заключена в панель JScrollPane. Если при этом у столбцов не заданы имена, то они помечаются буквами A, B, C и т. д., как принято в электронных таблицах.
Остальные конструкторы определяют таблицу с заранее заданными моделями данных.
□ Конструктор JTable (TableModel) использует заданную параметром модель ячеек таблицы. Модель столбцов и модель выделения данных определяются по умолчанию.
□ Конструктор JTable (TableModel, TableColumnModel) оставляет модель выделения данных по умолчанию.
□ Конструктор JTable (TableModel, TableColumnModel, ListSelectionModel) задает все три модели данных.
Листинг 13.1 показывает простой пример определения таблицы с помощью массива
объектов, в данном случае — строк.
import java.awt.*; import javax.swing.*;
public class SimpTable extends JFrame{
SimpTable(){
super(" My Table"); setLayout(new FlowLayout());
String[][] data = {{"-27", "32"}, {"-45", "55"}}; String[] colNames = {"Вчера", "Сегодня"};
JTable t1 = new JTable(data, colNames);
add(new JScrollPane(t1)); setSize(400, 400);
setDefaultCloseOperation(EXIT ON CLOSE); setVisible(true);
}
public static void main(String[] args){ new SimpTable();
}
}
Таблицу можно заполнить методом
setValueAt(Object data, int row, int column);
Он заменяет старое содержимое ячейки (row, column)
В таблице можно задать или заменить
Модель данных таблицы
Таблица класса JTable пользуется тремя моделями данных для хранения своих элементов. Две модели, описанные интерфейсами TableModel и TableColumnModel, специфичны для таблиц, третья модель — ListSelectionModel — заимствована у списков JList. Она уже рассматривалась нами в
Модель хранения содержимого ячеек таблицы описана интерфейсом TableModel, который частично реализован абстрактным классом AbstractTableModel и полностью реализован его подклассом DefaultTableModel.
Эта модель предполагает, что в ячейках таблицы могут храниться объекты любого типа и в разных ячейках даже одного столбца могут храниться объекты разных типов.
Строки и столбцы пронумерованы, начиная от нуля. Общий суперкласс всех ячеек столбца с индексом ind можно получить методом getColumnClass(int ind). Текущее число строк в таблице можно узнать методом getRowCount ( ), число столбцов- методом
getColumnCount (). У столбца может быть имя, получить которое можно методом getColumnName (int), возвращающим строку класса String.
Содержимое ячейки таблицы можно получить из модели данных в виде объекта класса Object методом getValueAt (int rowInd, int colInd), а установить в модель, если ячейка
редактируема, — методом setValueAt(Object data, int rowInd, int colInd).
Проверить, редактируема ячейка или нет, можно логическим методом
isCellEditable(int rowInd, int colInd).
Легко создать свою модель ячеек таблицы, расширив класс AbstractTableModel. При этом необходимо определить три метода:
int getRowCount(); int getColumnCount();
Object getValueAt(int, int);
import java.awt.*; import javax.swing.*; import javax.swing.table.*;
public class SimpTable extends JFrame{
SimpTable(){
super(" Таблица с неизменяемым первым столбцом"); setLayout(new FlowLayout());
JTable t1 = new JTable(new FirstColumnTableModel());
add(new JScrollPane(t1));
setSize(400, 400);
setDefaultCloseOperation(JFrame.EXIT ON CLOSE); setVisible(true);
}
public static void main(String[] args){ new SimpTable();
}
}