vue使用iframe内嵌unity模型,并且向模型传递信息,接受信息

1 静态模型地址

放在跟src同级的static里边,testHtml就是需要嵌的网页

2 TestHtml文件内容

html 复制代码
<body>
    <div id="unity-container">
        <canvas id="unity-canvas"></canvas>
    </div>

    <script src="Build/KEIPER_12_18.loader.js"></script>
    <script>
        let unityInstance = null;

        createUnityInstance(document.querySelector("#unity-canvas"), {
            dataUrl: "Build/KEIPER_12_18.data",
            frameworkUrl: "Build/KEIPER_12_18.framework.js",
            codeUrl: "Build/KEIPER_12_18.wasm",
            streamingAssetsUrl: "StreamingAssets",
            companyName: "DefaultCompany",
            productName: "KEIPER_2025_1211",
            productVersion: "1.0",
        }).then(instance => {
            unityInstance = instance;
            console.log("Unity loaded");

            window.addEventListener('message', (event) => {
                console.log("模型收到来自父窗口的消息:", event.data)
                if (event.data.type == 'call-callUnity') {
                    callUnity(JSON.stringify(event.data.data));

                }
            })

            
        });


        function callUnity(msg) {
            if (!unityInstance) {
                console.warn("Unity not ready");
                return;
            }

            //进行切片发送
            const jsonStr = typeof msg === "string" ? msg: JSON.stringify(msg);          
            const size = 1024;
            const total = Math.ceil(jsonStr.length/size);

            for(let i=0;i<total;i++){
                const chunk = jsonStr.substr(i * size, size);
                strNew =  i + "/" + total + "|" + chunk;
                unityInstance.SendMessage(
                    "WebGLSendAndReceiver",
                    "OnReceiveMessage",
                    i + "/" + total + "|" + chunk
                );

               //alert(strNew);

            }
        }

        // Unity → HTML(给 Unity 调用)
        function OnReceiveFromUnity(message) {
            /*  alert("Unity 传来的参数是:\n\n" + message); */
            console.log("从Unity接收到的消息:", message);

            const msgObject = {
                type: 'unity-message',
                data: message
            };
            try {
                window.top.postMessage(msgObject, '*');
            } catch (error) {
                console.error("发送消息失败:", error);
            }
        }


    </script>

</body>

主要就是两个方法

1、监听unity发来的消息,然后包装一下,等待发给vue

bash 复制代码
function OnReceiveFromUnity(message) {
    /*  alert("Unity 传来的参数是:\n\n" + message); */
    console.log("从Unity接收到的消息:", message);

    const msgObject = {
        type: 'unity-message',
        data: message
    };
    try {
        window.top.postMessage(msgObject, '*');
    } catch (error) {
        console.error("发送消息失败:", error);
    }
}

2、监听来自vue的消息,切片发送给unity

bash 复制代码
 window.addEventListener('message', (event) => {
		console.log("模型收到来自父窗口的消息:", event.data)
    if (event.data.type == 'call-callUnity') {
        callUnity(JSON.stringify(event.data.data));

    }
})

3 vue文件代码

bash 复制代码
<iframe style="width: 1920px;height:1080px;" id="modelRef" ref="modelRef" src="static/KEIPER_12_18/TestHtml.html" frameborder="0" @load="onModelLoad"></iframe>

load方法是模型加载后会执行,监听来自unity发送的消息

bash 复制代码
 onModelLoad() {
   window.addEventListener('message', function (event) {
        if (event.data.type == 'unity-message') {
            console.log('收到来自unity的消息:', event.data);
            this.testId = event.data.data
            this.getDialogData(this.testId)
        }
    }.bind(this));
},

4 给unity传信息

bash 复制代码
sendMessageToIframe(message) {
  const iframe = this.$refs.modelRef;
    if (!iframe) {
        console.error('无法获取iframe引用');
        return;
    }
   let newMessage = {
       type: 'call-callUnity',
       data:message
   };
    //console.log('向unity发送消息---------------vue:', newMessage);
    iframe.contentWindow.postMessage(newMessage, '*');
},
相关推荐
Csvn22 分钟前
OpenSpec 详细使用教程
前端
之歆1 小时前
Day19_LESS 完全指南——从入门到工程实践
前端·css·less
云水一下2 小时前
HTML5 从入门到精通:实战收官——从零搭建完整静态网站,综合运用所有知识
前端·html5
不总是2 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
冬奇Lab2 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
zhangyao9403303 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
kjs--3 小时前
浏览器书签执行脚本
前端
之歆4 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化
沄媪4 小时前
CSRF 跨站请求伪造
前端·ctf·csrf
kyriewen4 小时前
我关掉了Copilot:因为我写的代码出现在了别人的建议里
前端·javascript·ai编程