|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
java.lang.Object javax.swing.BoxLayout
public class BoxLayout
複数のコンポーネントを、垂直方向にも水平方向にも配置できるようにする、レイアウトマネージャーです。コンポーネントは折り返されずに配置されるので、たとえば、垂直に並べられたコンポーネントは、フレームのサイズが変更されても垂直に並んだままです。
|
水平および垂直の異なる組み合わせを持つ複数のパネルを入れ子にすると、GridBagLayout と同様の効果を簡単に実現できます。上の図では、水平方向に並べられた 2 つのパネルに、垂直方向に並べられた 3 つのコンポーネントがそれぞれ含まれています。
BoxLayout マネージャーは、レイアウトの種類を指定する軸パラメータで構築されます。以下の 4 つの選択肢があります。
X_AXIS - コンポーネントは左から右へ水平に配置されます。
Y_AXIS - コンポーネントは上から下へ垂直に配置されます。
LINE_AXIS - コンポーネントはコンテナの ComponentOrientation プロパティーに基づき、単語を行に配置するのと同じ方法で配置されます。コンテナの ComponentOrientation が水平方向の場合、コンポーネントは水平方向に配置され、垂直方向の場合は垂直方向に配置されます。水平配置では、コンテナの ComponentOrientation が左から右への配置の場合は、コンポーネントは左から右に配置され、そうでない場合は右から左に配置されます。垂直配置では、コンポーネントは常に上から下に配置されます。
PAGE_AXIS - コンポーネントはコンテナの ComponentOrientation プロパティーに基づき、テキスト行をページに配置するのと同じ方法で配置されます。コンテナの ComponentOrientation が水平方向の場合、コンポーネントは垂直方向に配置され、垂直方向の場合は水平方向に配置されます。水平配置では、コンテナの ComponentOrientation が左から右への配置の場合は、コンポーネントは左から右に配置され、そうでない場合は右から左に配置されます。 垂直配置では、コンポーネントは常に上から下に配置されます。
どちらの方向に配置される場合でも、コンポーネントはコンテナに追加された順序で配置されます。
BoxLayout は、水平レイアウトの場合はその最適な幅、垂直レイアウトの場合は最適な高さに従ってコンポーネントを配置しようとします。水平レイアウトの場合、すべてのコンポーネントが同じ高さではなくても、BoxLayout は各コンポーネントをもっとも高いコンポーネントと同じ高さに揃えようとします。特定のコンポーネントでこれが不可能な場合は、そのコンポーネントの Y 方向の位置合わせ用の値に従って、コンポーネントを縦に整列します。デフォルトでは、コンポーネントの Y 方向の位置合わせ用の値は 0.5 です。 これは、コンポーネントの上下方向の中心の Y 座標が、Y 方向の位置合わせ用の値が 0.5 の別のコンポーネントの上下方向の中心と同じになることを意味します。
同様に、垂直レイアウトの場合も、BoxLayout は列のすべてのコンポーネントの幅を最大幅に揃えるよう試行します。これに失敗した場合は、X 方向の位置合わせ用の値に従って、コンポーネントを水平方向に整列します。PAGE_AXIS
レイアウトでは、コンポーネントの先端位置を基準にして整列されます。X 方向の位置合わせ用の値が 0.0 の場合、基準位置はコンテナの ComponentOrientation
が左から右方向であればコンテナの左端になり、右から左方向であればコンテナの右端になります。
多くのプログラムでは BoxLayout が直接使われる代わりに、Box クラスが使われます。Box クラスは、BoxLayout を使用する軽量コンテナです。BoxLayout を効果的に使用するために役立つ便利なメソッドを提供します。入れ子になった複数のボックスへのコンポーネント追加によって、必要な配置を容易に得ることができます。
詳細と使用例については、「The Java Tutorial」の「How to Use BoxLayout」を参照してください。
警告: このクラスの直列化されたオブジェクトは、今後の Swing リリースと互換ではなくなる予定です。現在の直列化のサポートは、短期間の運用や、同じバージョンの Swing を実行するアプリケーション間の RMI に適しています。JDK Version 1.4 以降、すべての JavaBeans™ の長期間の運用サポートは、java.beans
パッケージに追加されています。詳細は、XMLEncoder
を参照してください。
Box
,
ComponentOrientation
,
JComponent.getAlignmentX()
,
JComponent.getAlignmentY()
フィールドの概要 | |
---|---|
static int |
LINE_AXIS
ターゲットコンテナの ComponentOrientation プロパティーの決定に従って、テキスト行の方向にコンポーネントの配置を指定します。 |
static int |
PAGE_AXIS
ターゲットコンテナの ComponentOrientation プロパティーの決定に従って、複数のページにまたがって行が進んでいく方向にコンポーネントが配置されるように指定します。 |
static int |
X_AXIS
コンポーネントの配置の方向を左から右に指定します。 |
static int |
Y_AXIS
コンポーネントの配置の方向を上から下に指定します。 |
コンストラクタの概要 | |
---|---|
BoxLayout(Container target,
int axis)
コンポーネントを指定された方向に配置するレイアウトマネージャーを生成します。 |
メソッドの概要 | |
---|---|
void |
addLayoutComponent(Component comp,
Object constraints)
このクラスでは使用しません。 |
void |
addLayoutComponent(String name,
Component comp)
このクラスでは使用しません。 |
int |
getAxis()
コンポーネントの配置に使用された軸を返します。 |
float |
getLayoutAlignmentX(Container target)
コンテナの X 軸に沿った配置方法を返します。 |
float |
getLayoutAlignmentY(Container target)
コンテナの Y 軸に沿った配置方法を返します。 |
Container |
getTarget()
このレイアウトマネージャーを使用するコンテナを返します。 |
void |
invalidateLayout(Container target)
子のレイアウト情報が変更されたことを示します。 |
void |
layoutContainer(Container target)
指定されたコンテナを配置する必要があるときに AWT によって呼び出されます。 |
Dimension |
maximumLayoutSize(Container target)
ターゲットコンテナが自身のコンポーネントを配置するときに使用できる、最大の寸法を返します。 |
Dimension |
minimumLayoutSize(Container target)
指定されたターゲットコンテナに含まれるコンポーネントのレイアウトに必要な最小寸法を返します。 |
Dimension |
preferredLayoutSize(Container target)
指定されたターゲットコンテナにあるコンポーネントについて、このレイアウトの推奨寸法を返します。 |
void |
removeLayoutComponent(Component comp)
このクラスでは使用しません。 |
クラス java.lang.Object から継承されたメソッド |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
フィールドの詳細 |
---|
public static final int X_AXIS
public static final int Y_AXIS
public static final int LINE_AXIS
ComponentOrientation
プロパティーの決定に従って、テキスト行の方向にコンポーネントの配置を指定します。
public static final int PAGE_AXIS
ComponentOrientation
プロパティーの決定に従って、複数のページにまたがって行が進んでいく方向にコンポーネントが配置されるように指定します。
コンストラクタの詳細 |
---|
public BoxLayout(Container target, int axis)
target
- 配置する必要があるコンテナaxis
- 配置する必要があるコンテナコンポーネントの配置方向。BoxLayout.X_AXIS
、BoxLayout.Y_AXIS
、BoxLayout.LINE_AXIS
、または BoxLayout.PAGE_AXIS
のどれか
AWTError
- axis
の値が無効な場合メソッドの詳細 |
---|
public final Container getTarget()
public final int getAxis()
BoxLayout.Y_AXIS
、BoxLayout.LINE_AXIS
、または BoxLayout.PAGE_AXIS
のどれか
public void invalidateLayout(Container target)
このメソッドは、コンテナで無効なメソッドが呼び出されたときに AWT によって呼び出されます。無効なメソッドはイベントスレッドに非同期的に呼び出すことができるため、このメソッドも非同期的に呼び出すことができます。
LayoutManager2
内の invalidateLayout
target
- 影響を受けるコンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合public void addLayoutComponent(String name, Component comp)
LayoutManager
内の addLayoutComponent
name
- コンポーネントの名前comp
- コンポーネントpublic void removeLayoutComponent(Component comp)
LayoutManager
内の removeLayoutComponent
comp
- コンポーネントpublic void addLayoutComponent(Component comp, Object constraints)
LayoutManager2
内の addLayoutComponent
comp
- コンポーネントconstraints
- 制約public Dimension preferredLayoutSize(Container target)
LayoutManager
内の preferredLayoutSize
target
- 配置する必要があるコンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合Container
,
minimumLayoutSize(java.awt.Container)
,
maximumLayoutSize(java.awt.Container)
public Dimension minimumLayoutSize(Container target)
LayoutManager
内の minimumLayoutSize
target
- 配置する必要があるコンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合preferredLayoutSize(java.awt.Container)
,
maximumLayoutSize(java.awt.Container)
public Dimension maximumLayoutSize(Container target)
LayoutManager2
内の maximumLayoutSize
target
- 配置する必要があるコンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合preferredLayoutSize(java.awt.Container)
,
minimumLayoutSize(java.awt.Container)
public float getLayoutAlignmentX(Container target)
LayoutManager2
内の getLayoutAlignmentX
target
- コンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合public float getLayoutAlignmentY(Container target)
LayoutManager2
内の getLayoutAlignmentY
target
- コンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合public void layoutContainer(Container target)
LayoutManager
内の layoutContainer
target
- レイアウトするコンテナ
AWTError
- ターゲットが BoxLayout コンストラクタに指定されたコンテナでない場合
|
JavaTM Platform Standard Ed. 6 |
|||||||||
前のクラス 次のクラス | フレームあり フレームなし | |||||||||
概要: 入れ子 | フィールド | コンストラクタ | メソッド | 詳細: フィールド | コンストラクタ | メソッド |
Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。