Unity HybridCLR 笔记

🛠️ 准备工作

  1. 确保Unity 安装开发模块

    Windows Build Support (IL2CPP) Mac Build Support (IL2CPP)

  2. Windows :需要安装 Visual Studio 2019或更高版本 ,并确保包含了"使用Unity的游戏开发"和"使用C++的游戏开发"两个组件。同时需要安装 Git

  3. Mac :需要安装 Xcode (版本13或以上)和 Git


一、安装与配置HybridCLR

1、安装 HybridCLR包

包管理 - 使用 Git地址 (https://gitee.com/focus-creative-games/hybridclr_unity.git )安装HybridCLR包

2、初始化 HybridCLR

菜单栏 HybridCLR - Installer - 控制台输出 Installation Successful

3、项目设置

① Scripting Backend :必须设置为 IL2CPP

② Api Compatibility Level :设置为 .Net 4.x (Unity 2019-2020)或 .Net Framework(Unity 2021及以上版本)。

二、编写与测试热更新代码

环境配置完毕,接下来通过一个简单测试来验证效果。

  1. 创建热更新模块

    • Assets 目录下创建一个新文件夹,例如 HotUpdate

    • HotUpdate 文件夹上右键,选择 Create -> Assembly Definition,创建一个名为 HotUpdate 的程序集定义文件。

  2. 编写测试脚本

    • HotUpdate 文件夹中创建 Hello.cs 脚本,写入以下简单代码:

      cs 复制代码
      // Assets/HotUpdate/Hello.cs
      using UnityEngine;
      
      public class Hello
      {
          public static void Run()
          {
              Debug.Log("Hello, HybridCLR");
          }
      }
  3. 加载热更新程序集

    • 在主场景中创建一个挂载了 LoadDll.cs 脚本的游戏物体,该脚本负责加载 HotUpdate.dll 并通过反射调用其中的代码。

    • 核心加载逻辑示例如下:

      cs 复制代码
      // 在非编辑器环境下,从文件加载热更新DLL
      Assembly hotUpdateAss = Assembly.Load(File.ReadAllBytes($"{Application.streamingAssetsPath}/HotUpdate.dll.bytes"));
      // 通过反射执行热更新代码
      Type type = hotUpdateAss.GetType("Hello");
      type.GetMethod("Run").Invoke(null, null);
  4. 构建与测试
    HybridCLR -> Settings,将热更新的程序集(Assembly)HotUpdate 添加到列表中。

    • 运行 HybridCLR/Generate/All 菜单进行必要的生成操作。

    • 将项目 HybridCLRData / HotUpdateDlls 下的生成的 HotUpdate.dll 文件再加个.bytes后缀名,并放入 StreamingAssets 文件夹。

    • 进行打包构建,如果控制台成功打印出 Hello, HybridCLR,则说明整个环境搭建成功。

相关推荐
LinXunFeng2 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
闪闪发亮的小星星6 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq6 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息
阿米亚波6 天前
【Windows】QEMU 启动 openEuler aarch64/arm64 架构系统 + 离线软件源
linux·windows·经验分享·笔记·架构·arm
自传.6 天前
尚硅谷 Vibe Coding|第三章(1) Claude Code深度使用与进阶技巧 学习笔记
笔记·学习·尚硅谷·vibecoding
.千余6 天前
【C++】模板进阶全解:非类型参数|全特化|偏特化|分离编译完全指南
开发语言·c++·笔记·学习·其他
自传.6 天前
尚硅谷 Vibe Coding|第二章 AI编程工具生态 学习笔记
笔记·学习·ai编程·尚硅谷·vibe coding
秋波。未央6 天前
Java Agent 开发 · Day 1 学习笔记(含作业完整标准答案)
java·笔记·学习
中屹指纹浏览器6 天前
2026指纹浏览器字体指纹、字体渲染偏差检测与全维度虚拟字体池搭建方案
经验分享·笔记
叶帆6 天前
【YFIOs】用C#开发硬件之设备上云
开发语言·unity·c#