JavaTM Platform
Standard Ed. 6

javax.swing
クラス SpringLayout

java.lang.Object
  上位を拡張 javax.swing.SpringLayout
すべての実装されたインタフェース:
LayoutManager, LayoutManager2

public class SpringLayout
extends Object
implements LayoutManager2

SpringLayout は、一連の制約に基づいて、関連するコンテナの子を配置します。SpringLayout の使用例については、「The Java Tutorial」の「How to Use SpringLayout」を参照してください。

Spring オブジェクトで表される各制約は、2 つのコンポーネントエッジ間の垂直方向または水平方向の距離を制御します。エッジは、コンテナの子またはコンテナ自身に属すことができます。たとえば、コンポーネントに許される幅は、コンポーネントの west (左) エッジと east (右) エッジ間の距離を制御する制約を使用して表現できます。コンポーネントに許される y 座標は、コンポーネントの north (上端) エッジとコンテナの north エッジ間の距離の制約によって表現できます。

SpringLayout によって制御されるコンテナのすべての子は、コンテナ自身と同様に、関連する制約を 1 セットだけ持ちます。制約は、SpringLayout.Constraints オブジェクトによって表現されます。SpringLayout がデフォルトで作成する制約では、関連するコンポーネントに、コンポーネントの Component.getMinimumSize() メソッド、Component.getPreferredSize() メソッド、および Component.getMaximumSize() メソッドが返す最小サイズ、推奨サイズ、および最大サイズが設定されます。xy の位置は初期状態では制約が設定されていないため、Component の位置は、制約を設定するまで親 ContainerInsets に対して 0,0 となります。

コンポーネントの制約を変更するには複数の方法があります。putConstraint メソッドのいずれかを使用すると、同一コンテナ内の 2 つのコンポーネントのエッジに接続するスプリングを確立できます。また、getConstraints メソッドを使用すると、適切な SpringLayout.Constraints オブジェクトを取得でき、その後 1 つ以上のスプリングを変更できます。getConstraint メソッドを使用すると、コンポーネントの特定のエッジに対するスプリングを取得でき、その後スプリングを変更できます。Container.add(Component, Object) を使用すると、コンポーネントをコンテナに追加するときに制約オブジェクトを指定することにより、独自の SpringLayout.Constraints オブジェクトをコンポーネントに関連付けることができます。

各制約を表す Spring オブジェクトには、最小値 (minimum 値)、推奨値 (preferred 値)、最大値 (maximum 値)、および現在の値が設定されます。スプリングの現在の値は、最小値と最大値の間にある値で、Spring.sum(javax.swing.Spring, javax.swing.Spring) メソッドの説明で示される式に従います。最小値、推奨値、および 最大値が等しい場合、現在の値も常に等しくなります。 このような柔軟性のないスプリングは、「柱」 (strut) と呼ばれます。ファクトリメソッドの Spring.constant(int) を使用すると、柱を生成できます。Spring クラスには、別のスプリングに依存するスプリングなど、その他の種類のスプリングを作成するファクトリメソッドも用意されています。

SpringLayout では、各エッジの位置は別の 1 つエッジだけの位置に依存します。制約をあとで追加してエッジに新しいバインディングを作成すると、以前のバインディングは破棄され、エッジは 1 つのエッジに依存した状態のまま維持されます。スプリングは、コンテナとその直接の子のエッジ間にだけ接続する必要があります。SpringLayout の動作は、別のコンテナの内部または外部からコンポーネントのエッジに接続する制約によって表現される場合、定義されません。

SpringLayout とその他のレイアウトマネージャー


注: 多くのレイアウトマネージャーとは異なり、SpringLayout は、管理するコンポーネントの位置を自動的に設定しません。SpringLayout を使用する GUI をハンドコーディングする場合は、west/east および north/south の位置に制約を設定することによって、コンポーネントの位置を初期化してください。

使用する制約によっては、コンテナのサイズを明示的に設定することが必要な場合もあります。


SpringLayout は単純ですが、ほとんどのレイアウトマネージャーの動作をエミュレートできます。FlowLayout の行ブレークのような機能については、Spring クラスに専用のサブクラスを作成する必要があります。

