ラベル内での画像の位置

広告

ラベルに画像を表示した場合に、ラベル内で画像のどの位置に表示するのかを設定する方法を確認します。

設定するのに使用するメソッドは文字列の表示位置を指定した場合と同じくsetHorizontalAlignmentメソッドとsetVerticalAlignmentメソッドを使います。詳しくは「ラベル内での文字列の位置」を参照して下さい。

ここでは実際の使い方だけを確認しておきます。

ImageIcon icon = new ImageIcon("./img/sample.png");
JLabel label = new JLabel(icon);

label.setHorizontalAlignment(JLabel.LEFT);
label.setVerticalAlignment(JLabel.TOP);

注意して頂きたい点は、水平方向の位置のデフォルトが文字列の場合は左詰(JLabel.LEADING)なのに対してラベルに画像を表示する場合は中央(JLabel.CENTER)という点です。

垂直方向の位置は文字列の場合でも画像の場合でも中央(JLabel.CENTER)で同じです。

サンプルプログラム

では実際に試してみます。

SSample7_1.java

import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JLabel;
import javax.swing.ImageIcon;
import javax.swing.border.LineBorder;
import java.awt.Color;
import java.awt.Container;
import java.awt.BorderLayout;
import java.awt.Dimension;

class SSample7_1 extends JFrame{
  public static void main(String args[]){
    SSample7_1 frame = new SSample7_1("タイトル");
    frame.setVisible(true);
  }

  SSample7_1(String title){
    setTitle(title);
    setBounds(100, 100, 300, 250);
    setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

    JPanel p = new JPanel();

    ImageIcon icon1 = new ImageIcon("./board.png");
    ImageIcon icon2 = new ImageIcon("./hasami.png");
    ImageIcon icon3 = new ImageIcon("./bag.png");

    JLabel label1 = new JLabel(icon1);
    label1.setPreferredSize(new Dimension(100,100));
    label1.setHorizontalAlignment(JLabel.LEFT);
    label1.setVerticalAlignment(JLabel.TOP);
    label1.setBorder(new LineBorder(Color.blue, 2, true));

    JLabel label2 = new JLabel();
    label2.setIcon(icon2);
    label2.setPreferredSize(new Dimension(100,100));
    label2.setHorizontalAlignment(JLabel.RIGHT);
    label2.setVerticalAlignment(JLabel.BOTTOM);
    label2.setBorder(new LineBorder(Color.blue, 2, true));

    JLabel label3 = new JLabel(icon3);
    label3.setPreferredSize(new Dimension(100,100));
    label3.setBorder(new LineBorder(Color.blue, 2, true));

    p.add(label1);
    p.add(label2);
    p.add(label3);

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

ではコンパイルを行った上で実行してみます。

ラベル内での画像の位置

3つのラベルを表示しています。1つ目は左上に画像を表示、2つ目は右下に画像を表示するように設定しています。3つ目は位置を指定しなかった場合のデフォルトの表示位置です。

( Written by Tatsuo Ikura )