• 締切済み

一定時間が経過した後のフレーム移動について

Flash初心者です。うまく質問したいことが伝わるか心配ですが、どうぞ宜しくお願いします。 タブメニュー型のムービーを作成していまして、10秒経過すると次のタブが開き、 また10秒すると次のタブが開く…。このループです。 タブの数は4つ。1フレームごとにそれぞれのタブが開いているように画像で見せておいて(計4フレームを使用)、 スクリプトで10秒の間隔をおき、次のフレームに移動させる仕組みになっています。 タブにはクリックできるようにボタンが仕込んであり、クリックするとムービーの流れ(再生されている順)に関係なく、 そのタブに移動します(2つ目のタブなら2フレーム目を再生)。 (タブの部分のテキスト、タブが開いたときに表示されるバナー画像は外部読み込みになっています。 ただ、この外部読み込みに関しては質問の内容に影響しないと思いますので詳しくは説明しないでおきます。) スクリプトは下記のとおりです。(注:教えて!gooにあったものを使わせていただきました。) ※1フレーム目 --------------------------------------------------------------------- this.stop(); timerID = setInterval(startMovie, 10000); function startMovie() { gotoAndPlay(2); clearInterval(timerID); } ※2フレーム目 --------------------------------------------------------------------- this.stop(); timerID2 = setInterval(startMovie2, 10000); function startMovie2() { gotoAndPlay(3); clearInterval(timerID2); } ※3フレーム目 --------------------------------------------------------------------- this.stop(); timerID3 = setInterval(startMovie3, 10000); function startMovie3() { gotoAndPlay(4); clearInterval(timerID3); } ※4フレーム目 --------------------------------------------------------------------- this.stop(); timerID4 = setInterval(startMovie4, 10000); function startMovie4() { gotoAndPlay(1); clearInterval(timerID4); } これでちゃんと10秒経過すると次のフレームに移動し、それがループされるのですが 問題は、途中で順に再生されているタブと違うタブをクリックしたときに起こります。 一度、その再生順がクリックすることによって変わってしまうと、元々の『10秒後に次のフレームへの移動』の動きと、 クリックされたタブから『10秒後に次のフレームへの移動』の動きが重複しているようなんです。 ちゃんと確認できたわけではありませんが、複数回これを繰り返すと4つのタブがかなりの速度でパッパッパと遷移し、 まともに見ることすらできないものになってしまいます。 解決したいのは、クリックしたタブ(移動したフレーム)から新たに10秒がカウントされ、10秒後には次のフレームに移動し 10秒経過する前に他のタブをクリックしたときでも、そのタブ(フレーム)に移動してからまた新たに10秒がカウントされる…。 このようにするにはどうしたらいいでしょうか? どうぞご教示ください。

  • Flash
  • 回答数1
  • ありがとう数1

みんなの回答

  • perse
  • ベストアンサー率74% (113/152)
回答No.1

1フレームが1つのタブならgotoAndPlayではなくてgotoAndStopでは無いでしょうか? とりあえずコンナ感じでどうでしょうか? タブへ移動するボタンのインスタンス名をtab1_btn~tab4_btnとして 1~4フレーム目にそれぞれ配置して以下のASを1フレーム目に記述してください。 this.stop(); //タブが移動する間隔 (ミリ秒) t = 10000; //タブのフレーム位置 var tab1 = 1; //タブ1は1フレーム目 var tab2 = 2; var tab3 = 3; var tab4 = 4; //次に移動するタブ var nexttab = tab2; var id; //再びこのフレームが表示されたとき用 clearInterval(id); //tミリ秒後に次のタブへ移動するようにsetInterval id = setInterval(startMovie, t); //タブ1クリック時 tab1_btn.onRelease = function() { //押したタブへフレーム移動 _root.gotoAndStop(tab1); //setInterval取り消し clearInterval(_root.id); //次に移動するフレーム _root.nexttab = tab2; //setInterval設定 _root.id = setInterval(startMovie, t); }; //以下同様 tab2_btn.onRelease = function() { _root.gotoAndStop(tab2); clearInterval(_root.id); _root.nexttab = tab3; _root.id = setInterval(startMovie, t); }; tab3_btn.onRelease = function() { _root.gotoAndStop(tab3); clearInterval(_root.id); _root.nexttab = tab4; _root.id = setInterval(startMovie, t); }; tab4_btn.onRelease = function() { _root.gotoAndStop(tab4); clearInterval(_root.id); _root.nexttab = tab1; _root.id = setInterval(startMovie, t); }; //フレーム移動関数 tミリ秒間隔で実行される function startMovie() { //フレーム移動 _root.gotoAndStop(_root.nexttab); _root.nexttab++; if (_root.nexttab>_root.tab4) { _root.nexttab = _root.tab1; } }

