Well, back to the basics of Java...
Just in case anybody (that's including me ;-)) gets this problem (again) here is the solution.
Basic scenario: building a JTable with a non default model class extending
AbstractTableModel as follows. I have omitted necessary includes and actually removed method bodies for simplification purposes.
Spot the error...
public class SyncOperationTableModel extends AbstractTableModel
{
// attributes
public SyncOperationTableModel(ArrayList syncOperations)
{
super();
// initialize attributes
}
public int getRowCount()
{
// return the row count based on attributes (for instance)
}
public int getColumnCount()
{
// return column count base on attributes (for instance)
}
public String getColumName(int column)
{
// return column name
}
public Object getValueAt(int row, int column)
{
// return the value,
// by default setValueAt is not necessary
// (AbstractTableModel returns false to isCellEditable method)
}
}
Symptom? The column names (
getColumName(int column)) never get returned and are replaced with default names: A, B, C... At first sight this is strange, since I purposefully add the table to a JScrollPane (which should handle the table header automatically).
Solution? In the above code the
getColumnName(int column) does not get called simply because I have created a new method named getColumName (i.e. with a missing 'n' to the 'column' part of the name). Stu-pid!
New method:
@Override
public String getColumnName(int column)
{
// code
}
Reaaaaally hopeless... no wonder this was impossible to find despite GIYF. Now getting on to cell rendering - it's been a while... other silly mistakes ahead I am sure.
More news soon.
Thoughts in the meantime?