Swing/StripeTable のバックアップ(No.11)
- バックアップ一覧
- 差分 を表示
- 現在との差分 を表示
- 現在との差分 - Visual を表示
- ソース を表示
- Swing/StripeTable へ行く。
- 1 (2007-03-09 (金) 01:30:20)
- 2 (2007-03-09 (金) 17:57:48)
- 3 (2007-04-04 (水) 19:41:02)
- 4 (2007-05-18 (金) 15:10:06)
- 5 (2007-12-10 (月) 17:25:47)
- 6 (2007-12-21 (金) 18:39:10)
- 7 (2008-01-27 (日) 14:27:53)
- 8 (2008-04-17 (木) 15:42:48)
- 9 (2008-06-26 (木) 13:33:01)
- 10 (2008-09-03 (水) 15:35:26)
- 11 (2009-03-26 (木) 19:45:45)
- 12 (2009-03-27 (金) 13:07:32)
- 13 (2009-09-29 (火) 16:39:02)
- 14 (2010-04-16 (金) 19:32:00)
- 15 (2011-02-01 (火) 15:36:32)
- 16 (2011-02-07 (月) 19:39:18)
- 17 (2011-03-17 (木) 22:26:29)
- 18 (2013-04-02 (火) 19:16:41)
- 19 (2013-10-03 (木) 14:28:21)
- 20 (2013-10-22 (火) 15:08:58)
- 21 (2014-12-18 (木) 17:14:56)
- 22 (2015-03-19 (木) 16:40:57)
- 23 (2016-01-03 (日) 17:28:36)
- 24 (2016-05-26 (木) 15:30:46)
- 25 (2016-06-04 (土) 19:22:43)
- 26 (2017-03-29 (水) 19:50:51)
- 27 (2017-04-04 (火) 14:17:08)
- 28 (2017-11-02 (木) 15:27:06)
- 29 (2018-08-30 (木) 14:57:05)
- 30 (2020-08-22 (土) 18:33:39)
- 31 (2022-02-01 (火) 22:40:22)
- 32 (2024-10-21 (月) 00:28:46)
TITLE:TableCellRendererでセルの背景色を変更
TableCellRendererでセルの背景色を変更
TableCellRendererを継承するレンダラーを作ってテーブルのセルを修飾します。
- &jnlp;
- &jar;
- &zip;
#screenshot
サンプルコード
class StripeTableRenderer extends DefaultTableCellRenderer {
private static final Color evenColor = new Color(240, 240, 255);
public Component getTableCellRendererComponent(JTable table, Object value,
boolean isSelected, boolean hasFocus,
int row, int column) {
super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
if(isSelected) {
setForeground(table.getSelectionForeground());
setBackground(table.getSelectionBackground());
}else{
setForeground(table.getForeground());
setBackground((row%2==0)?evenColor:table.getBackground());
}
setHorizontalAlignment((value instanceof Number)?RIGHT:LEFT);
return this;
}
}
解説
上記のサンプルでは、以下のようなセルレンダラーを作成し、Objectを継承するクラスのデフォルトレンダラーとして設定しています。
- 奇数偶数で行の背景色を変更してテーブルをストライプ模様にする
- 第0列のカラムのセルを右寄せ
- ここでは、TableColumn#setCellRenderer(TableCellRenderer)*1を使わず、Object.classのDefaultRendererひとつにまとめているため、TableModel#getColumnClass(0)がInteger.classを返すようにしている
table.setDefaultRenderer(Object.class, new StripeTableRenderer());
あるセルが描画されるとき、設定されたTableCellRendererのgetTableCellRendererComponentメソッドが呼び出されます。レンダラーは、引数などから得られる情報(選択されているか、何行何列目かなど)を使って、コンポーネントを修飾してからreturnします。
サンプルのTestRendererでは、JLabelを継承するDefaultTableCellRendererを継承しているので、自分自身(this)をsetForeground、setHorizontalAlignmentなどのメソッドで修飾し直し、さらに自分自身(this)を戻り値としています。このようにコンポーネントを使い回しているため、セルの数が膨大になっても、オブジェクトを大量に生成しなくて済むようになっています。
また、返されたコンポーネントは、セルの描画のみに利用されて、コンポーネントとしては機能しません。
セルレンダラーで色を変更する代わりに、以下のようにJTable#prepareRendererメソッドをオーバーライドする方法もあります。使用するセルレンダラーに関係なく、テーブル全体で前処理することができます。このため、Numberクラス用のDefaultTableCellRendererがそのまま使われるので、TableModel#getColumnClass(int)が、Number.classを返すようにしておけば、勝手に右寄せしてくれます。
JTable table = new JTable(model) {
private final Color evenColor = new Color(240, 240, 255);
public Component prepareRenderer(TableCellRenderer tcr, int row, int column) {
Component c = super.prepareRenderer(tcr, row, column);
if(isRowSelected(row)) {
c.setForeground(getSelectionForeground());
c.setBackground(getSelectionBackground());
}else{
c.setForeground(getForeground());
c.setBackground((row%2==0)?evenColor:getBackground());
}
return c;
}
};
参考リンク
- Sorting and Otherwise Manipulating Data - How to Use Tables (The Java™ Tutorials > Creating a GUI with JFC/Swing > Using Swing Components)
- SwingのJTableコンポーネントでセルを描く
コメント
- JTable#prepareRendererメソッドを使用する場合のサンプルを修正。 -- terai
- メモ:JTable でセルのないところに行っぽい表示を出せますか? - KrdLabの不定期日記。これおもしろいです。 -- terai
- ↑ありがとうございます.terai様のサイトは情報が充実していてすばらしいです.参考にさせていただきます. -- KrdLab?