当前位置: 首页 > news >正文

【Unity】 HTFramework框架(六十)Assistant助手(在Unity中接入DeepSeek等AI语言大模型)

更新日期:2025年2月14日。
Github源码:[点我获取源码]
Gitee源码:[点我获取源码]

索引

  • Assistant助手
  • 安装Ollama
    • 使用Assistant(在编辑器中)
      • 打开Assistant
      • 配置Assistant
      • 使用Assistant
      • 处理Assistant回复的内容
      • 使用推理大模型
    • 使用Assistant(在运行时)
      • 用户发起问话
      • Assistant回复

Assistant助手

Assistant为通用AI助手,支持在编辑器运行时调用DeepSeek等AI语言大模型。

安装Ollama

为了方便演示Assistant,我们使用相对简单的Ollama本地部署大模型的方式,关于如何使用Ollama部署AI大模型,这在网上有很详细的教程,而且非常简单,所以我便不再重复讲解了(当然,如果还是不会,你也可以直接问AI)。

使用Assistant(在编辑器中)

编辑器中使用Assistant,可以帮助你解答一些代码问题或Unity引擎的知识,或直接生成代码。

打开Assistant

通过菜单HTFramework / ★ AI / Assistant打开Assistant窗口(快捷键Alt + A):

在这里插入图片描述

Assistant窗口如下:

在这里插入图片描述

左侧显示会话历史记录,右侧显示当前会话内容,在下方的输入框中输入你的问题,点击发送消息(或按回车)按钮就可以得到AI助手的解答。

比如随便乱问:

在这里插入图片描述

比如问点Unity的东西:

在这里插入图片描述

当然,并不是一开始就能使AI助手开始工作,我们必须先进行基本的配置。

配置Assistant

点击Assistant窗口右上角的设置按钮,打开配置界面:

在这里插入图片描述

配置界面如下:

在这里插入图片描述

1.大模型:使用的大模型名称(如果是调用Ollama大模型,则模型参数也必须带上,也即是后面的16b),点击后面的选择按钮可快速切换一些预制的大模型(主要是DeepSeek的),当然你也可以手输任何大模型名称;
2.流式请求:大模型生成文本时,采用流式响应;
3.大模型根地址:也即是大模型接口的根级路径,我这里使用Ollama本地部署的,所以直接填localhost(Ollama默认端口为11434);
4.API接口:访问的大模型API接口(Ollama默认为/api/generate);
5.超时时长:单次请求超时时长;
6.多轮对话最大轮数:对话采用多轮对话形式,表示最多7条历史记录会被回传(AI结合对话历史分析问题会更加准确);
7.打印相关日志:主要用于调试时打印相关日志(注意,如果AI生成的内容太长,你的控制台可能会被刷屏);
8.显示推理过程:使用DeepSeek-R1等推理模型时,会同时显示其推理过程;
9.RunInOllama:点击即可直接调用Ollama启动当前设置的大模型,如果该模型未下载,将会自动下载(仅限Ollama本地部署的情况)。

使用Assistant

配置完成并测试通过后,我们便可以畅通无阻的使用Assistant了,除了直接在输入框中输入任意问题,你还可以在编辑器中将你不太熟悉的组件,发给Assistant进行解答(只需右击组件,选择Ask AI Assistant):

在这里插入图片描述

等待AI回复:

请添加图片描述

处理Assistant回复的内容

由于Assistant回复的内容为Markdown格式的文本,直接看起来不是很友好,轻量级的Markdown解析库正好有现成的,但需要引入HTModuleManager模块。

然后点击如下按钮,既可以在通用Markdown查看窗口中预览内容:

在这里插入图片描述

通用Markdown查看窗口:

在这里插入图片描述

使用推理大模型

使用DeepSeek-R1等推理模型时,AI的回复内容会包含推理过程:

请添加图片描述

使用Assistant(在运行时)

运行时使用Assistant也很简单,我直接贴出代码。

用户发起问话

public class Test : HTBehaviour
{
    protected override void Awake()
    {
        base.Awake();

        AskAssistant();
    }

    public void AskAssistant()
    {
    	//ChatSession 即代表一个会话,其包含历史记录并自动回传
        ChatSession chatSession = new ChatSession("0", "新的会话");
        chatSession.Data.Model = "deepseek-r1:14b";
        chatSession.Data.Stream = true;
        chatSession.BaseAddress = "http://localhost:11434";
        chatSession.API = "/api/generate";
        chatSession.Timeout = 60;
        chatSession.Round = 7;
        chatSession.IsLogInEditor = false;

        //向AI说话
        chatSession.UserSpeak("你好呀!", OnReply, OnEnd);
    }

    /// <summary>
    /// AI回复(如果是流式请求,则重复回调此方法)
    /// </summary>
    private void OnReply(string content)
    {
        Debug.Log("AI回复:" + content);
    }
    /// <summary>
    /// AI回复结束
    /// </summary>
    /// <param name="success"></param>
    private void OnEnd(bool success)
    {
        Debug.Log("AI回复完成。");
    }
}

Assistant回复

这里为流式请求:

在这里插入图片描述

想要管理多个会话的话,就维护一个ChatSession数组就可以了。

最后,看好DeepSeek,期待他的继续强大。

相关文章:

  • 蓝桥杯---N字形变换(leetcode第6题)题解
  • 蓝桥杯备赛 Day13.1走出迷宫
  • 以SpringBoot+Vue分布式架构商城系统为例,讲解订单生命周期的管理
  • 分卷压缩怎么操作?分卷压缩怎么解压?
  • Python----PyQt开发(PyQt高级:手搓一个简单的记事本)
  • 腾讯混元hunyuan3d生成模型,本地搭建和使用
  • singleTaskAndroid的Activity启动模式知识点总结
  • 374_C++_升级等其他类型标签,使用将4字节字符串转换为无符号整数的定义方式
  • Managed Lustre 和 WEKA:高性能文件系统的对比与应用
  • 图像缩放的双线性插值实现方式
  • Reasoning in High Gear 推理加速发展
  • 【Java八股文】02-Java集合面试篇
  • docker容器部署jar应用导入文件时候报缺少字体错误解决
  • DeepSeek预测25考研分数线,复试资料分享
  • 【弹性计算】弹性计算的技术架构
  • 在springboot加vue项目中加入图形验证码
  • Windows软件自动化利器:pywinauto python
  • 用什么办法能实现ubuntu里面运行的自己开发的python程序能自动升级。
  • 【横川咨询】开发了一个极简音乐播放器
  • 【原创】解决vue-element-plus-admin无法实现下拉框动态控制表单功能,动态显隐输入框
  • 郑培凯:汤显祖的“至情”与罗汝芳的“赤子之心”
  • 智能手表眼镜等存泄密隐患,国安部提醒:严禁在涉密场所使用
  • 时隔近4年再出征!长三丙成功发射通信技术试验卫星十九号
  • 中共中央、国务院印发《生态环境保护督察工作条例》
  • 火车站员工迟到,致出站门未及时开启乘客被困?铁路部门致歉
  • 总没胃口,一吃就饱……别羡慕,也可能是生病了