`

actionscript 和JavaScript 通信

    博客分类:
  • flex
阅读更多

 

ExternalInterface 类是外部 API,这是一个在 ActionScript 和 Flash Player 容器之间实现直接通信的应用程序编程接口,例如,包含 JavaScript 的 HTML 页。Adobe 建议使用 ExternalInterface 实现 JavaScript 与 ActionScript 之间的所有通信。
在 Flash Player 中,可以使用 HTML 页中的 JavaScript 来调用 ActionScript 函数。ActionScript 函数可以返回一个值,JavaScript 会立即接收它作为该调用的返回值。

addCallback(functionName:String, closure:Function) 将 ActionScript 方法注册为可从容器调用。

call(functionName:String, ... arguments)  调用由 Flash Player 容器公开的函数,不传递参数或传递多个参数。

actionscript code:

 

package com.adobe.cairngorm.util
{
    import flash.display.Sprite;
    import flash.events.*;
    import flash.external.ExternalInterface;
    import flash.text.TextField;
    import flash.utils.Timer;
    import flash.text.TextFieldType;
    import flash.text.TextFieldAutoSize;

    public class ExternalInterfaceExample extends Sprite {
        private var input:TextField;
        private var output:TextField;
        private var sendBtn:Sprite;

        public function ExternalInterfaceExample() {
            input = new TextField();
            input.type = TextFieldType.INPUT;
            input.background = true;
            input.border = true;
            input.width = 350;
            input.height = 18;
            addChild(input);

            sendBtn = new Sprite();
            sendBtn.mouseEnabled = true;
            sendBtn.x = input.width + 10;
            sendBtn.graphics.beginFill(0xCCCCCC);
            sendBtn.graphics.drawRoundRect(0, 0, 80, 18, 10, 10);
            sendBtn.graphics.endFill();
            sendBtn.addEventListener(MouseEvent.CLICK, clickHandler);
            addChild(sendBtn);

            output = new TextField();
            output.y = 25;
            output.width = 450;
            output.height = 325;
            output.multiline = true;
            output.wordWrap = true;
            output.border = true;
            output.text = "Initializing...\n";
            addChild(output);

            if (ExternalInterface.available) {
                try {
                    output.appendText("Adding callback...\n");
                    ExternalInterface.addCallback("sendToActionScript", receivedFromJavaScript);
                    if (checkJavaScriptReady()) {
                        output.appendText("JavaScript is ready.\n");
                    } else {
                        output.appendText("JavaScript is not ready, creating timer.\n");
                        var readyTimer:Timer = new Timer(100, 0);
                        readyTimer.addEventListener(TimerEvent.TIMER, timerHandler);
                        readyTimer.start();
                    }
                } catch (error:SecurityError) {
                    output.appendText("A SecurityError occurred: " + error.message + "\n");
                } catch (error:Error) {
                    output.appendText("An Error occurred: " + error.message + "\n");
                }
            } else {
                output.appendText("External interface is not available for this container.");
            }
        }
        private function receivedFromJavaScript(value:String):void {
            output.appendText("JavaScript says: " + value + "\n");
        }
        private function checkJavaScriptReady():Boolean {
            var isReady:Boolean = ExternalInterface.call("isReady");
            return isReady;
        }
        private function timerHandler(event:TimerEvent):void {
            output.appendText("Checking JavaScript status...\n");
            var isReady:Boolean = checkJavaScriptReady();
            if (isReady) {
                output.appendText("JavaScript is ready.\n");
                Timer(event.target).stop();
            }
        }
        private function clickHandler(event:MouseEvent):void {
            if (ExternalInterface.available) {
                ExternalInterface.call("sendToJavaScript", input.text);
            }
        }
    }
}

 


html code:


<!-- saved from url=(0014)about:internet -->
 <html lang="en">
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>ExternalInterfaceExample</title>
 <script language="JavaScript">
     var jsReady = false;
     function isReady() {
         return jsReady;
     }
     function pageInit() {
         jsReady = true;
         document.forms["form1"].output.value += "\n" + "JavaScript is ready.\n";
     }
     function thisMovie(movieName) {
         if (navigator.appName.indexOf("Microsoft") != -1) {
             return window[movieName];
         } else {
             return document[movieName];
         }
     }
     function sendToActionScript(value) {
         thisMovie("ExternalInterfaceExample").sendToActionScript(value);
     }
     function sendToJavaScript(value) {
         document.forms["form1"].output.value += "ActionScript says: " + value + "\n";
     }
 </script>
 </head>
 <body onload="pageInit();">
 
     <object classid="clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
             id="ExternalInterfaceExample" width="500" height="375"
             codebase="http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab">
         <param name="movie" value="ballProjFlex/asWithJs.swf" />
         <param name="quality" value="high" />
         <param name="bgcolor" value="#869ca7" />
         <param name="allowScriptAccess" value="sameDomain" />
         <embed src="ballProjFlex/asWithJs.swf" quality="high" bgcolor="#869ca7"
             width="500" height="375" name="ExternalInterfaceExample" align="middle"
             play="true" loop="false" quality="high" allowScriptAccess="sameDomain"
             type="application/x-shockwave-flash"
             pluginspage="http://www.macromedia.com/go/getflashplayer">
         </embed>
     </object>
 
     <form name="form1" onsubmit="return false;">
         <input type="text" name="input" value="" />
         <input type="button" value="Send" onclick="sendToActionScript(this.form.input.value);" /><br />
         <textarea cols="60" rows="20" name="output" readonly="true">Initializing...</textarea>
     </form>
 
 </body>
 </html>


分享到:
评论

相关推荐

    一个实现ActionScript 与JavaScript 进行相互通信的程序例子

    6. **最佳实践**:为了提高性能和用户体验,避免频繁的ActionScript和JavaScript通信。考虑批量处理数据,或者使用事件驱动的通信模型。 这个程序例子将展示如何配置和使用这些机制,以便在ActionScript和...

    actionscript与JavaScript通信

    jsp 就是 servlet,因此能和 jsp 通信也就能和 servlet 通信。当然与 php, asp 通信方法也都是这样的

    javascript和actionscript之间通信实例

    Flash内容可以通过模拟一个IFrame来使用这个API,从而与JavaScript通信。 9. **Bridge Libraries**: 有一些开源库,如`swfobject`和`GreenSock's AS3 to JS Bridge`,它们简化了JavaScript与ActionScript之间的通信...

    ActionScript与JavaScript相互调用

    ActionScript和JavaScript是两种在Web开发中广泛应用的脚本语言,它们各自有着不同的应用场景和优势。ActionScript主要用于Adobe Flash平台,而JavaScript则是Web浏览器中的主要编程语言。这两者之间的交互能力,...

    javascript与actionscript3.0通信实例.rar

    以上就是JavaScript与ActionScript 3.0通信的基本原理和实现过程。通过掌握这些知识,开发者可以创建更加动态和交互丰富的Web内容,特别是在需要兼容Firework程序的情况下。不过,随着Web技术的发展,这种通信方式...

    SWF(ActionScript3.0)与JavaScipt(JS)通信示例

    今天花了一些时间整理出来了Swf 文件与JavaScript通信的示例,在此贴出供大家参考。 在ActionScript3.0与JavaScipt通信的时候需要用到ExternalInterface类。 “ExternalInterface”类是外部API,在ActionScript和...

    actionscript api javascript api j2ee api html+dom

    JavaScript API通常包括DOM(文档对象模型)操作、BOM(浏览器对象模型)访问、AJAX(异步JavaScript和XML)通信、CSS操作等。JavaScript API是现代Web开发不可或缺的一部分,广泛应用于前端界面的动态化和增强用户...

    flash和JavaScript通信

    在Web开发领域,Flash和JavaScript之间的通信是一种常见技术,它允许两种不同的技术栈协同工作,增强网页的功能性和交互性。 Flash曾经是实现动态内容和多媒体交互的重要工具,而JavaScript则是浏览器端的主要脚本...

    一个flash和javascript通信的例子

    标题 "一个Flash和JavaScript通信的例子" 涉及的核心技术是Flash与JavaScript之间的交互,也称为Flash External Interface(简称FEI)或者ActionScript JavaScript Bridge(AS3 JSBridge)。这种技术允许网页中的...

    CSS中文 Flash.ActionScript.as3.0 JavaScript 语言参考

    进阶内容涵盖DOM操作(文档对象模型,用于修改网页结构)、BOM(浏览器对象模型,处理窗口、历史、位置等浏览器特性)、AJAX(异步JavaScript和XML,实现页面无刷新更新)、ES6及后续版本的新特性(如箭头函数、模板...

    JavaScript与ActionScript3交互问题总结

    ExternalInterface是AS3中用于与JavaScript通信的内置类。要使用它,首先需要在AS3代码中启用接口,并声明可供JavaScript调用的方法。例如: ```as3 import flash.external.ExternalInterface; ExternalInterface....

    javascript与actionscript的交互.[课件]

    它支持面向对象编程,提供了强大的性能和更丰富的功能,如图形绘制、网络通信和视频播放。ActionScript 通常用于创建动画、游戏和富媒体应用程序,这些内容可以通过Flash Player或Adobe AIR在各种平台上运行。 3. ...

    Flash与JavaScript的通信例子及总结(源码)

    3. 性能:过多的Flash与JavaScript通信可能会影响页面性能,因此应合理设计通信频率和数据量。 总结,Flash与JavaScript的通信是一个强大且灵活的技术,它使得网页内容能够实现更丰富的交互效果。理解并熟练掌握...

    JavaScript和Flash的通信(转)

    ### JavaScript和Flash之间的通信 随着Web技术的发展,不同的媒体组件如JavaScript和Flash之间进行交互的需求逐渐增加。在本文中,我们将深入探讨JavaScript和Flash如何实现跨语言通信,并提供实际的应用案例来帮助...

    JavaScript和ActionScript的交互实现代码

    JavaScript 和 ActionScript 是两种在 Web 开发中常用于交互的脚本语言,分别在浏览器的前端(JavaScript)和 Adobe Flash Player(ActionScript)中运行。本文将详细介绍如何实现在 Flash 内容(ActionScript)与...

    JavaScript和Flash的通信.rar_javascript

    JavaScript和Flash之间的通信是Web开发中的一个重要话题,尤其是在过去的十几年里,当Flash在网页动画和交互性内容中占据主导地位时。尽管现在HTML5已经逐渐取代了Flash,但理解这两种技术如何协同工作仍然有价值,...

    Actionscript与javascript交互实例程序(修改)

    在本实例中,我们探讨了如何实现Actionscript与JavaScript之间的交互。...这种交互对于创建混合型的RIA应用非常重要,能够充分利用Actionscript的强类型和面向对象特性以及JavaScript的灵活性和广泛兼容性。

    ActionScript

    ActionScript是一种基于ECMAScript(JavaScript的标准化版本)的编程语言,主要被应用于Adobe Flash平台,用于创建交互式内容、富互联网应用程序(RIA)以及动画。在“ActionScript开发技术大全”这个主题中,我们...

    actionscript与javascript的区别

    ActionScript和JavaScript是两种在Web开发中广泛使用的脚本语言,它们虽然有着相似之处,但在很多方面也存在着显著的差异。 ActionScript最初是为Adobe Flash平台设计的,主要用于创建交互式内容、动画以及富互联网...

    Actionscript中文帮助文档

    ActionScript是一种基于ECMAScript规范...对于初学者,建议从基础语法和面向对象编程入手,逐步熟悉显示列表和事件处理,然后深入到更复杂的网络通信和多媒体处理。同时,配合实际项目练习,将理论知识转化为实践技能。

Global site tag (gtag.js) - Google Analytics