Summary

JTableのセルに表示されている文字列の揃えを変更します。

Source Code Examples

TableColumn col = table.getColumnModel().getColumn(1);
col.setCellRenderer(new HorizontalAlignmentTableRenderer());
// ...
class HorizontalAlignmentTableRenderer extends DefaultTableCellRenderer {
  @Override public Component getTableCellRendererComponent(JTable table,
        Object value, boolean isSelected, boolean hasFocus, int row, int column) {
    Component c = super.getTableCellRendererComponent(
        table, value, isSelected, hasFocus, row, column);
    if (c instanceof JLabel) {
      initLabel((JLabel) c, row);
    }
    return c;
  }

  private void initLabel(JLabel l, int row) {
    if (leftRadio.isSelected()) {
      l.setHorizontalAlignment(SwingConstants.LEFT);
    } else if (centerRadio.isSelected()) {
      l.setHorizontalAlignment(SwingConstants.CENTER);
    } else if (rightRadio.isSelected()) {
      l.setHorizontalAlignment(SwingConstants.RIGHT);
    } else if (customRadio.isSelected()) {
      l.setHorizontalAlignment(row % 3 == 0 ? SwingConstants.LEFT:
                               row % 3 == 1 ? SwingConstants.CENTER:
                                              SwingConstants.RIGHT);
    }
  }
}
View in GitHub: Java, Kotlin

Explanation

上記のサンプルでは、JTableの第1列目のセルに表示されている文字列の揃えを変更するテストを行っています。

  • left: 左揃え
  • center: 中央揃え
  • right: 右揃え
  • custom: 行ごとに左、中央、右揃えを変更

  • JTableは、ObjectNumberBooleanクラスのデフォルトセルレンダラーを持っているため、モデルが各列のクラスを正しく返すようにTableModel#getColumnClass(int)をオーバーライドすることでそのクラスのデフォルトセルレンダラーが使用される
    • Object: SwingConstants.LEFT(文字列などは左揃え)
    • Number: SwingConstants.RIGHT(数字は右揃え)
    • Boolean: JCheckBox, CENTER(チェックボックスは中央揃え)
  • DefaultTableModel#TableModel#getColumnClass(int)のデフォルトは、すべての列のクラスとしてObject.classを返す
  • 各クラスのデフォルトセルレンダラーが使用されるのは、列にセルレンダラーが割り当てられていない場合に限られる
    // JTableの手抜きサンプルなら、以下のようにオーバーライドするのが簡単?(モデルが空になる場合、例外が発生する可能性がある)
    String[] columnNames = {"String", "Integer", "Boolean"};
    Object[][] data = {
      {"AAA", 1, true},
      {"BBB", 2, false},
    };
    DefaultTableModel model = new DefaultTableModel(data, columnNames) {
      @Override public Class<?> getColumnClass(int column) {
        return getValueAt(0, column).getClass();
      }
    };
    JTable table = new JTable(model);
    
  • クラスのデフォルトセルレンダラーではなく、任意の列にセルレンダラーを割り当てて文字揃えを変更する方法もある
    DefaultTableCellRenderer r = new DefaultTableCellRenderer();
    r.setHorizontalAlignment(SwingConstants.CENTER);
    table.getColumnModel().getColumn(2).setCellRenderer(r);
    

Reference

Comment