トップ 一覧 検索 ヘルプ RSS ログイン

イベント/ボタンの変更点

  • 追加された行はこのように表示されます。
  • 削除された行はこのように表示されます。
!! ボタン

例として、ボタンが押されるたびに異なる乱数を表示する「ランダムナンバージェネレータ」を紹介しましょう。大げさに名前まで付けてしまいましたが、単に 0 から 1 の乱数を表示するという単純なプログラムです。

''Sample31.java''
{{pre num
/* <applet code="Sample31.class" width="150" height="120"></applet> */
import java.applet.Applet;
import java.awt.*;
import java.awt.event.*;

public class Sample31 extends Applet
                      implements ActionListener
{
    // コンポーネントの変数を定義
    Button button;
    Label label;
    
    public void init(){
        // オブジェクトの作成
        button = new Button( "Click me!");
        label = new Label("Click the button!");
        
        // ボタンをリスナーに登録する
        button.addActionListener( this);
        
        // レイアウトの設定
        this.setLayout( new GridLayout( 2, 1));
        
        // コンポーネントをアプレットに追加する
        this.add( button);
        this.add( label);
    }
    
    /*
     * ActionEvent を受け取って処理する。
     */ 
    public void actionPerformed( ActionEvent ev){
        if( ev.getSource() == this.button){
            this.label.setText( "a = " + Math.random());
        }
    }
}
}}

Sample31の実行結果は図のようになります。

{{ref_image fig035.png}}
'''図 35:''' Sample31 実行結果

イベントの処理に関係する部分を太字にしました。

まず7行目ですが、いままでになかった implements ActionListener という語が追加されています。これは Sample31 クラスに ActionListener を実装せよという命令です。これによりSample31クラスはActionListenerインタフェースを実装したことになります。

19行目で、生成したボタンオブジェクトをこのアプレットのリスナーへ登録しています。このリスナーへの登録を行わないと、リスナーを実装していてもボタンオブジェクトから発生したイベントはリスナーを素通りしてしまいますので注意してください。

32行目から36行目が、ボタンオブジェクトで発生したイベントを処理する部分になります。actionPerformed() というメソッドを定義していますが、これはインタフェースで「私を実装したクラスはこのメソッドを定義しなさいよ」と宣言されていたメソッドです。1このメソッドは引数として、自分が捕まえたイベントを持っています。33行目のif文で、リスナーが捕まえたイベントが確かに我々が意図したボタンから発生したものかどうかを確かめています。ボタンが複数あるときには必要な作業です。我々が意図したボタンからのイベントであれば、34行目でラベルに表示される乱数を更新しています。

新しくイベントとリスナーが登場しましたが、そんなに扱いにくそうなものではないですよね?

この調子で残りも見ていきましょう。