概要

JTableを追加したJViewportがセルで隠れていない部分の色を変更します。

スクリーンショット

TableBackground.png

サンプルコード

// JScrollPane scroll = new JScrollPane(table);
scroll.getViewport().add(table);
scroll.getViewport().setOpaque(true);
scroll.getViewport().setBackground(Color.WHITE);
// table.getParent().setBackground(Color.WHITE);
view all

解説

このページのタイトルなどで「JTableの背景色」としている部分は、実際はJTableの背景色ではなく、JTableを追加したJViewportがセルで隠れていない領域を表しています。

このため、上記のスクリーンショットのように色をつけたい場合は、JTable自身の背景色を設定するのではなくJViewportの背景色を設定する必要があります。サンプルコードではJScrollPaneからJViewportを取得していますがJTable#getParent()メソッドからもJViewportを取得できます。

上記のサンプルでは、背景色を不透明にするを選択して背景色を設定するとJViewportの背景色が変更されます。

  •  JDK 1.6.0で追加されたJTable#setFillsViewportHeightメソッドを使用してJTableJViewportの高さまで拡張すれば、直接JTableの背景色を設定するだけで同様の状態になる
  • セルの背景色を変更する場合はTableCellRendererを使用する
  • ヘッダの背景色(カラムをマウスでドラッグ中に表示される)を変更する場合は、空のJViewportJScrollPaneのカラムヘッダに追加してその背景色を変更する
scroll.setColumnHeader(new JViewport());
//or scroll.setColumnHeaderView(new JLabel());
scroll.getColumnHeader().setBackground(Color.RED);

参考リンク

コメント