Swing/CellHighlight の変更点
- 追加された行はこの色です。
- 削除された行はこの色です。
- Swing/CellHighlight へ行く。
- Swing/CellHighlight の差分を削除
--- category: swing folder: CellHighlight title: JTableのセルのハイライト tags: [JTable, TableCellRenderer, MouseListener, MouseMotionListener] author: aterai pubdate: 2005-03-21T07:27:38+09:00 description: JTableのセル上にマウスカーソルが存在する場合、その背景色を変更します。 image: https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTIqY941CI/AAAAAAAAATI/gk-sbbRE5gw/s800/CellHighlight.png --- * 概要 [#summary] `JTable`のセル上にマウスカーソルが存在する場合、その背景色を変更します。 #download(https://lh6.googleusercontent.com/_9Z4BYR88imo/TQTIqY941CI/AAAAAAAAATI/gk-sbbRE5gw/s800/CellHighlight.png) * サンプルコード [#sourcecode] #code(link){{ class HighlightListener extends MouseAdapter { private int row = -1; private int col = -1; private final JTable table; public HighlightListener(JTable table) { this.table = table; } public boolean isHighlightableCell(int row, int column) { return this.row == row && this.col == column; } @Override public void mouseMoved(MouseEvent e) { Point pt = e.getPoint(); row = table.rowAtPoint(pt); col = table.columnAtPoint(pt); if (row < 0 || col < 0) { row = -1; col = -1; } table.repaint(); } @Override public void mouseExited(MouseEvent e) { row = -1; col = -1; table.repaint(); } } class HighlightRenderer extends DefaultTableCellRenderer { private final HighlightListener highlighter; public HighlightRenderer(JTable table) { super(); highlighter = new HighlightListener(table); table.addMouseListener(highlighter); table.addMouseMotionListener(highlighter); } @Override public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) { super.getTableCellRendererComponent( table, value, isSelected, hasFocus, row, column); setHorizontalAlignment((value instanceof Number) ? RIGHT : LEFT); if (highlighter.isHighlightableCell(row, column)) { setBackground(Color.RED); } else { setBackground(isSelected ? table.getSelectionBackground() : table.getBackground()); } return this; } } }} * 解説 [#explanation] 上記のサンプルでは、`JTable`に`MouseListener`、`MouseMotionListener`を追加してマウスカーソルが乗っているセルを取得し、セルレンダラーでこれを参照してその背景色を変更しています。 ---- `JTable#prepareRenderer(...)`メソッドをオーバーライドする方法もあります。 - `JTable#prepareRenderer(...)`メソッドをオーバーライドする方法もある #code{{ class HighlightableTable extends JTable { private final HighlightListener highlighter; public HighlightableTable(TableModel model) { super(model); highlighter = new HighlightListener(this); addMouseListener(highlighter); addMouseMotionListener(highlighter); } @Override public Component prepareRenderer( TableCellRenderer r, int row, int column) { Component c = super.prepareRenderer(r, row, column); if (highlighter.isHighlightableCell(row, column)) { c.setBackground(Color.RED); } else if (isRowSelected(row)) { c.setBackground(getSelectionBackground()); } else { c.setBackground(Color.WHITE); } return c; } } }} * 参考リンク [#reference] - [[JListのセルをカーソル移動でロールオーバー>Swing/RollOverListener]] * コメント [#comment] #comment - ソースコードの整理、スクリーンショットの更新 -- &user(aterai); &new{2008-03-14 (金) 16:38:10}; #comment