ishippy
質問者

お礼

早速、お答えをいただきましてありがとうございます。 ご教示いただいたASで新たにムービーを作ってみたのですが 思ったようなムービーになりませんでした。 ただ、10秒なら10秒を、タイムラインで時間を取るようにする (12fpsなので10秒は120フレームまでフレームを取る) 方法で、今回のこのムービーを作成し、なんとか自分が 思い描いていたものが作れました。 考え方として、今回、お教えいただいた方法は非常に参考に なりました。本当にありがとうございました。

関連するQ&A

  • 数秒後に別フレームにとばす方法

    1フレーム目で画像を読み込み10秒表示させた後に2フレーム目でまた10秒表示させるといった事を試しています。 表示させる画像はムービークリップで最後の1秒でフェードアウトさせるようにしているのですが 完全にフェードアウトする前に2フレーム目に飛んでしまいます。 何か解決方法はないのでしょうか?? 1フレーム目 ---------------------------------------------------------- this.stop(); timerID = setInterval(startMovie, 10000); function startMovie() { clearInterval(timerID); gotoAndStop(2); } 2フレーム目 ---------------------------------------------------------- this.stop(); timerID = setInterval(startMovie, 10000); function startMovie() { clearInterval(timerID); gotoAndStop(1); } ちなみにgotoAndStop();を消すとそのフレームでループしますが完全にフェードアウトしてくれます…。

    • ベストアンサー
    • Flash
  • 一定時間停止後フレーム移動

    初心者ですがよろしくお願いします。 ActionScript3.0にて 一定時間後に任意のフレームまで戻るを実行したいのですが 一定時間止まらずにフレームまで戻ってしまいます。 下記の記述は間違ってますか? 一定時間停止の記述法は色々あるみたいですが いくつかやってみたところエラーばっか出て動きませんでした。 この記述だとちゃんと停止するのですが gotoAndPlay(10); を付けると停止しません。 this.stop(); this.iid = setInterval (function (m) { m.play (); clearInterval (m.iid); }, 3000, this); gotoAndPlay(10);

    • ベストアンサー
    • Flash
  • スライドの表示とアクションスクリプトの関連

    こんにちわ。 現在、プレゼン風のスライドを作成しております。 親スライドがあり、その下に子スライドを数個作成しております。また、その子スライドにアクションを配置した仕様にしております。 また、アクションは、以前にこちらのサイトで教えていただきました、時間指定のアクションなのですが、子スライド2が表示されて数秒後に子スライド2内の指定のフレームに移動するアクションスクリプトを記述しています。というか、そういう風にしたいと想っています。 親スライド   |   子スライド1ー静止画   |   子スライド2-時間指定のスクリプト this.stop(); timerID = setInterval(startMovie, 28000); timerID2 = setInterval(startMovie2, 31000); function startMovie() { gotoAndPlay(5); clearInterval(timerID); } function startMovie2() { gotoAndPlay(10); clearInterval(timerID2); } 上記スクリプトは、子スライド2内の1フレーム目に記述しています。 また、各スライドの切り替えは、mediaDisplayのパラメーターで映像に合わせて、時間指定で切り替えています。 上記、スクリプトは稼動するのですが、スライド2が表示されてからではなく、全体が再生されてからの時間で動いてしまいます。 ですので、スライド1が表示されている裏でスライド2のアクションが動いてる感じです。 スライド2が表示されてから、アクションスクリプトが動くようになるには、どういう風に指定すればよいのでしょうか? ほかのとこでも聞いたのですが、ちょっと利き方が悪いのか、お返事がなくて。。。

  • スライドプレゼンテーション機能を使ったときのボタンでのスライド移動

    こんにちわ。 FLASH8のスライドプレゼンテーション機能を使用して、映像とリンクしたプレゼンテーションを作成しています。 仕様としては、各スクリーンにフレームアクションを作成し、 各スクリーンにスクリプトを記述し、フレームを時間制御しています。 スクリーンの時間制御スクリプト: on (reveal) { timerID3 = setInterval(startMovie3, 31000); timerID4 = setInterval(startMovie4, 38000); function startMovie3() { trace("31秒待った"); trace([currentSlide, currentSlide.gotoNextSlide]); // 確認用に追加 rootSlide.currentSlide.gotoAndPlay(10); clearInterval(timerID3); } function startMovie4() { trace("38秒待った"); trace([currentSlide, currentSlide.gotoNextSlide]); // 確認用に追加 rootSlide.currentSlide.gotoAndPlay(15); clearInterval(timerID4);} } 上記をスクリーンに記述して、各スライドのフレームを制御しています。状況としては、こんな感じなのですが、問題は、一度ボタンでスライドを移動し、そのスクリプトの全ての時間指定が終了する前に、違うスライドへボタンで移動した場合、前のスライドのスクリーンに記述した時間指定のスクリプトも一緒に裏で動き前のスライドに記述した時間にあわせて、現表示されているフレームも稼動してしまいます。 トレースの状況としては、 28秒待った _level0.bg.controls.slide02,[type Function] 31秒待った _level0.bg.controls.slide02,[type Function] 37秒待った null,undefined 38秒待った _level0.bg.controls.slide02,[type Function] 一度スライドをボタンで選択しても、違うスライドを選択した時点で前のスライドのスクリプトを無効なりに制御する方法はありませんでしょうか?何卒、よろしくお願いいたします。

  • jsのスライドショーのボタンの時間制御について

    jsのスライドショーについて質問です。 メイン画像とサムネール画像が連動していて、5秒間で次の画像及びサムネールに自動的にスライドするというものを作りました。そして、Prevボタンやnextボタンをつけ、クリックと、手動で次のスライドに移るようにしました。 これに、切り替わったスライドから5秒間止まり次の画像に切り替わるという設定を加えたいのですが、うまくいきません。自動再生中の4秒後にボタンをクリックすると、次のスライドが1秒で、また次のスライドに切り替わってしまうのです。 どうか方法を教えてください。 <スクリプト> //自動再生 var timerID = setInterval(function(){ $('#thumbsNext').click(); },5000); $('#gallery ul').hover(function(){ clearInterval(timerID); }, function(){ timerID = setInterval(show, 5000); // マウスアウト時にスライドショーを再開 }); function show(){ $('#thumbsInner').animate({ marginLeft:parseInt($('#thumbsInner').css('margin-left'))-248+'px' },'slow','swing', function(){ $('#thumbsInner').css('margin-left','-248px'); $('#thumbsInner ul li:first').appendTo('#thumbsInner ul'); $('#thumbsList .active').next().click(); }); }

  • 簡単なサンプルが動かないのはなぜ?

    超初心者です。 自力でがんばろうと、いろんなBBSの過去記事を除きやってるのですが 動きません。 たとえば //timerObjオブジェクトの設定 timerObj = new Object(); timerObj.timeout = function() { clearInterval(timerID); // インターバルの終了 }; //計測開始(5秒でタイムアウト) var timerID = setInterval(timerObj, "timeout", 5000); このようなサンプルを見つけ5秒間待つアクションを ちゃんとフレームアクションに入れました でも希望のとおり動きません。 初めは「制御」メニューのシンプルアクションをONにするのを知らずに やっていましたが、今は分かっています。 STOP(); だけのフレームアクションは利いていますので。。。 ちなみに //timerObjオブジェクトの設定 timerObj = new Object(); timerObj.timeout = function() { clearInterval(timerID); // インターバルの終了 stop(); }; //計測開始(5秒でタイムアウト) var timerID = setInterval(timerObj, "timeout", 5000); こうやってstop();をつけてもそこではとまりません。 シンタックスのエラーもないということは 何か設定かがおかしいのかもしれません。 もちろんキーフレームになっています。 もうちんぷんかんぷんです。 どなたかお助けを・・・・ VBAのソフト開発などはそれなりにしています。 なんでこんなこともわからんのか自己嫌悪になっております。

    • ベストアンサー
    • Flash
  • mcの中のフレームラベルの移動

    初めまして。 当方初心者なので、よくわからないので、質問させていただきます。 外部にswfとしてフレームラベルの複数ついたものがあって、 それをmc(mcs_mc)で読み込みし、スクリプトで一定時間毎に mcに読み込んだ外部swfのフレームラベル(chapter1~chapter10)を移動させたいのですが、うまく動いてくれません。 どの用にしたらよいでしょう?よろしくお願いします。 onClipEvent(load){ this._lockroot = true; } onClipEvent(enterFrame){ setInterval( function(){ mcs_mc.gotoAndPlay("chapter2"); }, 1000); }

    • ベストアンサー
    • Flash
  • gotoAndPlayで特定のフレームまで移動した後gotoAndStop

    ひとつのボタンのスクリプトで gotoAndPlayで特定のフレームまで移動した後に、 gotoAndStopでフレームを移動することはできますか? たとえば、 on (press) { gotoAndPlay(7); (14フレームまで再生した後) gotoAndstop(20); } といった内容です。 よろしくお願いします。

    • ベストアンサー
    • Flash
  • Actionscriptでのフレーム間の移動

    // ここで実際に○を移動させる Pofmaru1(l); Pofmaru2(r); // maru1を移動させる関数Pofmaru1 function Pofmaru1(l) { if (l == 1) { gotoAndPlay("maru1",2); }else if (l == 2) { ・・・・・・ // maru2を移動させる関数Pofmaru2 function Pofmaru2(r) { if (r == 1) { gotoAndPlay("maru2",2); }else if (r == 2) { ........ maru1を移動させる処理を呼んで、gotoAndplayでmaru1レイヤーの2フレーム目へ飛び、2フレーム目が再生されたら、次にクイックソートのプログラムに戻り、関数 Pofmaru2(r); を処理するようにしたいのですが、うまくいきません。C言語であれば普通if文の処理がされたら自動でプログラムに戻ってきて、Pofmaru2(r);の処理へ移ると思うのですが....Actionscriptはそうならないのでしょうか? ネットや本などで色々調べてみたのですが解決策が見つからず行き詰ってしまって困っています。 flash mxでプログラム通りにフレーム間を移動するようにするのは無理なのでしょうか?

  • flashを一定時間停止させる方法について

    flashで画像ボタンをスクロールさせて表示するメニューボタンを作ろうとしています。 画像ボタンは1つ移動するごとに3秒停止し、3秒経つと横に移動し、 次の画像ボタンが現れ、また3秒停止する、といった動きを繰り返すようにしました。 ここまではできたのですが、 押したい画像ボタンが現れるまで待つのが面倒な場合を考慮し、 メニューの左右にスクロールを進めるためのボタンを付けたところ、 停止の挙動がおかしくなってしまいます。 スクロールを進めるためのボタンを押さなければ正常に 3秒経って画像ボタンが移動するという動きを続けてくれるのですが、 スクロールを進めるボタンを押すと、その後の一時停止が0.5秒くらいになったり 1秒くらいになったりと、指定通りの動きをしなくなってしまいます。 どうすれば正常に動かすことができるのでしょうか? 現状では下記のスクリプトを空白キーフレームに入れて動かしています。 stop(); stopID = setInterval(stopFRAME,3000); function stopFRAME() { clearInterval(stopID); play(); } よろしくお願いします。

    • ベストアンサー
    • Flash

専門家に質問してみよう