JavaTM 2
Platform
Std. Ed. v1.4.0

javax.swing
クラス LookAndFeel

java.lang.Object
  |
  +--javax.swing.LookAndFeel
直系の既知のサブクラス:
BasicLookAndFeel, MultiLookAndFeel

public abstract class LookAndFeel
extends Object

プラグイン可能な Look & Feel コンポーネントについて、Look & Feel の特性を完全に定義します。


コンストラクタの概要
LookAndFeel()
           
 
メソッドの概要
 UIDefaults getDefaults()
          Look & Feel 固有のデフォルトテーブルを作成するために、UIManager.setLookAndFeel によって 1 回呼び出されます。
abstract  String getDescription()
          「The CDE/Motif Look and Feel」など、この Look & Feel の実装に対する 1 行の説明を返します。
static Object getDesktopPropertyValue(String systemPropertyName, Object fallbackValue)
          Toolkit.getDefaultToolkit().getDesktopProperty() を呼び出して、指定されたシステムデスクトッププロパティの値を返します。
abstract  String getID()
          この Look & Feel を識別する文字列を返します。
abstract  String getName()
          「CDE/Motif」など、この Look & Feel を識別する短い文字列を返します。
 boolean getSupportsWindowDecorations()
          LookAndFeel が返す RootPaneUI インスタンスが JRootPane でのウィンドウ装飾の提供をサポートする場合、true を返します。
 void initialize()
          UIManager.setLookAndFeel は、getDefaults() の最初の呼び出し (通常は唯一の呼び出し) の前に、このメソッドを呼び出します。
static void installBorder(JComponent c, String defaultBorderName)
          ボーダが現在 null であるか、すでに UIResource のインスタンスである場合に、指定されたコンポーネントにコンポーネントのデフォルト Border オブジェクトをインストールする簡易メソッドです。
static void installColors(JComponent c, String defaultBgName, String defaultFgName)
          現在のデフォルトテーブルの値で、コンポーネントのフォアグラウンドカラーおよびバックグラウンドカラープロパティを初期化する簡易メソッドです。
static void installColorsAndFont(JComponent c, String defaultBgName, String defaultFgName, String defaultFontName)
          現在のデフォルトテーブルの値で、コンポーネントのフォアグラウンド、バックグラウンド、およびフォントプロパティを初期化する簡易メソッドです。
abstract  boolean isNativeLookAndFeel()
          基本のプラットフォームに「ネイティブな」Look & Feel があり、現在の Look & Feel がその実装である場合に true を返します。
abstract  boolean isSupportedLookAndFeel()
          基本のプラットフォームがこの Look & Feel をサポートしたり、許容したりする場合に true を返します。
static void loadKeyBindings(InputMap retMap, Object[] keys)
          keys のバインディングを retMap にロードします。
static ComponentInputMap makeComponentInputMap(JComponent c, Object[] keys)
          keys から ComponentInputMap を生成します。
static Object makeIcon(Class baseClass, String gifFile)
          指定された gifFile ファイル名の ImageIcon の UIResource を作成する UIDefaults.LazyValue を作成するためのユーティリティメソッドです。
static InputMap makeInputMap(Object[] keys)
          keys から InputMap を生成します。
static JTextComponent.KeyBinding[] makeKeyBindings(Object[] keyBindingList)
          KeyBinding のリストを作成する簡易メソッドです。
 void provideErrorFeedback(Component component)
          フォーカスを持つ編集不可能な JTextField にペーストするなど、ユーザが無効な操作を行おうとするときに呼び出されます。
 String toString()
          このオブジェクトのプロパティを表示および識別する文字列を返します。
 void uninitialize()
          UIManager.setLookAndFeel は、新しいデフォルトの Look & Feel に変更する直前に、このメソッドを呼び出します。
static void uninstallBorder(JComponent c)
          ボーダが現在 UIResource のインスタンスである場合に、指定されたコンポーネントからコンポーネントのデフォルトのボーダをアンインストールする簡易メソッドです。
 
クラス java.lang.Object から継承したメソッド
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

コンストラクタの詳細

LookAndFeel

public LookAndFeel()
メソッドの詳細

installColors

public static void installColors(JComponent c,
                                 String defaultBgName,
                                 String defaultFgName)
現在のデフォルトテーブルの値で、コンポーネントのフォアグラウンドカラーおよびバックグラウンドカラープロパティを初期化する簡易メソッドです。各プロパティが設定されるのは、現在値が null または UIResource の場合だけです。

パラメータ:
c - デフォルトの色プロパティおよびフォントプロパティをインストールするターゲットコンポーネント
defaultBgName - デフォルトバックグラウンドのキー
defaultFgName - デフォルトフォアグラウンドのキー
関連項目:
installColorsAndFont(javax.swing.JComponent, java.lang.String, java.lang.String, java.lang.String), UIManager.getColor(java.lang.Object)

