チェックボックスの前景色/背景色の設定と背景の透明/非透明の切り替え

チェックボックスに表示される文字列の文字の色である前景色とチェックボックスの背景色をそれぞれ個別に設定することができます。またチェックボックスの背景は透明と非透明を切り替えることができます。ここではチェックボックスの前景色/背景色の設定方法、および背景の透明/非透明の切り替え方法について解説します。

(2022 年 04 月 11 日公開 / 2022 年 04 月 11 日更新)

前景色と背景色を設定する

チェックボックスに表示される文字列の文字の色である前景色を設定するには JCheckBox クラスの親クラスである JComponent クラスで用意されている setForeground メソッドを使います。

public void setForeground(Color fg)

このコンポーネントのフォアグラウンド・カラーを設定します。 このプロパティが受け付けられるかどうかはルック・アンド・フィールしだいであり、無視されることもあります。

オーバーライド:
setForeground 、クラス: Component

パラメータ:
fg - 要求するフォアグラウンドColor

引数には色を表す Color クラスのオブジェクトを指定して下さい。( Color クラスの使い方は「Colorクラス」を参照して下さい)。

実際の使い方は次のようになります。

JCheckBox check = new JCheckBox("Travel");
check.setForeground(Color.RED);

チェックボックスの背景色を設定するには JCheckBox クラスの親クラスである JComponent クラスで用意されている setBackground メソッドを使います。

public void setBackground(Color bg)

このコンポーネントのバックグラウンド・カラーを設定します。 バックグラウンド・カラーは、コンポーネントが不透明である場合にのみ、JComponentまたはComponentUIの実装のサブクラスによってのみ使用されます。 JComponentの直接のサブクラスは、このプロパティを受け付けるためにpaintComponentをオーバーライドする必要があります。
このプロパティが受け付けられるかどうかはルック・アンド・フィールしだいであり、無視されることもあります。

オーバーライド:
setBackground 、クラス: Component

パラメータ:
bg - 要求するバックグラウンドColor

引数には前景色と同じく色を表す Color クラスのオブジェクトを指定して下さい。

実際の使い方は次のようになります。

JCheckBox check = new JCheckBox("Travel");
check.setBackground(Color.GREEN);

チェックボックスの背景はデフォルトで非透明に設定されていますので、背景色を設定すれば反映されます。

サンプルプログラム

それでは簡単なサンプルプログラムを作って試してみます。テキストエディタで次のように記述したあと、 JSample3_1.java という名前で保存します。

import javax.swing.JFrame;
import javax.swing.JCheckBox;
import javax.swing.JPanel;
import java.awt.Container;
import java.awt.BorderLayout;
import java.awt.Color;

class JSample3_1 extends JFrame{
  public static void main(String args[]){
    JSample3_1 frame = new JSample3_1("MyTitle");
    frame.setVisible(true);
  }

  JSample3_1(String title){
    setTitle(title);
    setBounds(100, 100, 600, 400);
    setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    JCheckBox check1 = new JCheckBox("Travel");

    JCheckBox check2 = new JCheckBox("Movie");
    check2.setForeground(Color.GREEN);

    JCheckBox check3 = new JCheckBox("Sports");
    check3.setForeground(Color.RED);
    check3.setBackground(Color.BLACK);

    JPanel p = new JPanel();
    p.add(check1);
    p.add(check2);
    p.add(check3);

    Container contentPane = getContentPane();
    contentPane.add(p, BorderLayout.CENTER);
  }
}

次のようにコンパイルを行います。

javac JSample3_1.java

選択か非選択か設定する(1)

コンパイルが終わりましたら実行します。

java JSample3_1

チェックボックスを 3 つ追加しました。 2 つ目のチェックボックスには前景色を設定し、 3 つ目のチェックボックスは前景色と背景色を設定しています。

選択か非選択か設定する(2)

設定した前景色と背景色がチェックボックスに反映されていることが確認できます。

背景の透明と非透明を切り替える

チェックボックスはデフォルトの設定で背景が非透明に設定されていますが透明に設定することも可能です。チェックボックスの透明/非透明の切り替えを行うには JCheckBox クラスの親クラスである JComponent クラスで用意されている setOpaque メソッドを使います。

public void setOpaque(boolean isOpaque)

trueの場合、コンポーネントはその境界内のすべてのピクセルをペイントします。 そうでない場合、コンポーネントはピクセルの一部または全部をペイントしないので、その下のピクセルが透けて表示されます。
JComponentに対するこのプロパティのデフォルト値は、falseです。 ただし、もっとも標準的なJComponentのサブクラス(JButtonおよびJTreeなど)に対するこのプロパティのデフォルト値は、ルック・アンド・フィールに依存します。

パラメータ:
isOpaque - このコンポーネントが不透明な場合はtrue

引数には透明にするかどうかを表すboolean型の値を指定して下さい。trueを設定すると非透明になり、falseを設定すると透明になります。

実際の使い方は次のようになります。

JCheckBox check = new JCheckBox("Travel");
check.setOpaque(false);

サンプルプログラム

それでは簡単なサンプルプログラムを作って試してみます。テキストエディタで次のように記述したあと、 JSample3_2.java という名前で保存します。

import javax.swing.JFrame;
import javax.swing.JCheckBox;
import javax.swing.JPanel;
import java.awt.Container;
import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Font;

class JSample3_2 extends JFrame{
  public static void main(String args[]){
    JSample3_2 frame = new JSample3_2("MyTitle");
    frame.setVisible(true);
  }

  JSample3_2(String title){
    setTitle(title);
    setBounds(100, 100, 600, 400);
    setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    JCheckBox check1 = new JCheckBox("Travel");

    JCheckBox check2 = new JCheckBox("Movie");
    check2.setOpaque(false);

    JCheckBox check3 = new JCheckBox("Sports");
    check3.setOpaque(false);
    check3.setForeground(Color.RED);
    check3.setBackground(Color.BLACK);

    JPanel p = new JPanel();
    p.setBackground(Color.PINK);
    p.add(check1);
    p.add(check2);
    p.add(check3);

    Container contentPane = getContentPane();
    contentPane.add(p, BorderLayout.CENTER);
  }
}

次のようにコンパイルを行います。

javac JSample3_2.java

背景の透明と非透明を切り替える(1)

コンパイルが終わりましたら実行します。

java JSample3_2

透明かどうかが分かりやすいようにパネルの背景を桃色に設定したあとでチェックボックスを 3 つ追加しました。 1 つ目のチェックボックスはデフォルトのままで背景が非透明、 2 つ目のチェックボックスには背景を透明に設定しました。 3 つ目のチェックボックスは前景色と背景色を設定していますが背景を透明に設定しているので背景色は反映されていません。

背景の透明と非透明を切り替える(1)

-- --

チェックボックスの前景色/背景色の設定方法、および背景の透明/非透明の切り替え方法について解説しました。

( Written by Tatsuo Ikura )

Profile
profile_img

著者 / TATSUO IKURA

プログラミングや開発環境構築の解説サイトを運営しています。