Package com.kheops.util
Class TableSorter
java.lang.Object
javax.swing.table.AbstractTableModel
com.kheops.util.TableSorter
- All Implemented Interfaces:
Serializable
,TableModel
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.
- See Also:
-
Field Summary
Modifier and TypeFieldDescriptionstatic final int
static final int
static final int
protected TableModel
Fields inherited from class javax.swing.table.AbstractTableModel
listenerList
-
Constructor Summary
ConstructorDescriptionTableSorter
(TableModel tableModel) TableSorter
(TableModel tableModel, JTableHeader tableHeader) -
Method Summary
Modifier and TypeMethodDescriptiongetColumnClass
(int column) int
getColumnName
(int column) protected Comparator
getComparator
(int column) protected Icon
getHeaderRendererIcon
(int column, int size) int
int
getSortingStatus
(int column) getValueAt
(int row, int column) boolean
isCellEditable
(int row, int column) boolean
int
modelIndex
(int viewIndex) void
setColumnComparator
(Class type, Comparator comparator) void
setSortingStatus
(int column, int status) void
setTableHeader
(JTableHeader tableHeader) void
setTableModel
(TableModel tableModel) protected void
void
setUsingClassicArrow
(boolean b) void
setUsingCollators
(boolean b) void
setValueAt
(Object aValue, int row, int column) boolean
boolean
int
viewIndex
(int modelIndex) Methods inherited from class javax.swing.table.AbstractTableModel
addTableModelListener, findColumn, fireTableCellUpdated, fireTableChanged, fireTableDataChanged, fireTableRowsDeleted, fireTableRowsInserted, fireTableRowsUpdated, fireTableStructureChanged, getListeners, getTableModelListeners, removeTableModelListener
-
Field Details
-
tableModel
-
DESCENDING
public static final int DESCENDING- See Also:
-
NOT_SORTED
public static final int NOT_SORTED- See Also:
-
ASCENDING
public static final int ASCENDING- See Also:
-
-
Constructor Details
-
TableSorter
public TableSorter() -
TableSorter
-
TableSorter
-
-
Method Details
-
setUsingClassicArrow
public void setUsingClassicArrow(boolean b) -
usingClassicArrow
public boolean usingClassicArrow() -
setUsingCollators
public void setUsingCollators(boolean b) -
usingCollators
public boolean usingCollators() -
setupCollators
protected void setupCollators() -
getTableModel
-
setTableModel
-
getTableHeader
-
setTableHeader
-
isSorting
public boolean isSorting() -
getSortingStatus
public int getSortingStatus(int column) -
setSortingStatus
public void setSortingStatus(int column, int status) -
getHeaderRendererIcon
-
setColumnComparator
-
getComparator
-
modelIndex
public int modelIndex(int viewIndex) -
viewIndex
public int viewIndex(int modelIndex) -
getRowCount
public int getRowCount() -
getColumnCount
public int getColumnCount() -
getColumnName
- Specified by:
getColumnName
in interfaceTableModel
- Overrides:
getColumnName
in classAbstractTableModel
-
getColumnClass
- 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
-
setValueAt
- Specified by:
setValueAt
in interfaceTableModel
- Overrides:
setValueAt
in classAbstractTableModel
-