installColorsAndFont

public static void installColorsAndFont(JComponent c,
                                        String defaultBgName,
                                        String defaultFgName,
                                        String defaultFontName)
現在のデフォルトテーブルの値で、コンポーネントのフォアグラウンド、バックグラウンド、およびフォントプロパティを初期化する簡易メソッドです。各プロパティが設定されるのは、現在値が null または UIResource の場合だけです。

パラメータ:
c - デフォルトの色プロパティおよびフォントプロパティをインストールするターゲットコンポーネント
defaultBgName - デフォルトバックグラウンドのキー
defaultFgName - デフォルトフォアグラウンドのキー
defaultFontName - デフォルトフォントのキー
関連項目:
installColors(javax.swing.JComponent, java.lang.String, java.lang.String), UIManager.getColor(java.lang.Object), UIManager.getFont(java.lang.Object)

installBorder

public static void installBorder(JComponent c,
                                 String defaultBorderName)
ボーダが現在 null であるか、すでに UIResource のインスタンスである場合に、指定されたコンポーネントにコンポーネントのデフォルト Border オブジェクトをインストールする簡易メソッドです。

パラメータ:
c - デフォルトのボーダをインストールするターゲットコンポーネント
defaultBorderName - デフォルトのボーダを指定するキー

uninstallBorder

public static void uninstallBorder(JComponent c)
ボーダが現在 UIResource のインスタンスである場合に、指定されたコンポーネントからコンポーネントのデフォルトのボーダをアンインストールする簡易メソッドです。

パラメータ:
c - デフォルトのボーダをアンインストールするターゲットコンポーネント

makeKeyBindings

public static JTextComponent.KeyBinding[] makeKeyBindings(Object[] keyBindingList)
KeyBinding のリストを作成する簡易メソッドです。

keyBindingList の KeyStroke と Action の組み合わせごとに、KeyBinding の配列を 1 つ返します。KeyStroke は、KeyStroke.getKeyStroke メソッドで指定された形式の文字列、または KeyStroke オブジェクトです。

Action は文字列です。次に例を示します。

	JTextComponent.KeyBinding[] multilineBindings = makeKeyBindings( new Object[] {
"UP", DefaultEditorKit.upAction,
"DOWN", DefaultEditorKit.downAction,
"PAGE_UP", DefaultEditorKit.pageUpAction,
"PAGE_DOWN", DefaultEditorKit.pageDownAction,
"ENTER", DefaultEditorKit.insertBreakAction,
"TAB", DefaultEditorKit.insertTabAction
  });

パラメータ:
keyBindingList - KeyStroke と Action の組み合わせの配列
戻り値:
KeyBinding の配列

makeInputMap

public static InputMap makeInputMap(Object[] keys)
keys から InputMap を生成します。keys は、KeyStroke.getKeyStroke(String) で指定された KeyStroke を提供する String または KeyStroke である偶数項目、および Object が ActionMap の関連 Action を判定するのに使った奇数項目をすべて用いて、InputMap を記述します。

導入されたバージョン:
1.3

makeComponentInputMap

public static ComponentInputMap makeComponentInputMap(JComponent c,
                                                      Object[] keys)
keys から ComponentInputMap を生成します。keys は、KeyStroke.getKeyStroke(String) で指定された KeyStroke を提供する String または KeyStroke である偶数項目、および Object が ActionMap の関連 Action を判定するのに使った奇数項目をすべて用いて、InputMap を記述します。

導入されたバージョン:
1.3

loadKeyBindings

public static void loadKeyBindings(InputMap retMap,
                                   Object[] keys)
keys のバインディングを retMap にロードします。これによって retMap の既存のバインディングが削除されることはありません。keys は、KeyStroke.getKeyStroke(String) で指定された KeyStroke を提供する String または KeyStroke である偶数項目、および Object が ActionMap の関連 Action を判定するのに使った奇数項目をすべて用いて、InputMap を記述します。

導入されたバージョン:
1.3

makeIcon

public static Object makeIcon(Class baseClass,
                              String gifFile)
指定された gifFile ファイル名の ImageIcon の UIResource を作成する UIDefaults.LazyValue を作成するためのユーティリティメソッドです。


provideErrorFeedback

public void provideErrorFeedback(Component component)
フォーカスを持つ編集不可能な JTextField にペーストするなど、ユーザが無効な操作を行おうとするときに呼び出されます。デフォルトの実装では、ビープ音を鳴らします。別の動作を行う場合は、デフォルトの実装をサブクラスによってオーバーライドし、別のフィードバックを指定する必要があります。

パラメータ:
component - エラーが発生したコンポーネント。null は、エラー条件を Component に直接関連付けないことを示す

getDesktopPropertyValue

public static Object getDesktopPropertyValue(String systemPropertyName,
                                             Object fallbackValue)