SpringLayout を使用すると、Box を入れ子にした組み合わせでは解決できないような、レイアウトに関する難しい問題も多く解決できます。SpringLayoutLayoutManager2 規約を正確に遵守しているため、ほかのレイアウトマネージャーを入れ子にできます。 これは、ほかのレイアウトマネージャーに含まれる制約を作成する方法よりも望ましい方法です。

SpringLayout によるレイアウトオペレーションの漸近的複雑性は、制約またはコンポーネント、あるいはその両方の数に比例します。

警告: このクラスの直列化されたオブジェクトは、今後の Swing リリースと互換ではなくなる予定です。現在の直列化のサポートは、短期間の運用や、同じバージョンの Swing を実行するアプリケーション間の RMI に適しています。JDK Version 1.4 以降、すべての JavaBeans の長期間の運用サポートは、java.beans パッケージに追加されています。詳細は、XMLEncoder を参照してください。

導入されたバージョン:
1.4
関連項目:
Spring, SpringLayout.Constraints

入れ子のクラスの概要
static class SpringLayout.Constraints
          Constraints オブジェクトは、SpringLayout が制御するコンテナ内のコンポーネントのサイズ変更方法および位置変更方法を決定する制約を保持します。
 
フィールドの概要
static String BASELINE
          コンポーネントのベースラインを指定します。
static String EAST
          コンポーネントの境界の矩形の右端を指定します。
static String HEIGHT
          コンポーネントの境界の矩形の高さを指定します。
static String HORIZONTAL_CENTER
          コンポーネントの境界の矩形の水平方向の中心を指定します。
static String NORTH
          コンポーネントの境界の矩形の上端を指定します。
static String SOUTH
          コンポーネントの境界の矩形の下端を指定します。
static String VERTICAL_CENTER
          コンポーネントの境界の矩形の垂直方向の中心を指定します。
static String WEST
          コンポーネントの境界の矩形の左端を指定します。
static String WIDTH
          コンポーネントの境界の矩形の幅を指定します。
 
コンストラクタの概要
SpringLayout()
          新しい SpringLayout を構築します。
 
メソッドの概要
 void addLayoutComponent(Component component, Object constraints)
          constraintsSpringLayout.Constraints のインスタンスである場合は、指定されたコンポーネントに制約を関連付けます。
 void addLayoutComponent(String name, Component c)
          このレイアウトマネージャーはコンポーネントごとの文字列を使用しないため、何もしません。
 Spring getConstraint(String edgeName, Component c)
          コンポーネントの指定されたエッジと親の上端または左端との間の距離を制御するスプリングを返します。
 SpringLayout.Constraints getConstraints(Component c)
          指定されたコンポーネントの制約を返します。
 float getLayoutAlignmentX(Container p)
          0.5f (中央揃え) を返します。
 float getLayoutAlignmentY(Container p)
          0.5f (中央揃え) を返します。
 void invalidateLayout(Container p)
          レイアウトを無効にします。
 void layoutContainer(Container parent)
          指定されたコンテナを配置します。
 Dimension maximumLayoutSize(Container parent)
          指定されたコンテナの最大サイズの寸法を計算します。
 Dimension minimumLayoutSize(Container parent)
          指定されたコンテナの最小サイズの寸法を計算します。
 Dimension preferredLayoutSize(Container parent)
          指定されたコンテナの推奨サイズの寸法を計算します。
 void putConstraint(String e1, Component c1, int pad, String e2, Component c2)
          コンポーネント c1 のエッジ e1 をコンポーネント c2 のエッジ e2 にリンクします。
 void putConstraint(String e1, Component c1, Spring s, String e2, Component c2)
          コンポーネント c1 のエッジ e1 をコンポーネント c2 のエッジ e2 にリンクします。
 void removeLayoutComponent(Component c)
          指定されたコンポーネントに関連付けれられた制約を削除します。
 
クラス java.lang.Object から継承されたメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

フィールドの詳細

NORTH

public static final String NORTH
コンポーネントの境界の矩形の上端を指定します。

関連項目:
定数フィールド値

SOUTH

public static final String SOUTH
コンポーネントの境界の矩形の下端を指定します。

関連項目:
定数フィールド値

EAST

public static final String EAST
コンポーネントの境界の矩形の右端を指定します。

関連項目:
定数フィールド値

WEST

