更换Live2D模型具体步骤

(具体情况有差异,文章仅供思路参考)

项目介绍

我的后端来自fay数字人,https://gitee.com/xszyou/fay

前端来自https://gitee.com/garveyer/mate-human,有自带的数字人形象,但是本篇文章重点讲如何替换成其他Live2D形象

我的后端来自fay数字人,所以对Live2D文件格式有严格要求。下面图片是readme内容,因此我的文件必须按照目录结构实例存放。

前期准备

首先在mate-human\CubismSdkForWeb-5-r.4\Samples\Resources目录下新建文件夹MyModel,格式要求如图:

在expressions文件夹里面,修改文件名字为F01,F02.....这是因为后端固定只识别 F01、F02、F03、F04 这几个名字去调用表情,(从mate-human的Live2D 模型制作外包规范md中得知的),所以需要根据本项目更改这些文件名字。

与此同时,需要更改MyModel.model3.json中的映射文件,原本是没有改expressions里面的文件名字,如下图:

改后如图:

修改模型路径

找到lappdefine.ts(一般会在src下面)这个文件包含Live2D最重要的信息,比如引用的模型名称

复制代码
export const ModelDir: string[] = [
  'Haru'
];

模型面板背景

复制代码
export const BackImageName = 'nokia_reception_desk.png';

刚好我来介绍一下我的项目里面src都会包含哪些文件

javascript 复制代码
TypeScript
└── Demo
    └── src/
        ├─ lappdefine.ts          # 【文件1:改模型目录路径】
        ├─ live2d-action-map.ts   # 【文件2:动作&表情映射表】
        ├─ lapplive2dmanager.ts   # Live2D模型加载核心管理器
        ├─ fayclient.ts           # 和Fay后端WebSocket通信
        ├─ lipsync.ts             # 口型同步核心文件
        └─ main.ts                # 程序入口

动作映射

这一部分最为复杂,所以我先尝试着将所有动作表清空,如图所示目录

将这个文件里面的代码修改为这个:

javascript 复制代码
{
	"Version": 3,
	"FileReferences": {
		"Moc": "MyModel.moc3",
		"Textures": [
			"MyModel.2048/texture_00.png"
		],
		"Physics": "MyModel.physics3.json",
		"DisplayInfo": "MyModel.cdi3.json",
		"Expressions": [],
		"Motions": {
			
		}
	},
	"Groups": [
		{
			"Target": "Parameter",
			"Name": "EyeBlink",
			"Ids": ["ParamEyeLOpen","ParamEyeROpen"]
		},
		{
			"Target": "Parameter",
			"Name": "LipSync",
			"Ids": ["ParamMouthOpenY"]
		}
	],
	"HitAreas": []
}

可以运行显示出来人物形象,但是完全没有相关动作映射

我们一步步引入动作:

(这一块需要一个动作一个动作引入,否则人物显示不出来也找不到问题出在哪里)

在下面这个文件中的"Expressions": \[\]引入

之后要在映射表里添加映射

补充说明:smile,warm,neutral都是后端的部分,用于连接前后端内容,在后端项目fay/config里面,是一个excle表格

然后查看前端页面有没有人物形象

成功出现抱猫咪的剪纸人。

总结

1.Live2D 模型接入时:

先清空所有额外表情动作,只保留模型本体(moc3、贴图、物理文件),人物显示无报错后,再逐个追加表情、动作,出现报错能瞬间定位问题来源

2.关于 <!DOCTYPE> JSON 报错

只要报这个错,100% 是 SDK 请求的资源文件 404:要么路径写错、要么文件不存在、要么文件本身损坏非法,优先排查文件有效性,再排查路径。

以上就是实现思路,感谢观看。

相关推荐
xier_ran4 小时前
【infra之路】阶段二 · 模块一:GPU 架构与显存层级
人工智能·架构
lzp07914 小时前
从机器翻译到智驾:规则派的黄昏与数据革命的终局 (伍)
人工智能·自然语言处理·机器翻译
weixin_468466854 小时前
支持向量机新手实战指南
人工智能·python·算法·机器学习·支持向量机
lzp07914 小时前
从机器翻译到智驾:规则派的黄昏与数据革命的终局 (叁)
人工智能·自然语言处理·机器翻译
夕小瑶4 小时前
Claude Code 保姆级上手教程(2026 版)
人工智能·python
心态与习惯4 小时前
人工智能对管理科学与工程科研的冲击
人工智能·科研·读博·冲击·管科
sinat_286945194 小时前
gitnexus vs graphify
人工智能
Ztopcloud极拓云视角4 小时前
Claude Opus 4.8 实战接入指南:动态工作流 + 思考投入控制深度使用
大数据·人工智能·gpt·claude·deepseek
cxr8284 小时前
高分子复合材料 AI 逆向设计合—— 认知基座与理论框架
人工智能·材料逆向设计合成
落叶无情4 小时前
第二章 ICEF核心知识解读 第二节 ICEF:从“规律驱动提示“到“世界规律认知操作系统“的范式跃迁
人工智能