- java.lang.Object
-
- javax.swing.table.AbstractTableModel
-
- com.iamsoft.util.ui.swing.TableSorter
-
- All Implemented Interfaces:
Serializable
,TableModel
public class TableSorter extends AbstractTableModel
TableSorter is a decorator for TableModels; adding sorting functionality to a supplied TableModel. TableSorter does not store or copy the data in its TableModel; instead it maintains a map from the row indexes of the view to the row indexes of the model. As requests are made of the sorter (like getValueAt(row, col)) they are passed to the underlying model after the row numbers have been translated via the internal mapping array. This way, the TableSorter appears to hold another copy of the table with the rows in a different order.
TableSorter registers itself as a listener to the underlying model, just as the JTable itself would. Events recieved from the model are examined, sometimes manipulated (typically widened), and then passed on to the TableSorter's listeners (typically the JTable). If a change to the model has invalidated the order of TableSorter's rows, a note of this is made and the sorter will resort the rows the next time a value is requested.
When the tableHeader property is set, either by using the setTableHeader() method or the two argument constructor, the table header may be used as a complete UI for TableSorter. The default renderer of the tableHeader is decorated with a renderer that indicates the sorting status of each column. In addition, a mouse listener is installed with the following behavior:
- Mouse-click: Clears the sorting status of all other columns and advances the sorting status of that column through three values: {NOT_SORTED, ASCENDING, DESCENDING} (then back to NOT_SORTED again).
- SHIFT-mouse-click: Clears the sorting status of all other columns and cycles the sorting status of the column through the same three values, in the opposite order: {NOT_SORTED, DESCENDING, ASCENDING}.
- CONTROL-mouse-click and CONTROL-SHIFT-mouse-click: as above except that the changes to the column do not cancel the statuses of columns that are already sorting - giving a way to initiate a compound sort.
This is a long overdue rewrite of a class of the same name that first appeared in the swing table demos in 1997.
Customized to prevent excessive event widening. Single row insert/deletes will no longer fire a data changed event. Instead, a new insert/delete event will be fired. The view to model map will not be completely recalculated. Instead, after an inset, a binary search will be used to place the new row. After a delete, the removed row will simply be removed from the sort map. Note that events will be widened if sorting is enabled and
- the viewToModel array has not been calculated.
- the underlying event is an 'update'.
- the underlying event spans more than one row.
- Version:
- 2.0 02/27/04
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static int
ASCENDING
static Comparator
COMPARABLE_COMAPRATOR
static int
DESCENDING
static Comparator
LEXICAL_COMPARATOR
static int
NOT_SORTED
protected TableModel
tableModel
-
Fields inherited from class javax.swing.table.AbstractTableModel
listenerList
-
-
Constructor Summary
Constructors Constructor Description TableSorter()
TableSorter(TableModel tableModel)
TableSorter(TableModel tableModel, JTableHeader tableHeader)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Class
getColumnClass(int column)
int
getColumnCount()
String
getColumnName(int column)
protected Comparator
getComparator(int column)
protected Icon
getHeaderRendererIcon(int column, int size)
int
getRowCount()
int
getSortingStatus(int column)
JTableHeader
getTableHeader()
TableModel
getTableModel()
Object
getValueAt(int row, int column)
boolean
isCellEditable(int row, int column)
boolean
isSorting()
int
modelIndex(int viewIndex)
void
setColumnComparator(Class type, Comparator comparator)
void
setSortingStatus(int column, int status)
void
setTableHeader(JTableHeader tableHeader)
void
setTableModel(TableModel tableModel)
void
setValueAt(Object aValue, int row, int column)
-
Methods inherited from class javax.swing.table.AbstractTableModel
addTableModelListener, findColumn, fireTableCellUpdated, fireTableChanged, fireTableDataChanged, fireTableRowsDeleted, fireTableRowsInserted, fireTableRowsUpdated, fireTableStructureChanged, getListeners, getTableModelListeners, removeTableModelListener
-
-
-
-
Field Detail
-
tableModel
protected TableModel tableModel
-
DESCENDING
public static final int DESCENDING
- See Also:
- Constant Field Values
-
NOT_SORTED
public static final int NOT_SORTED
- See Also:
- Constant Field Values
-
ASCENDING
public static final int ASCENDING
- See Also:
- Constant Field Values
-
COMPARABLE_COMAPRATOR
public static final Comparator COMPARABLE_COMAPRATOR
-
LEXICAL_COMPARATOR
public static final Comparator LEXICAL_COMPARATOR
-
-
Constructor Detail
-
TableSorter
public TableSorter()
-
TableSorter
public TableSorter(TableModel tableModel)
-
TableSorter
public TableSorter(TableModel tableModel, JTableHeader tableHeader)
-
-
Method Detail
-
getTableModel
public TableModel getTableModel()
-
setTableModel
public void setTableModel(TableModel tableModel)
-
getTableHeader
public JTableHeader getTableHeader()
-
setTableHeader
public void setTableHeader(JTableHeader tableHeader)
-
isSorting
public boolean isSorting()
-
getSortingStatus
public int getSortingStatus(int column)
-
setSortingStatus
public void setSortingStatus(int column, int status)
-
getHeaderRendererIcon
protected Icon getHeaderRendererIcon(int column, int size)
-
setColumnComparator
public void setColumnComparator(Class type, Comparator comparator)
-
getComparator
protected Comparator getComparator(int column)
-
modelIndex
public int modelIndex(int viewIndex)
-
getRowCount
public int getRowCount()
-
getColumnCount
public int getColumnCount()
-
getColumnName
public String getColumnName(int column)
- Specified by:
getColumnName
in interfaceTableModel
- Overrides:
getColumnName
in classAbstractTableModel
-
getColumnClass
public Class getColumnClass(int column)
- Specified by:
getColumnClass
in interfaceTableModel
- Overrides:
getColumnClass
in classAbstractTableModel
-
isCellEditable
public boolean isCellEditable(int row, int column)
- Specified by:
isCellEditable
in interfaceTableModel
- Overrides:
isCellEditable
in classAbstractTableModel
-
getValueAt
public Object getValueAt(int row, int column)
-
setValueAt
public void setValueAt(Object aValue, int row, int column)
- Specified by:
setValueAt
in interfaceTableModel
- Overrides:
setValueAt
in classAbstractTableModel
-
-