Class TableColumnExt
- All Implemented Interfaces:
Serializable
,UIDependent
TableColumn
extension for enhanced view column configuration.
The general drift is to strengthen the TableColumn abstraction as the
place to configure and dynamically update view column properties, covering a
broad range of customization requirements. Using collaborators are expected
to listen to property changes and update themselves accordingly.
A functionality enhancement is the notion of column visibility:
TableColumnModelExt
manages sets of visible/hidden
TableColumnExt
s controlled by the columns'
visible
property. Typically, users can toggle column
visibility at runtime, f.i. through a dedicated control in the upper trailing
corner of a JScrollPane
.
A prominent group of properties allows fine-grained, per-column control of corresponding Table/-Header features.
- Sorting:
sortable
controls whether this column should be sortable by user's sort gestures;Comparator
can hold a column specific type. - Editing:
editable
controls whether cells of this column should be accessible to in-table editing. - Tooltip:
toolTipText
holds the column tooltip which is shown when hovering over the column's header. - Highlighter:
highlighters
holds the column highlighters; these are applied to the renderer after the table highlighters. Any modification of the list of containedHighlighter
s (setting them, adding one or removing one) will result in aPropertyChangeEvent
being fired for "highlighters". State changes on containedHighlighter
s will result in a PropertyChangeEvent for "highlighterStateChanged".
JComponent
, this class supports per-instance
"client" properties. They are meant as a small-scale extension mechanism.
They are similar to regular bean properties in that registered
PropertyChangeListener
s are notified about changes. TODO:
example?
A TableColumnExt
implements UIDependent, that is it takes over
responsibility to update LAF dependent properties of contained elements when
messaged with updateUI. This implementation updates its Highlighter
s,
Cell-/HeaderRenderer and CellEditor.
TODO: explain prototype (sizing, collaborator-used-by ColumnFactory (?))
- Author:
- Ramesh Gupta, Amy Fowler, Jeanette Winzenburg, Karl Schaefer
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstorage for client properties.protected Comparator<?>
per-column comparatorprotected CompoundHighlighter
The compound highlighter for the column.protected boolean
per-column editable property.protected boolean
hideable property.protected Object
prototype property.protected boolean
per-column sortable property.protected boolean
visible property.Fields inherited from class javax.swing.table.TableColumn
CELL_RENDERER_PROPERTY, cellEditor, cellRenderer, COLUMN_WIDTH_PROPERTY, HEADER_RENDERER_PROPERTY, HEADER_VALUE_PROPERTY, headerRenderer, headerValue, identifier, isResizable, maxWidth, minWidth, modelIndex, resizedPostingDisableCount, width
-
Constructor Summary
ConstructorsConstructorDescriptionCreates new table view column with a model index = 0.TableColumnExt
(int modelIndex) Creates new table view column with the specified model index.TableColumnExt
(int modelIndex, int width) Creates new table view column with the specified model index and column width.TableColumnExt
(int modelIndex, int width, TableCellRenderer cellRenderer, TableCellEditor cellEditor) Creates new table view column with the specified model index, column width, cell renderer and cell editor.TableColumnExt
(TableColumnExt columnExt) Instantiates a new table view column with all properties copied from the given original. -
Method Summary
Modifier and TypeMethodDescriptionvoid
addHighlighter
(Highlighter highlighter) Appends aHighlighter
to the end of the list of usedHighlighter
s.protected void
copyClientPropertiesFrom
(TableColumnExt original) Copies all clientProperties of thisTableColumnExt
to the target column.protected void
copyFrom
(TableColumnExt original) Copies properties from original.protected ChangeListener
Creates and returns the ChangeListener observing Highlighters.protected void
firePropertyChange
(String propertyName, Object oldValue, Object newValue) Notifies registeredPropertyChangeListener
s about property changes.getClientProperty
(Object key) Returns the value of the property with the specified key.Comparator<?>
Returns the comparator to use for the column.protected CompoundHighlighter
Returns the CompoundHighlighter assigned to the table, null if none.protected ChangeListener
Returns theChangeListener
to use with highlighters.Returns theHighlighter
s used by this table.Returns the prototypeValue property.boolean
Returns true if the user can resize the TableColumn's width, false otherwise.getTitle()
Convenience method which returns the headerValue property after converting it to a string.Returns the text of to display in the column's tool tip.boolean
Returns the per-column editable property.boolean
Returns the hideable property.boolean
Returns the sortable property.boolean
Returns a boolean indicating whether or not this column is visible.void
putClientProperty
(Object key, Object value) Sets the client property "key" tovalue
.void
removeHighlighter
(Highlighter highlighter) Removes the given Highlighter.void
setComparator
(Comparator<?> comparator) Sets the comparator to use for this column.void
setEditable
(boolean editable) Sets the editable property.void
setHideable
(boolean hideable) Sets the hideable property.void
setHighlighters
(Highlighter... highlighters) Sets theHighlighter
s to the table, replacing any old settings.void
setPrototypeValue
(Object value) Sets the prototypeValue property.void
setSortable
(boolean sortable) Sets the sortable property.void
Sets the title of this view column.void
setToolTipText
(String toolTipText) Registers the text to display in the column's tool tip.void
setVisible
(boolean visible) Sets the visible property.void
updateUI()
Update ui of owned ui-dependent parts.Methods inherited from class javax.swing.table.TableColumn
addPropertyChangeListener, createDefaultHeaderRenderer, disableResizedPosting, enableResizedPosting, getCellEditor, getCellRenderer, getHeaderRenderer, getHeaderValue, getIdentifier, getMaxWidth, getMinWidth, getModelIndex, getPreferredWidth, getPropertyChangeListeners, getWidth, removePropertyChangeListener, setCellEditor, setCellRenderer, setHeaderRenderer, setHeaderValue, setIdentifier, setMaxWidth, setMinWidth, setModelIndex, setPreferredWidth, setResizable, setWidth, sizeWidthToFit
-
Field Details
-
visible
protected boolean visiblevisible property. Initialized totrue
. -
hideable
protected boolean hideablehideable property. Initialized totrue
. -
prototypeValue
prototype property. -
comparator
per-column comparator -
sortable
protected boolean sortableper-column sortable property. Initialized totrue
. -
editable
protected boolean editableper-column editable property. Initialized totrue
. -
clientProperties
storage for client properties. -
compoundHighlighter
The compound highlighter for the column.
-
-
Constructor Details
-
TableColumnExt
public TableColumnExt()Creates new table view column with a model index = 0. -
TableColumnExt
public TableColumnExt(int modelIndex) Creates new table view column with the specified model index.- Parameters:
modelIndex
- index of table model column to which this view column is bound.
-
TableColumnExt
public TableColumnExt(int modelIndex, int width) Creates new table view column with the specified model index and column width.- Parameters:
modelIndex
- index of table model column to which this view column is bound.width
- pixel width of view column
-
TableColumnExt
public TableColumnExt(int modelIndex, int width, TableCellRenderer cellRenderer, TableCellEditor cellEditor) Creates new table view column with the specified model index, column width, cell renderer and cell editor.- Parameters:
modelIndex
- index of table model column to which this view column is bound.width
- pixel width of view columncellRenderer
- the cell renderer which will render all cells in this view columncellEditor
- the cell editor which will edit cells in this view column
-
TableColumnExt
Instantiates a new table view column with all properties copied from the given original.- Parameters:
columnExt
- the column to copy properties from- See Also:
-
-
Method Details
-
setHighlighters
Sets theHighlighter
s to the table, replacing any old settings. None of the given Highlighters must be null.This is a bound property.
Note: as of version #1.257 the null constraint is enforced strictly. To remove all highlighters use this method without param.
- Parameters:
highlighters
- zero or more not null highlighters to use for renderer decoration.- Throws:
NullPointerException
- if array is null or array contains null values.- See Also:
-
getHighlighters
Returns theHighlighter
s used by this table. Maybe empty, but guarantees to be never null.- Returns:
- the Highlighters used by this table, guaranteed to never null.
- See Also:
-
addHighlighter
Appends aHighlighter
to the end of the list of usedHighlighter
s. The argument must not be null.- Parameters:
highlighter
- theHighlighter
to add, must not be null.- Throws:
NullPointerException
- ifHighlighter
is null.- See Also:
-
removeHighlighter
Removes the given Highlighter.Does nothing if the Highlighter is not contained.
- Parameters:
highlighter
- the Highlighter to remove.- See Also:
-
getCompoundHighlighter
Returns the CompoundHighlighter assigned to the table, null if none. PENDING: open up for subclasses again?.- Returns:
- the CompoundHighlighter assigned to the table.
-
getHighlighterChangeListener
Returns theChangeListener
to use with highlighters. Lazily creates the listener.- Returns:
- the ChangeListener for observing changes of highlighters,
guaranteed to be
not-null
-
createHighlighterChangeListener
Creates and returns the ChangeListener observing Highlighters.Here: repaints the table on receiving a stateChanged.
- Returns:
- the ChangeListener defining the reaction to changes of highlighters.
-
getResizable
public boolean getResizable()Returns true if the user can resize the TableColumn's width, false otherwise. This is a usability override: it takes into account the case where it's principally allowed to resize the column but not possible because the column has fixed size.- Overrides:
getResizable
in classTableColumn
- Returns:
- a boolean indicating whether the user can resize this column.
-
setEditable
public void setEditable(boolean editable) Sets the editable property. This property allows to mark all cells in a column as read-only, independent of the per-cell editability as returned by theTableModel.isCellEditable
. If the cell is read-only in the model layer, this property will have no effect.- Parameters:
editable
- boolean indicating whether or not the user may edit cell values in this view column- See Also:
-
isEditable
public boolean isEditable()Returns the per-column editable property. The default istrue
.- Returns:
- boolean indicating whether or not the user may edit cell values in this view column
- See Also:
-
setPrototypeValue
Sets the prototypeValue property. The value should be of a type which corresponds to the column's class as defined by the table model. If non-null, the JXTable instance will use this property to calculate and set the initial preferredWidth of the column. Note that this initial preferredWidth will be overridden if the user resizes columns directly.- Parameters:
value
- Object containing the value of the prototype to be used to calculate the initial preferred width of the column- See Also:
-
getPrototypeValue
Returns the prototypeValue property. The default isnull
.- Returns:
- Object containing the value of the prototype to be used to calculate the initial preferred width of the column
- See Also:
-
setComparator
Sets the comparator to use for this column.JXTable
sorting api respects this property by passing it on to theSortController
.- Parameters:
comparator
- a custom comparator to use in interactive sorting.- See Also:
-
getComparator
Returns the comparator to use for the column. The default isnull
.- Returns:
Comparator
to use for this column- See Also:
-
setSortable
public void setSortable(boolean sortable) Sets the sortable property.JXTable
sorting api respects this property by disabling interactive sorting on this column if false.- Parameters:
sortable
- boolean indicating whether or not this column can be sorted in the table- See Also:
-
isSortable
public boolean isSortable()Returns the sortable property. The default value istrue
.- Returns:
- boolean indicating whether this view column is sortable
- See Also:
-
setToolTipText
Registers the text to display in the column's tool tip. Typically, this is used byJXTableHeader
to display when the mouse cursor lingers over the column's header cell.- Parameters:
toolTipText
- text to show.- See Also:
-
getToolTipText
Returns the text of to display in the column's tool tip. The default isnull
.- Returns:
- the text of the column ToolTip.
- See Also:
-
setTitle
Sets the title of this view column. This is a convenience wrapper forsetHeaderValue
.- Parameters:
title
- String containing the title of this view column
-
getTitle
Convenience method which returns the headerValue property after converting it to a string.- Returns:
- String containing the title of this view column or null if no headerValue is set.
-
setVisible
public void setVisible(boolean visible) Sets the visible property. This property controls whether or not this view column is currently visible in the table.- Parameters:
visible
- boolean indicating whether or not this view column is visible in the table- See Also:
-
isVisible
public boolean isVisible()Returns a boolean indicating whether or not this column is visible. The bare property value is constrained by this column's hideable setting, that is a not hideable column is always visible, irrespective of the property setting.The default is
true
.- Returns:
- boolean indicating whether or not this view column is visible in the table
- See Also:
-
setHideable
public void setHideable(boolean hideable) Sets the hideable property. This property controls whether the column can be hidden. This is a bound property. If the column's visibilty is affected, listeners are notified about that change as well..The default value is true.
- Parameters:
hideable
- boolean
-
isHideable
public boolean isHideable()Returns the hideable property.- Returns:
- the hideable property.
- See Also:
-
putClientProperty
Sets the client property "key" tovalue
. Ifvalue
isnull
this method will remove the property. Changes to client properties are reported withPropertyChange
events. The name of the property (for the sake of PropertyChange events) iskey.toString()
.The
get/putClientProperty
methods provide access to a per-instance hashtable, which is intended for small scale extensions of TableColumn.- Parameters:
key
- Object which is used as key to retrieve valuevalue
- Object containing value of client property- Throws:
IllegalArgumentException
- if key isnull
- See Also:
-
getClientProperty
Returns the value of the property with the specified key. Only properties added withputClientProperty
will return a non-null
value.- Parameters:
key
- Object which is used as key to retrieve value- Returns:
- Object containing value of client property or
null
- See Also:
-
copyFrom
Copies properties from original. Handles all properties except modelIndex, width, cellRenderer, cellEditor. Called from copy constructor.- Parameters:
original
- the tableColumn to copy from- See Also:
-
copyClientPropertiesFrom
Copies all clientProperties of thisTableColumnExt
to the target column.- Parameters:
original
- the target column.
-
firePropertyChange
Notifies registeredPropertyChangeListener
s about property changes. This method must be invoked internally whe any of the enhanced properties changed.Implementation note: needed to replicate super functionality because super's field
propertyChangeSupport
and methodfireXX
are both private.- Parameters:
propertyName
- name of changed propertyoldValue
- old value of changed propertynewValue
- new value of changed property
-
updateUI
public void updateUI()Update ui of owned ui-dependent parts. This implementation updates the contained highlighters.- Specified by:
updateUI
in interfaceUIDependent
-