public static final String WEST
コンポーネントの境界の矩形の左端を指定します。

関連項目:
定数フィールド値

HORIZONTAL_CENTER

public static final String HORIZONTAL_CENTER
コンポーネントの境界の矩形の水平方向の中心を指定します。

導入されたバージョン:
1.6
関連項目:
定数フィールド値

VERTICAL_CENTER

public static final String VERTICAL_CENTER
コンポーネントの境界の矩形の垂直方向の中心を指定します。

導入されたバージョン:
1.6
関連項目:
定数フィールド値

BASELINE

public static final String BASELINE
コンポーネントのベースラインを指定します。

導入されたバージョン:
1.6
関連項目:
定数フィールド値

WIDTH

public static final String WIDTH
コンポーネントの境界の矩形の幅を指定します。

導入されたバージョン:
1.6
関連項目:
定数フィールド値

HEIGHT

public static final String HEIGHT
コンポーネントの境界の矩形の高さを指定します。

導入されたバージョン:
1.6
関連項目:
定数フィールド値
コンストラクタの詳細

SpringLayout

public SpringLayout()
新しい SpringLayout を構築します。

メソッドの詳細

addLayoutComponent

public void addLayoutComponent(String name,
                               Component c)
このレイアウトマネージャーはコンポーネントごとの文字列を使用しないため、何もしません。

定義:
インタフェース LayoutManager 内の addLayoutComponent
パラメータ:
name - コンポーネントに関連付けられた文字列
c - 追加されるコンポーネント

removeLayoutComponent

public void removeLayoutComponent(Component c)
指定されたコンポーネントに関連付けれられた制約を削除します。

定義:
インタフェース LayoutManager 内の removeLayoutComponent
パラメータ:
c - コンテナから削除されるコンポーネント

minimumLayoutSize

public Dimension minimumLayoutSize(Container parent)
インタフェース LayoutManager の記述:
指定されたコンテナの最小サイズの寸法を計算します。含まれるコンポーネントは指定されます。

定義:
インタフェース LayoutManager 内の minimumLayoutSize
パラメータ:
parent - 配置されるコンポーネント
関連項目:
LayoutManager.preferredLayoutSize(java.awt.Container)

preferredLayoutSize

public Dimension preferredLayoutSize(Container parent)
インタフェース LayoutManager の記述:
指定されたコンテナの推奨サイズの寸法を計算します。含まれるコンポーネントは指定されます。

定義:
インタフェース LayoutManager 内の preferredLayoutSize
パラメータ:
parent - 配置されるコンテナ
関連項目:
LayoutManager.minimumLayoutSize(java.awt.Container)

maximumLayoutSize

public Dimension maximumLayoutSize(Container parent)
インタフェース LayoutManager2 の記述:
指定されたコンテナの最大サイズの寸法を計算します。含まれるコンポーネントは指定されます。

定義:
インタフェース LayoutManager2 内の maximumLayoutSize
関連項目:
Component.getMaximumSize(), LayoutManager

addLayoutComponent

public void addLayoutComponent(Component component,
                               Object constraints)
constraintsSpringLayout.Constraints のインスタンスである場合は、指定されたコンポーネントに制約を関連付けます。

定義:
インタフェース LayoutManager2 内の addLayoutComponent
パラメータ:
component - 追加するコンポーネント
constraints - コンポーネントの制約
関連項目:
SpringLayout.Constraints

getLayoutAlignmentX

public float getLayoutAlignmentX(Container p)
0.5f (中央揃え) を返します。

定義:
インタフェース LayoutManager2 内の getLayoutAlignmentX

getLayoutAlignmentY

public float getLayoutAlignmentY(Container p)
0.5f (中央揃え) を返します。

定義:
インタフェース LayoutManager2 内の getLayoutAlignmentY

invalidateLayout

public void invalidateLayout(Container p)
インタフェース LayoutManager2 の記述:
レイアウトを無効にします。このとき、レイアウトマネージャーが情報をキャッシュしていればそれを破棄します。

定義:
インタフェース LayoutManager2 内の invalidateLayout

putConstraint

public void putConstraint(String e1,
                          Component c1,
                          int pad,
                          String e2,
                          Component c2)
