flex集成IFrame,IFrame集成UnityWebPlayer直接通讯调用解决方式

摘要:
在Web开发中,flex与JS交互,UnityWebPlayer与JS交互。您需要将unityweblayer页面检查到flex应用程序框架中。flex和unityweblayer之间的直接交互已经完成。为了完成这个需求,我们需要解决以下问题:1.如何将html页面检查到flex容器中;2.如何实现flex和unity webplayer之间的直接通信;问题1:根据搜索,flex中有一个iframe插件,可以解决这个问题。unityweblayer调用flex函数的关键是在图中用红色标记它们。事实上,很容易理解iframe被签入flex HTML。如果iframe中的脚本发现SwfContent对象可以用于调用flex中的函数并与flex通信。

做Web开发一般是flex与JS交互,UnityWebPlayer与JS交互。

它们之间相互调用比較常见。

/**
 * Flex调用Javascript函数
 * @params  functionName:String   Javascript函数名称
 * @params ...params    Javascript函数參数
 * @return  返回Javascript函数的return内容
 **/
ExternalInterface.call(functionName:String, ...params);

/**
 * Javascript调用Flex函数
 * @params   functionName:String    Javascript调用Flex函数名
 * @params   closure:Function     Flex将要调用的函数
 * @return void
 **/
ExternalInterface.addCallback(functionName:String,closure:Function);

JS调用Unity web Content函数

<script type="text/javascript" language="javascript">
<!--
//initializing the WebPlayer
var u = new UnityObject2();
u.initPlugin(jQuery("#unityPlayer")[0], "Example.unity3d");

function SaySomethingToUnity()
{
	u.getUnity().SendMessage("MyObject", "MyFunction", "Hello from a web page!");
}
-->
</script>

在Unity web player中须要有一个“MyObject”的GameObject对象,而且附加一个带有“MyFunction”函数的脚本:

function MyFunction(param : String)
{
    Debug.Log(param);
}

unity web player调用网页中JS函数:

unity中增加该脚本调用
Application.ExternalCall( "SayHello", "The game says hello!" );

在web页面中须要定义一个叫 SayHello() 函数: 

<script type="text/javascript" language="javascript">
<!--
function SayHello( arg )
{
    // show the message
    alert( arg );
}
-->
</script>
以上两种交互方式是比較经常使用的,近期一个项目遇到了一个特殊的应用需求。须要把unity web player的页面签入到flex应用框架中。而且完毕flex与unity web player直接的交互。

为了完毕这项需求须要解决例如以下问题:

1、怎样把html页面签入到flex容器中;

2、怎样实现flex与unity web player直接的通讯问题;

问题1,通过收搜得出眼下flex中有一个iframe插件,能够解决。

步骤:

1、在此链接中下载现成的资料 https://github.com/flex-users/flex-iframe/downloads

我下的是最新的 flex-iframe-1.5.1.zip

解压后,在 flex-iframe-1.5.1sourceslibraryflex-iframesrccomgooglecodeflexiframe  这个路径中能够找到两个AcriptScript 类文件

2、将IFrame.as、IFrameExternalCalls.as  存放在Flex项目中。我将它拷贝到Class文件中或者引用binflex-iframe-1.5.swc

3、新建立 MXML应用程序,加入红色部分代码就可以。 source里填充要显示的页面

<?

xml version="1.0" encoding="utf-8"?

> <s:Application xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:flexiframe="http://code.google.com/p/flex-iframe/" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600" xmlns:iframe="Class.*"> <fx:Declarations> <!-- 将非可视元素(比如服务、值对象)放在此处 --> </fx:Declarations> <iframe:IFrame source="http://www.baidu.com/" /> </s:Application>

问题2,解决flex与unity web player直接通讯。


flex集成IFrame,IFrame集成UnityWebPlayer直接通讯调用解决方式第1张

unity web player调用flex函数,关键是通过图上红色标注,事实上非常好理解就是iframe签入到了Flex的HTML中,通过iframe中脚本发现SwfContent对象就能够实现调用flex中的函数,实现与flex通讯。




免责声明:文章转载自《flex集成IFrame,IFrame集成UnityWebPlayer直接通讯调用解决方式》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇一键清理 Nexus 中无用的 Docker 镜像在ModelSim中添加Xilinx仿真库下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Python之class面向对象(基础篇)

概述 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发“更快更好更强...” 面向过程编程最易被初学者接受,其往往用一长段代码来实现指定功能,开发过程中最常见的操作就是粘贴复制,即:将之前实现的代码块复制到现需功能处。 1 2 3 4 5 6 7 8...

bootstrap添加iframe页

改写自: https://www.cnblogs.com/yxgmagic/p/9637075.html 效果图: <div class="ibox float-e-margins"> <div id="tabContainer"></div> </div> <scri...

JQuery iframe宽高度自适应浏览器窗口大小的解决方法

iframe宽高度自适应浏览器窗口大小的解决方法   by:授客 QQ:1033553122 1.   测试环境 JQuery-3.2.1.min.js 下载地址: https://gitee.com/ishouke/front_end_plugin/blob/master/jquery-3.2.1.min.js   Bootstrap-3.3.7-dis...

JS高级---把局部变量变成全局变量

如何把局部变量变成全局变量?  把局部变量给window就可以了     函数的自调用---自调用函数 一次性的函数--声明的同时, 直接调用了 (function () { console.log("函数"); })(); 局部变量 页面加载后.这个自调用函数的代码就执行完了 (function (形参) {...

iOS中Block的用法,举例,解析与底层原理

1. 前言 Block:带有自动变量(局部变量)的匿名函数。它是C语言的扩充功能。之所以是拓展,是因为C语言不允许存在这样匿名函数。 1.1 匿名函数 匿名函数是指不带函数名称函数。C语言中,函数是怎样的呢?类似这样: int func(int count); 调用的时候: int result = func(10); func就是它的函数名。也可以通...

2015-8-25-关于后端的知识以及常用函数整理

首先结构一般是分为B/S(Browser/Server)和C/S(Client/Server)的,我们所用的是基于B/S结构的。 其中这里的B主要是一些控件的组成的页面,主要是由JScript控制的, 其中的S主要是由SSL代码控制的,又分为Server Script和Data Sources,首先来说说两者的一些区别(Server Script用SS代替...