Toolkit.getDefaultToolkit().getDesktopProperty() を呼び出して、指定されたシステムデスクトッププロパティの値を返します。指定されたプロパティの値が null の場合、fallbackValue を返します。

パラメータ:
systemPropertyName - 照会するシステムデスクトッププロパティの名前
fallbackValue - システム値が null の場合、値として戻るオブジェクト
戻り値:
デスクトッププロパティの現在の値
関連項目:
Toolkit.getDesktopProperty(java.lang.String)

getName

public abstract String getName()
「CDE/Motif」など、この Look & Feel を識別する短い文字列を返します。この文字列は、メニュー項目に適しています。Look & Feel は、それぞれ異なる名前を持っています。たとえば、数個のコンポーネントの描画方法を変更する MotifLookAndFeel のサブクラスは、「CDE/Motif My Way」などと呼ばれます。こうした名前は、ユーザが名前のリストから L&F を選択するときに便利です。


getID

public abstract String getID()
この Look & Feel を識別する文字列を返します。この文字列は、有名な Look & Feel の実装を認識するアプリケーション/サービスで使用されます。現在、有名なものとしては「Motif」、「Windows」、「Mac」、「Metal」などです。Look & Feel に基本的な変更を加えない有名なスーパークラスから派生した LookAndFeel は、このメソッドをオーバーライドすべきではないことに注意してください。


getDescription

public abstract String getDescription()
「The CDE/Motif Look and Feel」など、この Look & Feel の実装に対する 1 行の説明を返します。これはユーザ向けの文字列で、ウィンドウのタイトルやツールヒントメッセージなどに使用されます。


getSupportsWindowDecorations

public boolean getSupportsWindowDecorations()
LookAndFeel が返す RootPaneUI インスタンスが JRootPane でのウィンドウ装飾の提供をサポートする場合、true を返します。

デフォルトの実装は false を返します。ウィンドウ装飾をサポートする場合、サブクラスでこの実装をオーバーライドし、true を返すようにします。

戻り値:
作成された RootPaneUI インスタンスがクライアント側の装飾をサポートする場合、true
導入されたバージョン:
1.4
関連項目:
JDialog.setDefaultLookAndFeelDecorated(boolean), JFrame.setDefaultLookAndFeelDecorated(boolean), JRootPane.setWindowDecorationStyle(int)

isNativeLookAndFeel

public abstract boolean isNativeLookAndFeel()
基本のプラットフォームに「ネイティブな」Look & Feel があり、現在の Look & Feel がその実装である場合に true を返します。たとえば CDE/Motif の見た目と実装では、基本のプラットフォームが Solaris であった場合に、true が返されます。


isSupportedLookAndFeel

public abstract boolean isSupportedLookAndFeel()
基本のプラットフォームがこの Look & Feel をサポートしたり、許容したりする場合に true を返します。Look & Feel が特殊なリソースや、現在のプラットフォームに対して定義されていない法的契約に依存する場合、このメソッドは false を返します。

関連項目:
UIManager.setLookAndFeel(javax.swing.LookAndFeel)

initialize

public void initialize()
UIManager.setLookAndFeel は、getDefaults() の最初の呼び出し (通常は唯一の呼び出し) の前に、このメソッドを呼び出します。サブクラスは、static 初期化子ではなく、このメソッドで必要な一度だけのセットアップを実行します。Look & Feel クラスのオブジェクトは、isSupportedLookAndFeel() が false を返すことを確認するためにだけロードされる場合があるからです。

関連項目:
uninitialize(), UIManager.setLookAndFeel(javax.swing.LookAndFeel)

uninitialize

public void uninitialize()
UIManager.setLookAndFeel は、新しいデフォルトの Look & Feel に変更する直前に、このメソッドを呼び出します。サブクラスは、このメソッドでいくつかのリソースを解放できます。

関連項目:
initialize()

getDefaults

public UIDefaults getDefaults()
Look & Feel 固有のデフォルトテーブルを作成するために、UIManager.setLookAndFeel によって 1 回呼び出されます。アプリケーションビルダなど、ほかのアプリケーションもこのメソッドを呼び出す場合があります。

関連項目:
initialize(), uninitialize(), UIManager.setLookAndFeel(javax.swing.LookAndFeel)

toString

public String toString()
このオブジェクトのプロパティを表示および識別する文字列を返します。

オーバーライド:
クラス Object 内の toString
戻り値:
このオブジェクトの文字列表現

JavaTM 2
Platform
Std. Ed. v1.4.0

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

Java、Java 2D、および JDBC は米国ならびにその他の国における米国 Sun Microsystems, Inc. の商標もしくは登録商標です。
Copyright 1993-2002 Sun Microsystems, Inc. 901 San Antonio Road
Palo Alto, California, 94303, U.S.A. All Rights Reserved.