Summary

JTreeのノード条件によって、その選択背景色を変更します。

Source Code Examples

class SelectionColorTreeCellRenderer extends DefaultTreeCellRenderer {
  private Color color = null;

  private void setParticularCondition(Object value) {
    if (value instanceof DefaultMutableTreeNode) {
      Object uo = ((DefaultMutableTreeNode) value).getUserObject();
      if (uo instanceof Color) {
        color = (Color) uo;
        return;
      }
    }
    color = null;
  }

  @Override public Component getTreeCellRendererComponent(
      JTree tree, Object value, boolean isSelected, boolean expanded,
      boolean leaf, int row, boolean hasFocus) {
    JComponent c = (JComponent) super.getTreeCellRendererComponent(
        tree, value, isSelected, expanded, leaf, row, hasFocus);
    if (isSelected) {
      setParticularCondition(value);
      c.setForeground(getTextSelectionColor());
      c.setBackground(getBackgroundSelectionColor());
      if (leaf && value.toString().startsWith("a")) {
        c.setOpaque(true);
        c.setBackground(Color.RED);
      } else {
        c.setOpaque(false);
        c.setBackground(getBackgroundSelectionColor());
      }
    } else {
      c.setForeground(getTextNonSelectionColor());
      c.setBackground(getBackgroundNonSelectionColor());
    }
    return c;
  }

  @Override public Color getBackgroundSelectionColor() {
    return color != null ? color : super.getBackgroundSelectionColor();
  }
}
View in GitHub: Java, Kotlin

Explanation

上記のサンプルでは、以下の条件でノードの選択時背景色を変更しています。

  • DefaultMutableTreeNode#getUserObject()Colorの場合、その色を選択時背景色に採用
    • DefaultTreeCellRenderer#getBackgroundSelectionColor()をオーバーライド
    • ノードアイコンの背景は選択状態に変更せずノードテキストの背景色のみ変更
  • ノードテキストがaで始まる場合、選択背景色をColor.REDに変更
    • TreeCellRenderer#getTreeCellRendererComponent(...)で取得したコンポーネント(JLabel)をsetOpaque(true)で不透明、setBackground(Color.RED)で背景色を変更
    • ノードアイコン、テキストの背景色が共に選択状態になる
    • SynthLookAndFeelで作成されているNimbusLookAndFeelなどでは上記のような選択背景色は適用されない

Reference

Comment