If I take a JTable
and specify a column's classtype on it's model as follows:
DefaultTableModel model = new DefaultTableModel(columnNames, 100) {
@Override
public Class<?> getColumnClass(int columnIndex) {
return Integer.class;
}};
Then whenever a user tries to enter a double
value into the table, Swing automatically rejects the input and sets the cell's outline to red.
I want the same effect to occur when someone enters a 'negative or 0' input to the cell. I've got this:
@Override
public void setValueAt(Object val, int rowIndex, int columnIndex) {
if (val instanceof Number && ((Number) val).doubleValue() > 0) {
super.setValueAt(val, rowIndex, columnIndex);
}
}
}
This prevents the cell from accepting any non-positive values, but it doens't set the color to red and leave the cell as editable.
I tried looking into how JTable's doing the rejection by default, but I can't seem to find it.
How can I make it reject the non-positive input the same way it rejects the non-Integer input?
Thanks
The
private static class JTable.GenericEditor
uses introspection to catch exceptions raised by constructing specificNumber
subclasses with invalidString
values. If you don't need such generic behavior, consider creatingPositiveIntegerCellEditor
as a subclass ofDefaultCellEditor
. YourstopCellEditing()
method would be correspondingly simpler.Addendum: Updated to use
RIGHT
alignment and common error code.Addendum: See also Using an Editor to Validate User-Entered Text.
I figured it out. Override the DefaultCellEditor and return
false
/ set the border to red if the number given is not positive.Unfortunately, since JTable.GenericEditor is
static
w/default
scope, I'm unable to override theGenericEditor
to provide this functionality and have to re-implement it w/ a few tweaks, unless someone has a better way of doing this, which I'd like to hear.This code is a small improvement of the accepted answer. If the user does not enter any value, clicking on another cell should allow him to select another cell. The accepted solution does not allow this.
This solution checks for empty text. In case of an empty text, we call the
stopCellEditing()
method.