• category: swing folder: TableColumnHeaderIcon title: JTableのカラムヘッダにIconを表示する tags: [JTable, JTableHeader, TableColumn, Icon] author: aterai pubdate: 2016-01-25T01:26:15+09:00 description: JTableの各カラムヘッダにアイコンとタイトル文字列を表示するよう設定します。 image: https://lh3.googleusercontent.com/-yQYpkrDnAcQ/VqT3Oq7tovI/AAAAAAAAOL8/YbbgnXgZ9B4/s800-Ic42/TableColumnHeaderIcon.png

概要

JTableの各カラムヘッダにアイコンとタイトル文字列を表示するよう設定します。

サンプルコード

URL[] icons = {
    getIconURL("wi0062-16.png"),
    getIconURL("wi0063-16.png"),
    getIconURL("wi0064-16.png")
};
String[] columnNames = {"Column1", "Column2", "Column3"};
JTable table = new JTable(new DefaultTableModel(columnNames, 8));
TableColumnModel m = table.getColumnModel();
for (int i = 0; i < m.getColumnCount(); i++) {
  // m.getColumn(i).setHeaderRenderer(new IconColumnHeaderRenderer());
  m.getColumn(i).setHeaderValue( // cellspacing='0'
    String.format("<html><table cellpadding='0'><td><img src='%s'/></td>%s",
                  icons[i], columnNames[i]));
}
table.setAutoCreateRowSorter(true);
View in GitHub: Java, Kotlin

解説

上記のサンプルでは、カラムヘッダにアイコンを表示するために、タイトル文字列として<img>タグでアイコンを表示するhtml文字列を設定しています。

  • html文字列としてString.format("<html><img src='%s'/> %s", url, str)を使用するとアイコンと文字列のベースラインが揃わない場合があるので<table>タグを使用
  • <table>タグを使用する場合、JTableHeaderの高さが拡大するのでcellpadding='0' cellspacing='0'などでセル余白を0に変更
  • デフォルトのヘッダレンダラーはJLabelを継承しているのでsetIcon(...)メソッドが使用可能だが、LookAndFeelによってはソートアイコンと競合する場合がある
    class IconColumnHeaderRenderer implements TableCellRenderer {
      private final Icon icon = new ImageIcon(getClass().getResource("wi0063-16.png"));
      @Override public Component getTableCellRendererComponent(
          JTable table, Object value, boolean isSelected, boolean hasFocus,
          int row, int column)
        TableCellRenderer r = table.getTableHeader().getDefaultRenderer();
        JLabel l = (JLabel) r.getTableCellRendererComponent(
            table, value, isSelected, hasFocus, row, column);
        l.setHorizontalTextPosition(SwingConstants.RIGHT);
        l.setIcon(icon);
        return l;
      }
    }
    

参考リンク

コメント