ラジオボタンの前景色/背景色の設定と背景の透明/非透明の切り替え

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

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

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

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

public void setForeground(Color fg)

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

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

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

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

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

JRadioButton radio = new JRadioButton("Apple");
radio.setForeground(Color.RED);

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

public void setBackground(Color bg)

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

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

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

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

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

JRadioButton radio = new JRadioButton("Apple");
radio.setBackground(Color.GREEN);

ラジオボタンの背景はデフォルトで非透明に設定されていますので、背景色を設定すれば反映されます。

サンプルプログラム

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

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

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

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

    JRadioButton radio1 = new JRadioButton("Apple");

    JRadioButton radio2 = new JRadioButton("Orange", true);
    radio2.setForeground(Color.GREEN);

    JRadioButton radio3 = new JRadioButton("Peach");
    radio3.setForeground(Color.RED);
    radio3.setBackground(Color.BLACK);

    ButtonGroup bgroup = new ButtonGroup();
    bgroup.add(radio1);
    bgroup.add(radio2);
    bgroup.add(radio3);

    JPanel p = new JPanel();
    p.add(radio1);
    p.add(radio2);
    p.add(radio3);

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

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

javac JSample5_1.java

前景色と背景色を設定する(1)

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

java JSample5_1

ラジオボタンを 3 つ追加しました。 2 つ目のラジオボタンには前景色を設定し、 3 つ目のラジオボタンは前景色と背景色を設定しています。

前景色と背景色を設定する(2)

設定した前景色と背景色がラジオボタンに反映されていることが確認できます。

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

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

public void setOpaque(boolean isOpaque)

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

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

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

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

JRadioButton radio = new JRadioButton("Apple");
radio.setOpaque(false);

サンプルプログラム

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

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

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

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

    JRadioButton radio1 = new JRadioButton("Apple");

    JRadioButton radio2 = new JRadioButton("Orange", true);
    radio2.setOpaque(false);

    JRadioButton radio3 = new JRadioButton("Peach");
    radio3.setOpaque(false);
    radio3.setForeground(Color.RED);
    radio3.setBackground(Color.BLACK);

    ButtonGroup bgroup = new ButtonGroup();
    bgroup.add(radio1);
    bgroup.add(radio2);
    bgroup.add(radio3);

    JPanel p = new JPanel();
    p.setBackground(Color.PINK);

    p.add(radio1);
    p.add(radio2);
    p.add(radio3);

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

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

javac JSample5_2.java

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

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

java JSample5_2

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

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

-- --

ラジオボタンの前景色/背景色の設定方法、および背景の透明/非透明の切り替え方法について解説しました。

( Written by Tatsuo Ikura )

Profile
profile_img

著者 / TATSUO IKURA

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