- 締切済み
フラッシュのスライドメニューにリンクを張る方法
FKASH CS3 でパソコンはマックです。 フラッシュでJPEGの画像を三枚並べて、横にスライドさせるだけの 簡単なフラッシュを作りました。 その三枚の画像をスライドさせているのですが その画像の一枚一枚にリンクを貼りたいのですが どうしたらいいのかわからくて・・・ アクションスクリプトのプログラミング初心者です。 わかる方おられましたら 是非教えてください! よろしくお願い致します。
- みんなの回答 (1)
- 専門家の回答
みんなの回答
- BlurFiltan
- ベストアンサー率91% (1611/1754)
「三兎追うものは一兎をも得ず」というわけで, とりあえず, 「動くこと」は「動くこと」,「リンク」は「リンク」,別々に考えましょう。 そして, 「3枚のJPEG」ではなく「1枚のJPEG」で考えましょう。 「新規ドキュメント」作成状態からです。 というわけで, 「新規ドキュメント」のステージ上に静止させた(つまり何もしない),JPEGを1枚だけ用意します。 そして, ステージ上のそのJPEGを選択した状態で, 「修正」→「シンボルに変換」より,「ボタン」または「ムービークリップ」に変換します。 変換するシンボルは「ボタン」でも「ムービークリップ」でもどちらでも良い(都合によって変える)のですが, この話の都合上,ここでは「ボタン」に変換したことにしておきます。 以下は,ActionScript のバージョンや, パブリッシュするSWFの Flash Player のバージョンによって変わります。 ◎ 場合1 ActionScript 1.0 (Flash Lite 1.x など対応版) この「場合1」は, 「ファイル」→「パブリッシュ設定」で「Flash」タブを選択し, スクリプトを ActionScript 1.0 に設定してした場合です。 上で作成したJPEG入りボタンを選択した状態で「アクション」パネルを表示させます。 そしてその「アクション」パネルに次のようなスクリプトを書きます。 //---------------------------------- //このボタンをクリックしたとき on (release) { //「AAA.html」を同窓で開く getURL("AAA.html", "_self"); } //---------------------------------- 「AAA.html」の部分はリンクさせたいページに変えてください。 http:// から始まるリンクでもかまいません。 「_self」の部分を「_blank」にすると,リンク先が別窓で開くようになります。 ちなみに, 一応これは ActionScript 1.0 を想定していますが, Flash Liate 1.x などを考えない場合は ActionScript 2.0 に設定していても大丈夫です。 ◎ 場合2 ActionScript 2.0 (場合1 で書いたスクリプトは消してください。) この「場合2」は, 「ファイル」→「パブリッシュ設定」で「Flash」タブを選択し, スクリプトを ActionScript 2.0 に設定してした場合です。 上で作成したJPEG入りボタンを選択した状態で「プロパティ」パネルを表示させます。 ※「アクション」パネル ではなく,「プロパティ」パネル です。 その「プロパティ」パネル の, [ <インスタンス名> ] のようになっている入力可能部分でボタンにインスタンス名を付けます。 ここでは「my_btn」(全て半角) というインスタンス名を付けることにしておきます。 その「my_btn」と命名したボタンのあるレイヤーとは別にActionScriptを書くために新規レイヤーを挿入します。 その新規レイヤーのキーフレームを選択した状態で「アクション」パネルを表示させます。 そしてその「アクション」パネルに次のようなスクリプトを書きます。 //---------------------------------- //「my_btn」クリック時に動作するイベントハンドラメソッドを定義 my_btn.onRelease = function():Void{ //「AAA.html」を同窓で開く getURL("AAA.html", "_self"); } //---------------------------------- 「AAA.html」の部分はリンクさせたいページに変えてください。 http:// から始まるリンクでもかまいません。 「_self」の部分を「_blank」にすると,リンク先が別窓で開くようになります。 ◎ 場合3 ActionScript 3.0 (場合1 や 場合2 で書いたスクリプトは消してください。) この「場合3」は, 「ファイル」→「パブリッシュ設定」で「Flash」タブを選択し, スクリプトを ActionScript 3.0 に設定してした場合です。 場合2 と同様, 上で作成したJPEG入りボタンを選択した状態で「プロパティ」パネルを表示させ, [ <インスタンス名> ] のようになっている入力可能部分でボタンにインスタンス名を付けます。 ここでは「my_btn」(全て半角) というインスタンス名を付けることにしておきます。 そしてこれまた 場合2 と同様, その「my_btn」と命名したボタンのあるレイヤーとは別にActionScriptを書くために新規レイヤーを挿入します。 (場合2 ですでに作成してあれば新規に作成する必要はありません。そのままのレイヤーを使用してください。) その新規レイヤーのキーフレームを選択した状態で「アクション」パネルに次のようなスクリプトを書きます。 //---------------------------------- //「my_btn」クリック時に 関数btnClickを実行 my_btn.addEventListener(MouseEvent.CLICK,btnClick); //関数btnClickの定義 function btnClick(e:MouseEvent):void { //リンク先URLのリクエストを作成 var my_req:URLRequest=new URLRequest("AAA.html"); //リクエスト先を同窓で開く navigateToURL(my_req); } //---------------------------------- 「AAA.html」の部分はリンクさせたいページに変えてください。 http:// から始まるリンクでもかまいません。 「_self」の部分を「_blank」にすると,リンク先が別窓で開くようになります。 場合1~3 のうちいずれかの方法で作成したボタンを3つ作り, その3つのボタンをスライド移動させれば良いと思います。 ただし, 場合2 または 場合3 のようにしてインスタンス名を付けたボタンを まとめて1つのムービークリップに変換して, そのムービークリップをスライド的に動かす場合は, そのムービークリップにもインスタンス名を付けて(例えば「my_mc」), スクリプトの my_btn.onRelease や my_btn.addEventListener(MouseEvent.CLICK,btnClick); の部分を my_mc.my_btn.onRelease や my_mc.my_btn.addEventListener(MouseEvent.CLICK,btnClick); のように変更する必要があります。 今回は場合1~3のような複数の場合を書きましたが 普通はそんな回答はできないので, パブリッシュする「ActionScript のバージョン」 や 「SWF の Flash Player のバージョン」 を決めて明記した上で質問するようにしてください。 でないと,無回答であったり,トンチンカンな回答が付くだけの場合が多いです。(または,私みたいな者から「状況がわからん!」 と説教を受けるかですね。)