您的位置:首页 > Web前端 > JavaScript

JS与Flash相互调用

2014-07-30 10:38 316 查看
HTML中添加Flash:

<object class="djs"
id="FlashID" classid="clsid:D27CDB6E-AE6D-11CF-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0" width="88" height="88" border="0">

<param name="movie" value="images/daojishi.swf">

<param name="quality" value="High">

<param name="loop" value="false">

<param name="wmode" value="transparent" />

<embed id="FlashID" src="images/daojishi.swf"
wmode="transparent" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" name="obj1" width="88" height="88" quality="High" loop="false">

</object>

说明:

<param name="wmode" value="transparent" /> :显示flash背景透明

给object和embed添加相同的ID:如果你省略了embed标签,那firefox就不能识别你的flash了

flash使用的actionscript跟javascript是非常相通的,下面描述如何互相调用函数:

1:javascript调用flash中的函数

在flash的脚本中增加

代码:import flash.external.ExternalInterface;

假定要调用的函数是hello,as代码如下

代码:function hello(){

return
"hello";

}

ExternalInterface.addCallback("hello", this, hello);

//第一个参数为导出函数名,第三个参数为as的函数名

这样就可以在js中调用as的hello函数了

2:flash调用js的函数

ExternalInterface.call("hello2", "jacky");

//第一个参数是js的函数名,后面的是js函数的参数

3:如何互相调用

html代码如下:

代码:<object type="application/x-shockwave-flash" data="test.swf" width="525" height="390" name="test">

<param
name="allowScriptAccess" value="sameDomain" />

<param
name="movie" value="test.swf" />

<param
name="quality" value="high" />

<param
name="scale" value="noScale" />

<param
name="wmode" value="transparent" />

</object>

function callFromFlash() {

var
a=thisMovie("test").hello();

alert(a);

}

function thisMovie(movieName) {

if
(navigator.appName.indexOf("Microsoft") != -1) {

return
window[movieName]

}

else
{

return
document[movieName]

}

}

最近开发网站时遇到一个问题,如何与FLASH里的AS脚本进行交互?

需要在Flash里读取网页JavaScript里的值,用于控制两个Flash协同显示内容。

最后终于在Flash找到了ExternalInterface类,要求环境:AS 1.0,Flash Player 8.0以上

一、在网页中通过JavaScript调用Flash里的ActionScript:

可以通过ExternalInterface的addCallback方法,在Flash里注册一个可以供网页上的JavaScript或ActiveX调用的方法,具体代码如下:

程序代码

import flash.external.*;

var methodName:String = "PlayBB";

var instance:Object = null;

var method:Function = playB;

var ws:Boolean = ExternalInterface.addCallback(methodName, instance, method);

在JavaScript中调用时,需要为Flash所在的Object标签设置一个ID,并且设置allowScriptAccess属性,示例代码如下:

程序代码

<object id="topFlash" name="topFlash" classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=7,0,19,0" width="686"
height="101">

<param
name="movie" value="_top.swf" />

<param
name="quality" value="high" />

<param
name="allowScriptAccess" value="always" />

<embed
allowScriptAccess="always" src="_top.swf" quality="high" pluginspage="http://www.macromedia.com/go/getflashplayer" type="application/x-shockwave-flash" width="686" height="101"></embed>

</object>

网页中的JavaScript具体的调用示例:

程序代码

function thisMovie(movieName) {

if
(navigator.appName.indexOf("Microsoft") != -1) {

return
window[movieName]

}

else
{

return
document[movieName]

}

}

thisMovie("topFlash").PlayBB();

二、在Flash的ActionScript中调用网页里的JavaScript:

直接使用ExternalInterface的Call方法就可以了,示例代码如下:

程序代码

import flash.external.*;

var obj:Object = ExternalInterface.Call("JavaScript方法", "参数");

参数可以是任何As中的类型,在调用时Flash会自动封装,多参数使用,分隔。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: