新・元地方の中規模印刷会社で苦悩するWebデザイナー改めWebディレクターの日記

自由な20代、窮屈な30代を経て、遂に40代になっちまったWebディレクター&パソコン講師の覚書と思う言(こと)。略称【ちほちゅう】

*

Flashの上にHTMLオブジェクトを配置する方法

   

  • このエントリーをはてなブックマークに追加

1年以上前の記事です。内容が古い可能性があります。

デザイナーからちょっとした注文が入ったので久しぶりにFlashをいじってみた。
Flashのコンテンツの上にHTMLのボタンを配置したいらしい。

Flashの上にHTML失敗
何も設定しないとこういった形でFlashが上に出てしまう。

スポンサーリンク
 

これは実は簡単で、Flashを透明にして、あとはCSSのz-indexで上下関係を設定してあげれば良い。
Flashの上にJavaScript(JQuery)で作られたプルダウンメニューを配置する際に頻繁に利用していた。

具体的には

  1. 上に乗せたいHTMLのオブジェクトにCSSで「z-index:1」と設定する。
  2. Flashのパラメータ「wmode」を「transparent(透明)」に設定する。

といった流れ。

HTMLオブジェクトに「z-index:1」を設定するのは簡単だと思うので端折ります。
問題はFlashのパラメータ「wmode」を「transparent(透明)」に設定する方法。

Dreamweaver(ドリームウィーバー)をお持ちの方は該当のFlashを選んで以下のように設定すればOK。
DreamweaverでのFlashのパラメータ設定

ただ、最近はFlashを使うときはswfobject使うことが多い。
swfobjectを使った上での設定は以下のように直接Javascriptを修正すればOK。

<script type=”text/javascript”>
<!–
var so = new SWFObject(“images/top.swf”, “できない。わからない。プロットファクトリーが解決します。”, “700”, “230”, “7”, “#ffffff”);
so.write(“flashcontents”);
 // –>
</script>

<script type=”text/javascript”>
<!–
var so = new SWFObject(“images/top.swf”, “できない。わからない。プロットファクトリーが解決します。”, “700”, “230”, “7”, “#ffffff”);
so.addParam(“wmode”, “transparent”);
so.write(“flashcontents”);
 // –>
</script>

太字の部分を追加してあげれば良いということになる。

なお、通常のFlashの場合でもソースレベルで修正は当然可能。
念のため、そのソースも引用させて頂きます。
(上記、Dreamweaverを使ってやる方法で生成されるソースとなります。)

<object classid=”clsid:D27CDB6E-AE6D-11cf-96B8-444553540000″ codebase=”http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,28,0″ width=”700″ height=”230″ title=”パソコン教室”>
        <param name=”movie” value=”images/top.swf” />
        <param name=”quality” value=”high” />
        <embed src=”images/top.swf” quality=”high” pluginspage=”http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash” type=”application/x-shockwave-flash” width=”700″ height=”230″></embed>
      </object>

<object classid=”clsid:D27CDB6E-AE6D-11cf-96B8-444553540000″ codebase=”http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=9,0,28,0″ width=”700″ height=”230″ title=”パソコン教室”>
        <param name=”movie” value=”images/top.swf” />
        <param name=”quality” value=”high” />
        <param name=”wmode” value=”transparent” />
        <embed src=”images/top.swf” width=”700″ height=”230″ quality=”high” pluginspage=”http://www.adobe.com/shockwave/download/download.cgi?P1_Prod_Version=ShockwaveFlash” type=”application/x-shockwave-flash” wmode=”transparent”></embed>
      </object>

こちらも太字の部分を追加すれば良いということになる。

まとめると、
swfobjectを使った場合はJavaScript内に「so.addParam(“wmode”, “transparent”);」を記入。
objectタグを使った場合はparamタグ「<param name=”wmode” value=”transparent” />」を記入。
embedタグを使った場合はembetタグ内に属性「wmode=”transparent”」を記入。
と言った形になる。

で、うまくいくと以下のようにFlashの上にHTMLで書いたメニューが表示されるようになる。
Flashの上にHTML成功

まあ、無理にFlashの上にHTMLのオブジェクトを乗せるなんてことしなくても、Flash内にすべて入れ込んじゃえばいいと考える人もいる筈。
ただ、SEOを考えた場合はそうしないほうがいい場合もあるんですよねぇ。

 - FLASH, 覚え書き

アドセンス広告メイン

Message

メールアドレスが公開されることはありません。

  関連記事

こまめに電源を切るよりもスリープモードが節電になる

1年以上前の記事です。内容が古い可能性があります。以前、モニターの色は白が節電に …

自分を自分の作ったリストに入れたり外したりする方法(ツイッター)

1年以上前の記事です。内容が古い可能性があります。いつの間にやらつぶくま自身がつ …

no image
オンライン決済(電子決済)方法一覧

1年以上前の記事です。内容が古い可能性があります。最近、あちらこちらからオンライ …

no image
使わなくなったデータCDどうする?

1年以上前の記事です。内容が古い可能性があります。「個人情報保護法」なんてのが施 …

no image
子供向け最強集客ツール

1年以上前の記事です。内容が古い可能性があります。連休中に子供とちょっとお出かけ …

Graffiti(グラフィティ)入力とはなんのこと?

1年以上前の記事です。内容が古い可能性があります。ちょっと前にあるニュースで見か …

地震の予兆現象、光柱(発光現象)、彩雲(虹)、地震雲

1年以上前の記事です。内容が古い可能性があります。先日の北海道で震度5弱を記録し …

やっぱりフォローしないと外される。「つぶくま」は100%リフォローします【ツイッター】

1年以上前の記事です。内容が古い可能性があります。熊谷市のツイッターポータルサイ …

「NISA(ニーサ)」とは「NEET(ニート)」とも「ニーソ」とも違う投資非課税制度だった

1年以上前の記事です。内容が古い可能性があります。新語・流行語大賞で初めて聞いた …

スパムのターゲットにされたので「Akismet」を導入した【WordPress】 #wp

1年以上前の記事です。内容が古い可能性があります。WordPress(ワードプレ …

血液型オヤジ