コンポーネント c1 のエッジ e1 をコンポーネント c2 のエッジ e2 にリンクします。エッジ間の距離は固定です。この制約により、後続のすべてのレイアウトオペレーションで、次の代入が発生します。
     value(e1, c1) = value(e2, c2) + pad

パラメータ:
e1 - 依存するエッジ
c1 - 依存するコンポーネント
pad - 依存する側とされる側の間の固定距離
e2 - 依存されるエッジ
c2 - 依存されるコンポーネント
関連項目:
putConstraint(String, Component, Spring, String, Component)

putConstraint

public void putConstraint(String e1,
                          Component c1,
                          Spring s,
                          String e2,
                          Component c2)
コンポーネント c1 のエッジ e1 をコンポーネント c2 のエッジ e2 にリンクします。エッジ (e2, c2) の値が変更されると、(e2, c2)s の (スプリング) sum によってエッジ (e1, c1) が計算されます。各エッジに、SpringLayout.NORTHSpringLayout.SOUTHSpringLayout.EASTSpringLayout.WESTSpringLayout.HORIZONTAL_CENTERSpringLayout.VERTICAL_CENTER、または SpringLayout.BASELINE のいずれかの値が設定されている必要があります。 

パラメータ:
e1 - 依存するエッジ
c1 - 依存するコンポーネント
s - 依存する側と依存される側を接続するスプリング
e2 - 依存されるエッジ
c2 - 依存されるコンポーネント
関連項目:
putConstraint(String, Component, int, String, Component), NORTH, SOUTH, EAST, WEST, VERTICAL_CENTER, HORIZONTAL_CENTER, BASELINE

getConstraints

public SpringLayout.Constraints getConstraints(Component c)
指定されたコンポーネントの制約を返します。GridBagLayout getConstraints メソッドとは異なり、このメソッドは制約を複製しません。コンポーネントに関連付けられた制約がない場合は、親のインセットに対して 0,0 の位置にあるデフォルトの制約オブジェクトを返します。 幅と高さはコンポーネントの最小サイズ、最大サイズ、および推奨サイズに制約されます。メソッドが呼び出された時点でサイズの特性は凍結されませんが、変更されたコンポーネントの特性を追跡する特性を持つ制約オブジェクトを返します。

パラメータ:
c - 返される制約を持つコンポーネント
戻り値:
指定されたコンポーネントの制約

getConstraint

public Spring getConstraint(String edgeName,
                            Component c)
コンポーネントの指定されたエッジと親の上端または左端との間の距離を制御するスプリングを返します。このメソッドは、エッジに対する現在のバインディングを返すのではなく、エッジをあとで再度バインドする場合にもエッジの特性を追跡するプロキシを返します。プロキシは、構築環境での使用を目的としています。 構築環境では、ユーザーが任意の順序でレイアウトの制約を定義できるようにすることが便利です。ただし、プロキシは、レイアウトの制約間の循環的な依存性を作成する手段を提供します。そのようなサイクルは、レイアウトオペレーションがいつでも終了できるように、SpringLayout によって内部的に検出されます。

パラメータ:
edgeName - SpringLayout.NORTHSpringLayout.SOUTHSpringLayout.EASTSpringLayout.WESTSpringLayout.VERTICAL_CENTERSpringLayout.HORIZONTAL_CENTER、または SpringLayout.BASELINE のいずれか
c - エッジスプリングを要求されるコンポーネント
戻り値:
指定されたエッジからその親の上端または左端までの 距離を制御するスプリングのプロキシ
関連項目:
NORTH, SOUTH, EAST, WEST, VERTICAL_CENTER, HORIZONTAL_CENTER, BASELINE

layoutContainer

public void layoutContainer(Container parent)
インタフェース LayoutManager の記述:
指定されたコンテナを配置します。

定義:
インタフェース LayoutManager 内の layoutContainer
パラメータ:
parent - 配置されるコンテナ

JavaTM Platform
Standard Ed. 6

バグの報告と機能のリクエスト
さらに詳しい API リファレンスおよび開発者ドキュメントについては、Java SE 開発者用ドキュメントを参照してください。開発者向けの詳細な解説、概念の概要、用語の定義、バグの回避策、およびコード実例が含まれています。

Copyright 2009 Sun Microsystems, Inc. All rights reserved. Use is subject to license terms. Documentation Redistribution Policy も参照してください。