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
TableColumnExts 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:
sortablecontrols whether this column should be sortable by user's sort gestures;Comparatorcan hold a column specific type. - Editing:
editablecontrols whether cells of this column should be accessible to in-table editing. - Tooltip:
toolTipTextholds the column tooltip which is shown when hovering over the column's header. - Highlighter:
highlightersholds the column highlighters; these are applied to the renderer after the table highlighters. Any modification of the list of containedHighlighters (setting them, adding one or removing one) will result in aPropertyChangeEventbeing fired for "highlighters". State changes on containedHighlighters 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
PropertyChangeListeners 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 Highlighters,
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 CompoundHighlighterThe compound highlighter for the column.protected booleanper-column editable property.protected booleanhideable property.protected Objectprototype property.protected booleanper-column sortable property.protected booleanvisible 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 TypeMethodDescriptionvoidaddHighlighter(Highlighter highlighter) Appends aHighlighterto the end of the list of usedHighlighters.protected voidcopyClientPropertiesFrom(TableColumnExt original) Copies all clientProperties of thisTableColumnExtto the target column.protected voidcopyFrom(TableColumnExt original) Copies properties from original.protected ChangeListenerCreates and returns the ChangeListener observing Highlighters.protected voidfirePropertyChange(String propertyName, Object oldValue, Object newValue) Notifies registeredPropertyChangeListeners 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 CompoundHighlighterReturns the CompoundHighlighter assigned to the table, null if none.protected ChangeListenerReturns theChangeListenerto use with highlighters.Returns theHighlighters used by this table.Returns the prototypeValue property.booleanReturns 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.booleanReturns the per-column editable property.booleanReturns the hideable property.booleanReturns the sortable property.booleanReturns a boolean indicating whether or not this column is visible.voidputClientProperty(Object key, Object value) Sets the client property "key" tovalue.voidremoveHighlighter(Highlighter highlighter) Removes the given Highlighter.voidsetComparator(Comparator<?> comparator) Sets the comparator to use for this column.voidsetEditable(boolean editable) Sets the editable property.voidsetHideable(boolean hideable) Sets the hideable property.voidsetHighlighters(Highlighter... highlighters) Sets theHighlighters to the table, replacing any old settings.voidsetPrototypeValue(Object value) Sets the prototypeValue property.voidsetSortable(boolean sortable) Sets the sortable property.voidSets the title of this view column.voidsetToolTipText(String toolTipText) Registers the text to display in the column's tool tip.voidsetVisible(boolean visible) Sets the visible property.voidupdateUI()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 theHighlighters 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 theHighlighters 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 aHighlighterto the end of the list of usedHighlighters. The argument must not be null.- Parameters:
highlighter- theHighlighterto add, must not be null.- Throws:
NullPointerException- ifHighlighteris 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 theChangeListenerto 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:
getResizablein 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.JXTablesorting 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:
Comparatorto use for this column- See Also:
-
setSortable
public void setSortable(boolean sortable) Sets the sortable property.JXTablesorting 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 byJXTableHeaderto 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. Ifvalueisnullthis method will remove the property. Changes to client properties are reported withPropertyChangeevents. The name of the property (for the sake of PropertyChange events) iskey.toString().The
get/putClientPropertymethods 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 withputClientPropertywill return a non-nullvalue.- 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 thisTableColumnExtto the target column.- Parameters:
original- the target column.
-
firePropertyChange
Notifies registeredPropertyChangeListeners 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
propertyChangeSupportand methodfireXXare 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:
updateUIin interfaceUIDependent
-