Unity(四十八):Unity与Web双向交互

效果

游戏对象绑定脚本

游戏脚本源码

csharp 复制代码
using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class Tent : MonoBehaviour
{
    public Camera camera;

    // Start is called before the first frame update
    void Start()
    {
    }

    // Update is called once per frame
    [System.Obsolete]
    void Update()
    {
        SendUnityMessage();
    }

    /// <summary>
    /// 发送数据到Web端
    /// </summary>
    [System.Obsolete]
    public void SendUnityMessage() {
        // 当前游戏对象的位置
        Vector3 worldPoint = transform.position;
        // 转换为屏幕位置
        Vector3 screenPoint = camera.WorldToScreenPoint(worldPoint);
        // w屏宽, h屏高, x位置, y位置
        Vector4 position = new Vector4(Screen.width, Screen.height, screenPoint.x, Screen.height - screenPoint.y);
        // 发送到Web端
        Application.ExternalCall("updatePosition2Web", transform.gameObject.name, position);
    }

    /// <summary>
    /// 接收来自Web的传参
    /// </summary>
    /// <param name="message">传参信息</param>
    public void ReceiveWebMessage(string message) {
        transform.position = Vector3.zero;
        Debug.Log(message);
    }
}

打包为Web应用

修改打包后的HTML源码

css 复制代码
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html,
body {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

#unity-canvas,
#unity-svg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}
html 复制代码
<!DOCTYPE html>
<html lang="en-us">

<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Unity WebGL Player</title>
  <link rel="shortcut icon" href="TemplateData/favicon.ico">
  <link rel="stylesheet" href="TemplateData/style.css">
  <link rel="manifest" href="manifest.webmanifest">
</head>

<body>
  <canvas id="unity-canvas" width=900 height=600 tabindex="-1"></canvas>
  <svg id="unity-svg">
    <text id="svg-text"></text>
  </svg>
  </div>
  <script src="./js/d3@7.js"></script>
  <script>
    var canvas = document.querySelector("#unity-canvas");

    let unity = null;

    var buildUrl = "Build";
    var loaderUrl = buildUrl + "/XXXXXX.loader.js";
    var config = {
      dataUrl: buildUrl + "/XXXXXX.data.unityweb",
      frameworkUrl: buildUrl + "/XXXXXX.framework.js.unityweb",
      codeUrl: buildUrl + "/XXXXXX.wasm.unityweb",
      streamingAssetsUrl: "StreamingAssets",
      companyName: "DefaultCompany",
      productName: "XXXXXX",
      productVersion: "0.1",
    };

    var script = document.createElement("script");
    script.src = loaderUrl;
    script.onload = () => {
      createUnityInstance(canvas, config, (progress) => {
        console.log('progress', progress);
      }).then((unityInstance) => {
        unity = unityInstance;
      }).catch((message) => {
        alert(message);
      });
    };
    document.body.appendChild(script);

    /**
     * 获取游戏对象相对于屏幕的位置
     * @param name      游戏对象名称
     * @param position  位置信息
     */
    function updatePosition2Web(name, position) {
      const [w, h, x, y] = position.replace(/[()\s]/g, '').split(',');

      const svg = d3.select('#unity-svg').attr('viewBox', [0, 0, w, h]);
      d3.select('#svg-text')
        .text(position)
        .attr('x', x)
        .attr('y', y)
        .attr('fill', 'red')
        .attr('font-size', 30)
        .on('click', e => {
          console.log(name, unity);
          unity.SendMessage(name, "ReceiveWebMessage", "发送消息到unity!!!")
        });
    }
  </script>
</body>

</html>
相关推荐
white-persist8 小时前
轻松抓包微信小程序:Proxifier+Burp Suite教程
前端·网络·安全·网络安全·微信小程序·小程序·notepad++
敲敲了个代码9 小时前
多标签页强提醒不重复打扰:从“弹框轰炸”到“共享待处理队列”的实战
java·前端·javascript·面试·架构
不想上班只想要钱9 小时前
动态类名在 <swiper-slide 的复制项中没有起作用的解决方法
前端·vue.js
weixin_395448919 小时前
tidl_import_mul_rmfsd_psd_u8_3x480x544_bise_raw_dynamic.txt
java·服务器·前端
Jinuss10 小时前
源码分析之React中updateContainerImpl方法更新容器
前端·react.js·前端框架
一种时光11 小时前
Unity 获取当前播放的动画,判断是否是某个动画
unity·游戏引擎
Mr Xu_11 小时前
Vue + Element Plus 实现前端导出 Excel 功能详解
前端·javascript·vue.js
仰泳之鹅11 小时前
【杂谈】使用Edge浏览器下载文件显示“Microsoft Defender SmartScreen 已阻止此不安全文件”的解决方法
前端·edge
万邦科技Lafite11 小时前
小红书评论数据一键获取,item_reviewAPI接口讲解
大数据·前端·数据库·chrome·电商开放平台
meng半颗糖12 小时前
vue3+tpescript 点击按钮跳转新页面直接通过链接预览word
前端·vue.js·word