前回は、
シーンの作成
まず、
// シーンを作成します。
var gallery:SceneObject = new SceneObject();
// シーンに名前を設定します。
gallery.name = "gallery";
// シーンをルートに追加します。
manager.root.addScene( gallery );
子シーンの作成
続いて、
作成するシーンは、
// americanシーンを作成します。
var american:SceneObject = new SceneObject();
// シーンの名前を設定します。
american.name = "american";
// シーンをgalleryに追加します。
gallery.addScene( american );
// frenchシーンを作成します。
var french:SceneObject = new SceneObject();
// シーンの名前を設定します。
french.name = "french";
// シーンをgalleryに追加します。
gallery.addScene( french);
// mameシーンを作成します。
var mame:SceneObject = new SceneObject();
// シーンの名前を設定します。
mame.name = "mame";
// シーンをgalleryに追加します。
gallery.addScene( mame);
これで、
ボタンの作成
それでは、
data:image/s3,"s3://crabby-images/7a5cd/7a5cd26aee8a1cdbf37eb9e1458cbddc1fd961d9" alt="図1 シーンパスの設定 図1 シーンパスの設定"
ロールオーバーの設定
「GalleryButton」
data:image/s3,"s3://crabby-images/8806d/8806d687d9fee895a4d56f93a75a5e7041ca4cb2" alt="図2 ロールオーバーの設定 図2 ロールオーバーの設定"
ボタンの表示
ボタンの設定が完了したら、
data:image/s3,"s3://crabby-images/1ec0f/1ec0f18bcea2f28839db9a580c5962467761804a" alt="図3 「GalleryButton」ボタンの設置 図3 「GalleryButton」ボタンの設置"
設置が完了したら、
data:image/s3,"s3://crabby-images/cafd3/cafd39fb171142633aee981efbb5986c017f5770" alt="図4 ボタン表示確認 図4 ボタン表示確認"
表示されている
data:image/s3,"s3://crabby-images/2235d/2235d3ebbf829579c2139ca8f1eb90c2192185c4" alt="図5 シーン遷移確認 図5 シーン遷移確認"
表示オブジェクトのアニメーション設定
続いて、
簡単なアニメーションの設定を行いましょう。
data:image/s3,"s3://crabby-images/02612/0261263079be09e0d0ed03d2c6917fa63f1b2824" alt="図6 レイヤーの設定 図6 レイヤーの設定"
次に、
data:image/s3,"s3://crabby-images/55bdc/55bdcbe676e1dfaeb67a7391924a894fe40715cb" alt="図7 アニメーションの設定 図7 アニメーションの設定"
表示設定
設定が完了したら、
// galleryPageを作成します。
var galleryPage:GalleryPage = new GalleryPage();
galleryPage.x = 151;
galleryPage.y = 114;
次に、
// galleryPage の表示設定を行います。
gallery.onSceneLoad = function():void {
this.addCommand(
new AddChild( this.container , galleryPage )
);
}
// galleryPage の削除設定を行います。
gallery.onSceneUnload = function():void {
this.addCommand(
new RemoveChild( this.container , galleryPage )
);
}
「gallery」
data:image/s3,"s3://crabby-images/09a80/09a8079bdbf741a056b4f291e6c304e68106ede8" alt="図8 「GalleryPage」表示確認 図8 「GalleryPage」表示確認"
ボタンの設定
「gallery」
AmericanButton
まず
data:image/s3,"s3://crabby-images/c9380/c93802ffe133a8f4f687791ca21c2dae59ab3e02" alt="図9 シーンパスの設定 図9 シーンパスの設定"
ここでは、
FrenchButton
次に、
data:image/s3,"s3://crabby-images/056d8/056d83cefeea4b541305611f4c886623f0dbb364" alt="図10 シーンパスの設定 図10 シーンパスの設定"
MameButton
最後に
data:image/s3,"s3://crabby-images/0d08d/0d08d74c0312d79519edc7bfda1b981aafab23af" alt="図11 シーンパスの設定 図11 シーンパスの設定"
ボタンの表示
ボタンの設定が完了したら、
表示設定の前には、
// ボタンインスタンスを生成します。
var americanButton:AmericanButton = new AmericanButton();
americanButton.x = 150;
americanButton.y = 161;
// ボタンインスタンスを生成します。
var frenchButton:FrenchButton = new FrenchButton();
frenchButton.x = 270;
frenchButton.y = 161;
// ボタンインスタンスを生成します。
var mameButton:MameButton = new MameButton();
mameButton.x = 390;
mameButton.y = 161;
表示設定の際に使用するイベントハンドラメソッドは
// galleryPage の表示設定を行います。
gallery.onSceneLoad = function():void {
this.addCommand(
new AddChild( this.container , galleryPage ),
new AddChild( this.container , americanButton ),
new AddChild( this.container , frenchButton ),
new AddChild( this.container , mameButton )
);
}
ボタンの削除処理も
// galleryPage の削除設定を行います。
gallery.onSceneUnload = function():void {
this.addCommand(
new RemoveChild( this.container , galleryPage ),
new RemoveChild( this.container , americanButton ),
new RemoveChild( this.container , frenchButton ),
new RemoveChild( this.container , mameButton )
);
}
設定が完了したら、
data:image/s3,"s3://crabby-images/473fe/473fef897e04e132e15606be856c7740d47c5022" alt="図12 画像の確認 図12 画像の確認"
表示されているボタンをクリックすると、
data:image/s3,"s3://crabby-images/fb5ce/fb5cef02a26454cd15559376c74986159981509d" alt="図13 ログの確認 図13 ログの確認"
表示オブジェクトの設定
「動物の詳細」
まずは
// インスタンスを生成します。
var photoBG:PhotoBG = new PhotoBG();
photoBG.x = 0;
photoBG.y = 0;
// インスタンスを生成します。
var photoBase:PhotoBase = new PhotoBase();
photoBase.x = 100;
photoBase.y = 20;
// インスタンスを生成します。
var closeButton:CloseButton = new CloseButton();
closeButton.x = 507;
closeButton.y = 30;
// インスタンスを生成します。
var backButton:BackButton = new BackButton();
backButton.x = 30;
backButton.y = 220;
// インスタンスを生成します。
var nextButton:NextButton = new NextButton();
nextButton.x = 570;
nextButton.y = 220;
// インスタンスを生成します。
var americanPhoto:AmericanPhoto = new AmericanPhoto();
americanPhoto.x = 120;
americanPhoto.y = 40;
// インスタンスを生成します。
var americanText:AmericanText = new AmericanText();
americanText.x = 119;
americanText.y = 354;
次に、
// americanシーンの表示オブジェクトの表示設定を行います。
american.onSceneLoad = function():void {
this.addCommand(
new AddChild( this.container , photoBG ),
new AddChild( this.container , closeButton ),
new AddChild( this.container , photoBase ),
new AddChild( this.container , backButton ),
new AddChild( this.container , nextButton ),
new AddChild( this.container , americanPhoto ),
new AddChild( this.container , americanText )
);
}
続いて、
// americanシーンの表示オブジェクトの削除設定を行います。
american.onSceneUnload = function():void {
this.addCommand(
new RemoveChild( this.container , photoBG ),
new RemoveChild( this.container , closeButton ),
new RemoveChild( this.container , photoBase ),
new RemoveChild( this.container , backButton ),
new RemoveChild( this.container , nextButton ),
new RemoveChild( this.container , americanPhoto ),
new RemoveChild( this.container , americanText )
);
}
ここまで設定が完了したら、
data:image/s3,"s3://crabby-images/96e39/96e396eff3cc37c8e2769c6ef3ecb16c5ddfc52d" alt="図14 表示オブジェクト確認 図14 表示オブジェクト確認"
表示オブジェクトの削除設定
表示オブジェクトの削除処理は設定しましたが、
data:image/s3,"s3://crabby-images/14682/146824e8cdf74f154b2a46b9828e1a74b405aa35" alt="図15 シーンパスの設定 図15 シーンパスの設定"
設定が完了したら、
data:image/s3,"s3://crabby-images/795f5/795f5a9153f55c6f530d05b326380f066b433668" alt="図16 「CloseButton」の遷移確認 図16 「CloseButton」の遷移確認"
上位シーンでの削除処理
「american」
「gallery」
// 共通部分の表示オブジェクトの削除処理を行います。
gallery.onSceneInit = function():void {
this.addCommand(
new RemoveChild( this.container , photoBG ),
new RemoveChild( this.container , closeButton ),
new RemoveChild( this.container , photoBase ),
new RemoveChild( this.container , backButton ),
new RemoveChild( this.container , nextButton )
);
}
「american」
// americanシーンの表示オブジェクトの削除設定を行います。
american.onSceneUnload = function():void {
this.addCommand(
new RemoveChild( this.container , americanPhoto ),
new RemoveChild( this.container , americanText )
);
}
設定が完了したら、
「american」
// インスタンスを生成します。
var frenchPhoto:FrenchPhoto = new FrenchPhoto ();
frenchPhoto.x = 120;
frenchPhoto.y = 40;
// インスタンスを生成します。
var frenchText:FrenchText = new FrenchText ();
frenchText.x = 119;
frenchText.y = 354;
// frenchシーンの表示オブジェクトの表示設定を行います。
french.onSceneLoad = function():void {
this.addCommand(
new AddChild( this.container , photoBG ),
new AddChild( this.container , closeButton ),
new AddChild( this.container , photoBase ),
new AddChild( this.container , backButton ),
new AddChild( this.container , nextButton ),
new AddChild( this.container , frenchPhoto ),
new AddChild( this.container , frenchText )
);
}
// frenchシーンの表示オブジェクトの削除設定を行います。
french.onSceneUnload = function():void {
this.addCommand(
new RemoveChild( this.container , frenchPhoto ),
new RemoveChild( this.container , frenchText )
);
}
// インスタンスを生成します。
var mamePhoto:MamePhoto = new MamePhoto ();
mamePhoto.x = 120;
mamePhoto.y = 40;
// インスタンスを生成します。
var mameText:MameText = new MameText ();
mameText.x = 119;
mameText.y = 354;
// mameシーンの表示オブジェクトの表示設定を行います。
mame.onSceneLoad = function():void {
this.addCommand(
new AddChild( this.container , photoBG ),
new AddChild( this.container , closeButton ),
new AddChild( this.container , photoBase ),
new AddChild( this.container , backButton ),
new AddChild( this.container , nextButton ),
new AddChild( this.container , mamePhoto),
new AddChild( this.container , mameText)
);
}
// mameシーンの表示オブジェクトの削除設定を行います。
mame.onSceneUnload = function():void {
this.addCommand(
new RemoveChild( this.container , mamePhoto),
new RemoveChild( this.container , mameText)
);
}
設定が完了したら、
data:image/s3,"s3://crabby-images/cd29b/cd29bd0dbc9565855219f2d19e97ada0e08386f2" alt="図17 「french」表示オブジェクトの確認 図17 「french」表示オブジェクトの確認"
data:image/s3,"s3://crabby-images/ada29/ada292e0e89021095afda9ec37b8e3d4fa1264dd" alt="図18 「mame」表示オブジェクトの確認 図18 「mame」表示オブジェクトの確認"
ボタンの設定
今は、
まず、
「scenePath」
「RollOverButton」
data:image/s3,"s3://crabby-images/79104/791048c716abac1abcc49e16020b2a539551dc12" alt="図19 「BackButton」の設定 図19 「BackButton」の設定"
次に
data:image/s3,"s3://crabby-images/2aae3/2aae39b7bd2da6fc4199797d21209e8a08adfa70" alt="図20 「NextButton」の設定 図20 「NextButton」の設定"
設定が完了したら、
「BackButton」
まず、
// americanシーンの表示オブジェクトの表示設定を行います。
american.onSceneLoad = function():void {
// scenePath の設定を行います。
backButton.back.scenePath = "/index/gallery/mame";
nextButton.next.scenePath = "/index/gallery/french";
this.addCommand(
new AddChild( this.container , photoBG ),
new AddChild( this.container , closeButton ),
new AddChild( this.container , photoBase ),
new AddChild( this.container , backButton ),
new AddChild( this.container , nextButton ),
new AddChild( this.container , americanPhoto ),
new AddChild( this.container , americanText )
);
}
続いて
// frenchシーンの表示オブジェクトの表示設定を行います。
french.onSceneLoad = function():void {
// scenePath の設定を行います。
backButton.back.scenePath = "/index/gallery/american";
nextButton.next.scenePath = "/index/gallery/mame";
this.addCommand(
new AddChild( this.container , photoBG ),
new AddChild( this.container , closeButton ),
new AddChild( this.container , photoBase ),
new AddChild( this.container , backButton ),
new AddChild( this.container , nextButton ),
new AddChild( this.container , frenchPhoto ),
new AddChild( this.container , frenchText )
);
}
最後に、
// mameシーンの表示オブジェクトの表示設定を行います。
mame.onSceneLoad = function():void {
// scenePath の設定を行います。
backButton.back.scenePath = "/index/gallery/french";
nextButton.next.scenePath = "/index/gallery/american";
this.addCommand(
new AddChild( this.container , photoBG ),
new AddChild( this.container , closeButton ),
new AddChild( this.container , photoBase ),
new AddChild( this.container , backButton ),
new AddChild( this.container , nextButton ),
new AddChild( this.container , mamePhoto ),
new AddChild( this.container , mameText )
);
}
設定が完了したら、
data:image/s3,"s3://crabby-images/2a6d0/2a6d0a0f21c58e54f2cbce822968d39846311fc2" alt="図21 シーン遷移の確認 図21 シーン遷移の確認"
プリローダーの作成
最後にプリローダーを作成しましょう。[Project_
「Preloader」
読み込み中に表示するテキストをステージに貼り付けましょう。
data:image/s3,"s3://crabby-images/ab89f/ab89fc53035f67ca3984694446681b9b5fbbaed7" alt="図22 固定文字の設定 図22 固定文字の設定"
「init」
data:image/s3,"s3://crabby-images/5d580/5d580ebc391bf8d95ef65fe2c3926d823176c829" alt="図23 読み込み失敗時の文言 図23 読み込み失敗時の文言"
次に読み込み状態を示す
data:image/s3,"s3://crabby-images/644c5/644c511ffba0a6c3646ea4cfb36c01cdbdac20dd" alt="図24 「ProgressBar」の作成 図24 「ProgressBar」の作成"
続いて、
data:image/s3,"s3://crabby-images/ca6ac/ca6ac82fde80d7287553820ae45b29172bc195f0" alt="図25 「ProgressPer」の作成 図25 「ProgressBar」の作成"
作成したシンボルをステージに貼り付けていきましょう。タイムライン上に
data:image/s3,"s3://crabby-images/5aae7/5aae7259e1c71ef70f24f02706f584186423eb31" alt="図26 「ProgressBar」の設置 図26 「ProgressBar」の設置"
読み込み状態に合わせて、
data:image/s3,"s3://crabby-images/eaddd/eaddd4df8297eae5a88cce11394dc3bed9a6b9f3" alt="図27 読み込み中アニメーションの設定 図27 読み込み中アニメーションの設定"
読み込みが完了すると、
data:image/s3,"s3://crabby-images/2ef06/2ef0603fd8c56807f7e6e553ff62c05a3a491497" alt="図28 「ProgressBar」を表示しない 図28 「ProgressBar」を表示しない"
続いて、
「ProgressPer」
data:image/s3,"s3://crabby-images/ce436/ce436247b22cb8e7bfd353d6f419cf4e2487de81" alt="図29 「ProgressPer」の設置 図29 「ProgressPer」の設置"
読み込み状態をパーセントで表示するために、
読み込み開始から読み込み完了までは、
// フレーム毎にテキストの値を変更します。
addEventListener( Event.ENTER_FRAME , perText );
function perText( e:Event ):void {
// 現在フレームが50を超えたら、イベントリスナーを削除します。
if( currentFrame > 50 ) {
removeEventListener( Event.ENTER_FRAME , perText );
}
// ProgressPerにパーセンテージを設定します。
pp.per.text = String( currentFrame * 2 - 2 ) + "%";
}
設定が完了したら、
data:image/s3,"s3://crabby-images/3c40d/3c40db07cc8d7ed3b5e2a1fa66052e8be665d9c0" alt="図30 プリローダー確認 図30 プリローダー確認"
プリローダーの読み込み状態が100%になると、
まとめ
タイムラインスタイルでの制作は以上になります。今回の制作では、
なお、