Class DateTableEditor
- java.lang.Object
-
- javax.swing.AbstractCellEditor
-
- com.github.lgooddatepicker.tableeditors.DateTableEditor
-
- All Implemented Interfaces:
java.io.Serializable
,javax.swing.CellEditor
,javax.swing.table.TableCellEditor
,javax.swing.table.TableCellRenderer
public class DateTableEditor extends javax.swing.AbstractCellEditor implements javax.swing.table.TableCellEditor, javax.swing.table.TableCellRenderer
DateTableEditor, This class is used to add a DatePicker to cells (or entire columns) of a Swing JTable or a SwingX JXTable component. This class can be used as a table cell "Editor", or as a "Renderer", or as both editor and renderer. Separate class instances should be used for the editor and the renderer.// Usage example: // Create a table. JTable table = new JTable(); //Set up a renderer and editor for the LocalDate type. table.setDefaultRenderer(LocalDate.class, new DateTableEditor()); table.setDefaultEditor(LocalDate.class, new DateTableEditor());
The DatePicker and DatePickerSettings: The date picker and a picker settings can be accessed with the supplied getter functions. Note that most of the settings for the date picker are left at their default values, but a few (mostly cosmetic) settings are changed in the DateTableEditor constructor. See the DateTableEditor constructor implementation to learn which default settings were changed. Auto adjust row height: By default, this class will automatically adjust the minimum height of all table rows. This occurs during the first time that any cell with an editor or render is displayed. The row height is only adjusted if the current table row height value is below the minimum value that is needed to display the date picker component. This auto adjust behavior can be turned off from the DateTableEditor constructor.- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description int
clickCountToEdit
clickCountToEdit, An integer specifying the number of clicks needed to start editing.
-
Constructor Summary
Constructors Constructor Description DateTableEditor()
Constructor, default.DateTableEditor(boolean autoAdjustMinimumTableRowHeight, boolean matchTableBackgroundColor, boolean matchTableSelectionBackgroundColor)
Constructor, with options.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.Object
getCellEditorValue()
getCellEditorValue, This returns the value contained in the editor.DatePicker
getDatePicker()
getDatePicker, Returns the DatePicker which is used by this class.DatePickerSettings
getDatePickerSettings()
getDatePicker, Returns the DatePickerSettings for the DatePicker being used by this class.java.awt.Component
getTableCellEditorComponent(javax.swing.JTable table, java.lang.Object value, boolean isSelected, int row, int column)
getTableCellEditorComponent, this returns the editor that is used for editing the cell.java.awt.Component
getTableCellRendererComponent(javax.swing.JTable table, java.lang.Object value, boolean isSelected, boolean hasFocus, int row, int column)
getTableCellRendererComponent, Returns the renderer that is used for drawing the cell.boolean
isCellEditable(java.util.EventObject anEvent)
isCellEditable, Returns true if anEvent is not a MouseEvent.void
setCellEditorValue(java.lang.Object value)
setCellEditorValue, This sets the picker to an appropriate value for the supplied object.-
Methods inherited from class javax.swing.AbstractCellEditor
addCellEditorListener, cancelCellEditing, fireEditingCanceled, fireEditingStopped, getCellEditorListeners, removeCellEditorListener, shouldSelectCell, stopCellEditing
-
-
-
-
Constructor Detail
-
DateTableEditor
public DateTableEditor()
Constructor, default.
-
DateTableEditor
public DateTableEditor(boolean autoAdjustMinimumTableRowHeight, boolean matchTableBackgroundColor, boolean matchTableSelectionBackgroundColor)
Constructor, with options.- Parameters:
autoAdjustMinimumTableRowHeight
- Set this to true to have this class automatically adjust the the minimum row height of all rows in the table, the first time that a DateTableEditor is displayed. Set this to false to turn off any row height adjustments. The default value is true.matchTableBackgroundColor
- This indicates whether this table editor should set the picker text area background color to match the background color of the table. The default value is true.matchTableSelectionBackgroundColor
- This indicates whether this table editor should set the picker text area background color to match the background color of the table selection (when selected). The default value is true.
-
-
Method Detail
-
getCellEditorValue
public java.lang.Object getCellEditorValue()
getCellEditorValue, This returns the value contained in the editor. This is required by the CellEditor interface.- Specified by:
getCellEditorValue
in interfacejavax.swing.CellEditor
-
getDatePicker
public DatePicker getDatePicker()
getDatePicker, Returns the DatePicker which is used by this class.
-
getDatePickerSettings
public DatePickerSettings getDatePickerSettings()
getDatePicker, Returns the DatePickerSettings for the DatePicker being used by this class. These settings can be adjusted as desired by the programmer.
-
getTableCellEditorComponent
public java.awt.Component getTableCellEditorComponent(javax.swing.JTable table, java.lang.Object value, boolean isSelected, int row, int column)
getTableCellEditorComponent, this returns the editor that is used for editing the cell. This is required by the TableCellEditor interface. For additional details, see the Javadocs for the function: TableCellEditor.getTableCellEditorComponent().- Specified by:
getTableCellEditorComponent
in interfacejavax.swing.table.TableCellEditor
-
getTableCellRendererComponent
public java.awt.Component getTableCellRendererComponent(javax.swing.JTable table, java.lang.Object value, boolean isSelected, boolean hasFocus, int row, int column)
getTableCellRendererComponent, Returns the renderer that is used for drawing the cell. This is required by the TableCellRenderer interface. For additional details, see the Javadocs for the function: TableCellRenderer.getTableCellRendererComponent().- Specified by:
getTableCellRendererComponent
in interfacejavax.swing.table.TableCellRenderer
-
isCellEditable
public boolean isCellEditable(java.util.EventObject anEvent)
isCellEditable, Returns true if anEvent is not a MouseEvent. Otherwise, it returns true if the necessary number of clicks have occurred, and returns false otherwise.- Specified by:
isCellEditable
in interfacejavax.swing.CellEditor
- Overrides:
isCellEditable
in classjavax.swing.AbstractCellEditor
-
setCellEditorValue
public void setCellEditorValue(java.lang.Object value)
setCellEditorValue, This sets the picker to an appropriate value for the supplied object. If the value is null, then picker will be cleared. If the value is a LocalDate instance, then the picker will be set to that value. All other types (including strings) will be read or converted to a string with a maximum length of the first 100 characters. The picker text will be set with the resulting string.
-
-