Swing/DisabledHeader の変更点
- 追加された行はこの色です。
- 削除された行はこの色です。
- Swing/DisabledHeader へ行く。
- Swing/DisabledHeader の差分を削除
--- category: swing folder: DisabledHeader title: JTableHeaderのカラムを選択不可にする tags: [JTable, JTableHeader, TableSorter] author: aterai pubdate: 2005-07-11T09:12:06+09:00 description: JTableHeaderのカラムを選択不可にして、ソートなどを禁止します。 image: https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTK7ZrULPI/AAAAAAAAAWw/fwuY_EwXQsM/s800/DisabledHeader.png --- * 概要 [#summary] `JTableHeader`のカラムを選択不可にして、ソートなどを禁止します。 #download(https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTK7ZrULPI/AAAAAAAAAWw/fwuY_EwXQsM/s800/DisabledHeader.png) * サンプルコード [#sourcecode] #code(link){{ public class SortButtonRenderer extends JButton implements TableCellRenderer { @Override public Component getTableCellRendererComponent( JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) { JButton button = this; if (!isEnabledAt(column)) { button.setText((value == null) ? "" : value.toString()); button.getModel().setEnabled(false); return button; } // ... } } private final HashMap dmap = new HashMap(); public boolean isEnabledAt(int col) { Integer oi = Integer.valueOf(col); if (dmap.containsKey(oi)) { Boolean b = (Boolean) dmap.get(oi); return b.booleanValue(); } else { return true; } } }} * 解説 [#explanation] サンプルでは、`0`列目のカラムヘッダを常に選択不可に、`3`列目はチェックボックスで選択できるかどうかを切り替えるようにしています。 - `0`列目のカラムヘッダを常に選択不可に設定 - `3`列目はチェックボックスで選択できるかどうかを切り替え可能に設定 - `HashMap`に選択不可にするカラムヘッダを設定してレンダラーがヘッダを描画するときにそれを`setEnabled(false)`に変更 - `TableSorter.java`を使用してソートしている場合は、`TableSorter`のインナークラスの`MouseHandler`を例えば以下のように変更すると任意のカラムがクリックしてもソート不可になる #code{{ private class MouseHandler extends MouseAdapter { @Override public void mouseClicked(MouseEvent e) { JTableHeader h = (JTableHeader) e.getSource(); TableColumnModel columnModel = h.getColumnModel(); int viewColumn = columnModel.getColumnIndexAtX(e.getX()); int column = columnModel.getColumn(viewColumn).getModelIndex(); // ここを変更 if (isSortableIndex(column)) { // column != -1 ) { int status = getSortingStatus(column); if (!e.isControlDown()) { cancelSorting(); } status = status + (e.isShiftDown() ? -1 : 1); status = (status + 4) % 3 - 1; // signed mod, returning {-1, 0, 1} setSortingStatus(column, status); } } } }} ---- - `JDK 1.6.0`で導入された`TableRowSorter`を使用する場合、`DefaultRowSorter#setSortable(int, boolean)`でソート不可にするカラムを指定可能 -- ソート不可の列の表示は以下のようなレンダラーで切り替え可能(参考: [[TableRowSorterでJTableのソート>Swing/TableRowSorter]]) #code{{ final JTableHeader hd = table.getTableHeader(); final TableCellRenderer headerRenderer = hd.getDefaultRenderer(); hd.setDefaultRenderer(new TableCellRenderer() { @Override public Component getTableCellRendererComponent(JTable tbl, Object val, boolean isS, boolean hasF, int row, int col) { JLabel lbl = (JLabel) headerRenderer.getTableCellRendererComponent( tbl, val, isS, hasF, row, col); int modelColumnIndex = tbl.convertColumnIndexToModel(col); lbl.setForeground(sorter.isSortable(modelColumnIndex) ? Color.BLACK : Color.GRAY); return lbl; } }); }} * 参考リンク [#reference] - [https://docs.oracle.com/javase/jp/8/docs/api/javax/swing/DefaultRowSorter.html#setSortable-int-boolean- DefaultRowSorter#setSortable(...) (Java Platform SE 8)] * コメント [#comment] #comment #comment