ActionScriptで頑張ればFlashゲームは無料で作れるFlashの基礎を無料で習得! ActionScript入門(6)(3/3 ページ)

» 2008年06月12日 00時00分 公開
[吉村美保クラスメソッド株式会社]
前のページへ 1|2|3       

イベントリスナーからイベントハンドラを削除

 では、マウスアップをしたときにはドラッグを停止させましょう。ドラッグを停止させるには、メソッドを使用します。mouseDownHandler内にマウスアップ時のイベントハンドラを登録する以下のコードを追記しましょう。

addEventListener( MouseEvent.MOUSE_UP, mouseUpHandler );

 イベントハンドラとして以下のメソッドも用意しましょう。

protected function mouseUpHandler( envet:MouseEvent ):void {
    stopDrag();
    removeEventListener( MouseEvent.MOUSE_UP, mouseUpHandler );
}

 「removeEventListener」とは登録してあるイベントハンドラをイベントリスナーから削除するメソッドです。マウスアップのイベントハンドラはマウスダウンしたときに毎回登録されますので、マウスアップした際に登録を削除しています。

処理分けをして福笑いFlashゲームをいったん完成

 イベントハンドラの登録、イベントハンドラの削除を学んだところで、マウスダウンした際、ドラッグさせるか回転させるかを処理分けする必要があります。処理分けの定義はシンプルに図11のようにしましょう。

図11 オブジェクトの幅(width)を3分割し、マウスダウンした位置が左の領域の場合は反時計回りに回転、中央の領域の場合は移動、右の領域の場合は時計回りに回転 図11 オブジェクトの幅(width)を3分割し、マウスダウンした位置が左の領域の場合は反時計回りに回転、中央の領域の場合は移動、右の領域の場合は時計回りに回転

 以上の定義から、今回Base.asは最終的にこんなコードになりました。皆さんも自分なりにコーディングしてみてください。そしてコードを比較してみましょう。演算子if文switch文は、いままでやったことの応用になりますので、分からないときは前回までの記事を見直してみてくださいね。

Base.as(完成)
public class Base extends Sprite {
    private const LEFT:String = "left";                          【1】
    private const CENTER:String = "center";                      【1】
    private const RIGHT:String = "right";                        【1】

    public function Base() {
        addEventListener( MouseEvent.MOUSE_DOWN
            , mouseDownHandler );                                【2】
    }

    protected function positionCheck( x:Number ):String {        【3】
        var result:String;
        var w:Number = width / 3;
        if ( x < w ) {  // 左の領域
            result = LEFT;
        } else if ( x >= w && x < w * 2 ) { // 中央の領域
            result = CENTER;
        } else { // 右の領域
            result = RIGHT;
        }
        return result;
    }
    // マウスダウン時のイベントハンドラ
    protected function mouseDownHandler( event:MouseEvent ):void {
        var check:String = positionCheck( event.localX );        【4】

        switch ( check ) {
        case LEFT:
            stage.addEventListener( MouseEvent.MOUSE_MOVE
                , leftMouseMoveHandler );                        【5】
            break;
        case CENTER:
            startDrag();                                         【6】
            break;
        case RIGHT:
            stage.addEventListener( MouseEvent.MOUSE_MOVE
                , rightMouseMoveHandler);                        【7】
            break;
        }
        stage.addEventListener( MouseEvent.MOUSE_UP, mouseUpHandler );
    }
    // マウスムーブ時のイベントハンドラ
    protected function leftMouseMoveHandler( event:MouseEvent ):void {
        rotation -= 0.5;                                         【8】
    }
    // マウスムーブ時のイベントハンドラ
    protected function rightMouseMoveHandler( event:MouseEvent):void {
        rotation += 0.5;                                         【9】
    }
    // マウスアップ時のイベントハンドラ
    protected function mouseUpHandler( envet:MouseEvent ):void {
        stopDrag();                                             【10】

        stage.removeEventListener( MouseEvent.MOUSE_MOVE
            , leftMouseMoveHandler );                           【11】
        stage.removeEventListener( MouseEvent.MOUSE_MOVE
            , rightMouseMoveHandler );                          【11】
        stage.removeEventListener( MouseEvent.MOUSE_UP
            , mouseUpHandler );                                 【11】
    }
}

 【1】「定数」の定義をしています。値を変更しない変数を「定数」と呼び、ASでは「const」というキーワードで定義します。

 【2】では、mouseDownHandlerをマウスダウン時のイベントハンドラとして登録しています。

 【3】のpositionCheck()はxがどの領域にあるかを戻り値として返すメソッドです。

 【4】では、マウスダウンしたx位置(event.localX)からpositionCheckメソッドの戻り値を取得しています。

 【5】では、leftMouseMoveHandlerをマウスムーブ時(マウスを動かしたときのこと)のイベントハンドラとして登録しています。

 【6】のstartDrag()はドラッグの開始を、【10】stopDrag()はドラッグの停止を表しています。

 【7】では、rightMouseMoveHandlerをマウスムーブ時のイベントハンドラとして登録しています。

 【8】では、反時計回りに0.5度ずつ角度を回転します。【9】では、時計回りに0.5度ずつ角度を回転します。

 【11】では、イベントリスナーからイベントハンドラを削除しています。

 ドラッグ時、オブジェクトが回転することでマウスポインタの位置がオブジェクトの領域から外れ、マウスアップイベントが発生しないこともあるので、表示オブジェクトのステージであるstageに対してaddEventListenerやremoveEventListenerをしました。

実行してみよう

 では、プログラムを実行してみましょう。各オブジェクトをドラッグすると移動、回転しますか?

オーバーライドの復習も

 もう1つの仕様として「マウスダウンにより髪の毛の色が変わる」というのがありました。これは前回解説したオーバーライドを使ってやってみましょう。Hair.asでmouseDownHandlerをオーバーライドすることで、できそうですね。drawメソッドの引数に色を指定できるようにして、以下のようにオーバーライドを行ってみましょう。

Hair.as(一部抜粋)
    override protected function mouseDownHandler(event:MouseEvent):void {
        super.mouseDownHandler( event );
        draw( RED )
    }

引数により塗りの色を指定できるようにdrawメソッドを修正
    protected function draw( color:uint ):void {
        graphics.beginFill( color );
        graphics.moveTo( 0, 16 );

……(略)……

 実行してみましょう。髪の毛をクリックすると、色が赤になるはずです。

最終回は、とても大切な“エラー/例外”処理

 いかがでしたか? 今回作ったものを拡張していけば、似顔絵作成ゲームなどもできそうですね。次回はいよいよ最終回です。次回は、地味なようでいてとても大切な“エラー/例外”処理について説明して締めくくりたいと思います。お楽しみに!

 今回のサンプルのソースコードはこちらからダウンロードできます。

プロフィール

吉村 美保(よしむら みほ)

クラスメソッド株式会社 情報システム部 プログラマー
ゲーム開発、インストラクターなどの経験を経て、クラスメソッド株式会社に入社。入社後はFlexやAIRによるRIA開発を行っている。



前のページへ 1|2|3       

Copyright © ITmedia, Inc. All Rights Reserved.

スポンサーからのお知らせPR

注目のテーマ

Microsoft & Windows最前線2025
AI for エンジニアリング
ローコード/ノーコード セントラル by @IT - ITエンジニアがビジネスの中心で活躍する組織へ
Cloud Native Central by @IT - スケーラブルな能力を組織に
システム開発ノウハウ 【発注ナビ】PR
あなたにおすすめの記事PR

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。