Interface TableColumnModelExt
- All Superinterfaces:
TableColumnModel
- All Known Implementing Classes:
DefaultTableColumnModelExt
TableColumnModel suitable for use with
JXTable. It extends the notion of columns considered as part
of the view realm to include invisible columns. Conceptually, there are
several sets of "columns":
- model columns: all columns of a
TableModel. They are but a virtual concept, characterizable f.i. by (model) column index, (model) column name. - view columns: all
TableColumnExtobjects added to theTableColumnModelExt, each typically created and configured in relation to a model column. These can be regarded as a kind of subset of the model columns (not literally, obviously). Each view column belongs to exactly one of the following (real) subsets:- visible columns: all view columns with the visibility property enabled
- hidden columns: all view columns with the visibility property disabled
ColumnControlButton.
An example to programmatically hide the first visible column in the column model:
TableColumnExt columnExt = columnModel.getColumnExt(0);
if (columnExt != null) {
columnExt.setVisible(false);
}
Note that it is principally allowed to add standard TableColumns.
Practically, it doesn't make much sense to do so - they will always be
visible.
While individual visible columns can be requested by both column identifier
and column index, the latter is not available for hidden columns. An example
to programmatically guarantee that the view column which corresponds to the
first column in the associated TableModel.
List<TableColumn> columns = colModel.getColumns(true);
for (TableColumn column : columns) {
if (column.getModelIndex() == 0) {
if (column instanceof TableColumnExt) {
((TableColumnExt) column).setVisible(false);
}
return;
}
}
Alternatively, the column could be requested directly by identifier. By
default the column's headerValue is returned as identifier, if none is set.
Object identifier = tableModel.getColumnName(0);
TableColumnExt columnExt = columnModel.getColumnExt(identifier);
if (columnExt != null) {
columnExt.setVisible(false);
}
Relying on default identifiers is inherently brittle (headerValues might
change f.i. with Locales), so explicit configuration of columns with
identifiers is strongly recommended. A custom ColumnFactory
helps to automate column configuration.
This class guarantees to notify registered
TableColumnModelListeners of type
TableColumnModelExtListener about propertyChanges fired by
contained TableColumns.
An example of a client which adjusts itself based on
headerValue property of visible columns:
TableColumnModelExtListener l = new TableColumnModelExtListener() {
public void columnPropertyChange(PropertyChangeEvent event) {
if ("headerValue".equals(event.getPropertyName())) {
TableColumn column = (TableColumn) event.getSource();
if ((column instanceof TableColumnExt)
&& !((TableColumnExt) column).isVisible()) {
return;
}
resizeAndRepaint();
}
}
public void columnAdded(TableColumnModelEvent e) {
}
public void columnMarginChanged(ChangeEvent e) {
}
public void columnMoved(TableColumnModelEvent e) {
}
public void columnRemoved(TableColumnModelEvent e) {
}
public void columnSelectionChanged(ListSelectionEvent e) {
}
};
columnModel.addColumnModelListener(l);
- Author:
- Richard Bair, Jeanette Winzenburg
- See Also:
-
Method Summary
Modifier and TypeMethodDescriptionvoidAdds a listener for table column model events.intgetColumnCount(boolean includeHidden) Returns the number of contained columns.getColumnExt(int columnIndex) Returns theTableColumnExtat view positioncolumnIndex.getColumnExt(Object identifier) Returns the firstTableColumnExtwith the givenidentifier.getColumns(boolean includeHidden) Returns aListof containedTableColumns.Methods inherited from interface javax.swing.table.TableColumnModel
addColumn, getColumn, getColumnCount, getColumnIndex, getColumnIndexAtX, getColumnMargin, getColumns, getColumnSelectionAllowed, getSelectedColumnCount, getSelectedColumns, getSelectionModel, getTotalColumnWidth, moveColumn, removeColumn, removeColumnModelListener, setColumnMargin, setColumnSelectionAllowed, setSelectionModel
-
Method Details
-
getColumnCount
int getColumnCount(boolean includeHidden) Returns the number of contained columns. The count includes or excludes invisible columns, depending on whether theincludeHiddenis true or false, respectively. If false, this method returns the same count asgetColumnCount().- Parameters:
includeHidden- a boolean to indicate whether invisible columns should be included- Returns:
- the number of contained columns, including or excluding the invisible as specified.
-
getColumns
Returns aListof containedTableColumns. Includes or excludes invisible columns, depending on whether theincludeHiddenis true or false, respectively. If false, anIteratorover the List is equivalent to theEnumerationreturned bygetColumns().NOTE: the order of columns in the List depends on whether or not the invisible columns are included, in the former case it's the insertion order in the latter it's the current order of the visible columns.
- Parameters:
includeHidden- a boolean to indicate whether invisible columns should be included- Returns:
- a
Listof contained columns.
-
getColumnExt
Returns the firstTableColumnExtwith the givenidentifier. The return value is null if there is no contained column with identifier or if the column withidentifieris not of typeTableColumnExt. The returned column may be visible or hidden.- Parameters:
identifier- the object used as column identifier- Returns:
- first
TableColumnExtwith the given identifier or null if none is found
-
getColumnExt
Returns theTableColumnExtat view positioncolumnIndex. The return value is null, if the column at positioncolumnIndexis not of typeTableColumnExt. The returned column is visible.- Parameters:
columnIndex- the index of the column desired- Returns:
- the
TableColumnExtobject that matches the column index - Throws:
ArrayIndexOutOfBoundsException- if columnIndex out of allowed range, that is if(columnIndex < 0) || (columnIndex ≥ getColumnCount()).
-
addColumnModelListener
Adds a listener for table column model events. This enhances super's behaviour in that it guarantees to notify listeners of type TableColumnModelListenerExt about property changes of contained columns.- Specified by:
addColumnModelListenerin interfaceTableColumnModel- Parameters:
x- aTableColumnModelListenerobject
-