我的编程空间,编程开发者的网络收藏夹
学习永远不晚

unity与vue交互(无第三方插件)

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

unity与vue交互(无第三方插件)

vue与unity交互最终版本 不需要安装任何第三方插件

请大家安心看完,写的比较详细,并且绝对有效,所以篇幅比较大,也可以直接看图解,看不懂图解后再看文档也可

因为之前我使用的vue-unity-webgl 后来发现使用过程中容易出现各种问题,也可能是我们菜吧,没弄懂插件如何使用,下面先说一下我遇见的问题

问题1:unity为了解决无法输入中文问题,使用了网上的解决方案,因为vue-unity-webgl会将unity的东西完全融入到vue,所以unity的操作也会导致vue页面出现异常,例如我的el-input无法正常输入

问题2:unity引入hls,为了解决视频播放问题,因为vue-unity-webgl不支持引入其他js,导致unity无法正常播放视频(我还傻呵呵的改了三方源码,打了补丁,现在血亏)

综合以上2个原因,我决定从根本上解决此问题,也为了避免不再背锅,想出了以下解决方案,这个方案比较简单但却非常有效;

思路:

  1. 在vue中依然使用iframe引入unity文件,原因:iframe是另外一个window,即使unity程序出现了使用了全局的方法来进行操作,也不行影响到vue程序
  2. unity编辑后的index.html被iframe引入,然后再index.html中追加几行代码,进行unity的方法接受和vue传递,详情见图解

好处:
unity存在于iframe的独立window中,可以避开好多非常规操作引起的问题,并且此方法可以适用于任何前端和unity的交互场景,不要求一定是vue

tip:
不用担心iframe层级无限高导致布局困难的问题,新版unity即使在iframe中引入,也是可以被定位元素覆盖住的

unity文件写法:

1、定义一个jslib文件,名字随意起,但是一定要放在Plugins文件夹,代码示例如下

在这里插入图片描述

这里定义了一个sayHello和一个ReportReady,简单解释下:
sayHello是unity自己测试用的方法;

ReoprtReady是unity加载完成后,触发window对象下的ReportReaddy事件,这个事件明显不存在,是对于window对象的自定义方法;

至于前端需要调用的方法存在于第二步中;

2、新建一个测试文件,创建一个物体名为JsTalker

在这里插入图片描述

此文件的写法相信unity小伙伴都知道意思,不过多赘述,简要描述下就是,此物体引用过来第一步写的2个方法(SayHello、RepoetReady),暴露出去一个方法(SetToken),这个暴露出来的方法就是前端需要调用的

此时运行表现形式应该会提示window下无ReportReady方法,所以需要在unity打包后生产的index.html中加入一行代码 window.ReportReady=function(){} 此时不会报错;

接下来就是unity加载完毕执行ReportReady,然后input按下指定按键,触发SayHello,前端如果调用SetToken会使unity中text变量变动

vue文件写法

1、在index.html页面中定义的RepoetReady中,按照下列方式进行书写

在这里插入图片描述
在这里插入图片描述

解释:当unity触发window.ReportReady的时候,向顶层window传递事件,然后调用定义好的send;

表现形式:unity加载完毕,触发ReportReady,前端接收到后执行send,同时向上层传递事件,进行交互;

send写法为固定api,解释见上图

2、在使用iframe引入unity的vue组件中书写

在这里插入图片描述

当index.html使用window.top.dispatchEvent的时候,此处可以监听到;

提问:为啥监听的是fn,因为unity调用window.ReportReady的时候,携带的参数是(‘fn',…),这里是我和unity工程师定义的,第一个参数是事件名字,第二个参数为携带参数

当vue程序出发send事件的时候,实际上是触发index.html中定义的send方法,然后携带参数,index.html接受到后,会将参数发送给unity

在这里插入图片描述

此时,双向交互完成。

总结:

window.ReportReady 是自定义事件,是由unity挂载到window的,当unity需要给vue发送事件的时候,会调用window.ReportReady(),然后带有2个参数,一个是事件名字,一个是携带参数,这个示例中,携带事件名字为fn;
前端接受到后,通过dispatch来派发到顶层window,顶层window就是咱们的vue,然后vue中通过事件监听来获取;
发送事件的话就是通过send,通过contentWindow来调用iframe中(unity打包后的index.html)的方法,方法为固定api写法,其中贴图中有注释

到此这篇关于unity与vue交互(无第三方插件)的文章就介绍到这了,更多相关unity与vue交互内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

unity与vue交互(无第三方插件)

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++云服务集成:与第三方服务无缝交互

在 c++++ 中集成云服务可以提高应用程序的弹性、可伸缩性和可用性。集成步骤包括:1. 选择云服务提供商;2. 设置帐户;3. 安装开发库;4. 编写集成代码。本文以从 aws s3 检索数据为例,展示了 c++ 中云服务集成的实战应用。
C++云服务集成:与第三方服务无缝交互
2024-05-11

利用第三方插件与工具提升游戏开发效率(第三方插件与工具在游戏开发中的应用与优势)

第三方插件和工具为游戏开发提供了强大优势,包括自动化重复性任务、提供高级功能、简化集成、减少错误和加快迭代。这些工具可用于游戏开发的各个阶段,从前期制作到后期制作。虚幻引擎和Unity提供广泛的插件和工具,而第三方市场提供预制资产。最佳实践包括研究和选择、合理使用、保持更新、自定义和集成以及文档和培训。利用这些工具有助于提升效率、提高代码质量,并打造更好的游戏体验。
利用第三方插件与工具提升游戏开发效率(第三方插件与工具在游戏开发中的应用与优势)
2024-04-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录