关于2233看板娘的配置方法

[个人博客折腾记录] 关于2233看板娘的配置方法

说实话,这个功能我也是折腾了很久才搞出来,过程比较曲折,代码中也有些 Bug,但是能跑起来就行,不影响效果,所以我就懒得修啦~ _(≧▽≦)/

参考来源:
详细可参考这位大佬的博客:网页添加 Live2D 看板娘
最早出处的链接现在大部分都打不开了,这篇比较新也比较全。


下载项目

我用的是 GitHub 上 fghrsh 大佬维护的 Live2D 看板娘 Demo,地址是:
https://github.com/fghrsh/live2d_demo

你可以直接访问上面链接下载,也可以用下面的命令克隆下来:

1
git clone https://github.com/fghrsh/live2d_demo.git

目录结构简介

克隆下来之后大致长这样:

1
2
3
4
5
6
7
8
9
10
11
12
13
│  demo1-default.html       // 基本 Demo
│ demo2-autoload.html // 自动加载 Demo
│ demo3-waifu-tips.html // 内置 waifu-tips 的 Demo

└─assets
autoload.js // 自动异步加载
flat-ui-icons-regular.* // Flat UI 图标字体文件
live2d.js // Live2D 核心文件
waifu-tips.js // Live2D 看板娘交互逻辑
waifu-tips.json // Live2D 看板娘提示语配置
waifu.css // Live2D 看板娘样式表
jquery.min.js?v=3.3.1 // jQuery 库
jquery-ui.min.js // jQuery UI 库

其中几个主要文件是:

  • waifu-tips.js:核心逻辑与参数设置
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
// 后端接口
live2d_settings['modelAPI'] = '//live2d.fghrsh.net/api/'; // 自建 API 修改这里
live2d_settings['tipsMessage'] = 'waifu-tips.json'; // 同目录下可省略路径
live2d_settings['hitokotoAPI'] = 'lwl12.com'; // 一言 API,可选 'lwl12.com', 'hitokoto.cn', 'jinrishici.com'(古诗词)

// 默认模型
live2d_settings['modelId'] = 1; // 默认模型 ID,可在 F12 控制台找到
live2d_settings['modelTexturesId'] = 53; // 默认材质 ID,可在 F12 控制台找到

// 工具栏设置
live2d_settings['showToolMenu'] = true; // 显示 工具栏 ,可选 true(真), false(假)
live2d_settings['canCloseLive2d'] = true; // 显示 关闭看板娘 按钮,可选 true(真), false(假)
live2d_settings['canSwitchModel'] = true; // 显示 模型切换 按钮,可选 true(真), false(假)
live2d_settings['canSwitchTextures'] = true; // 显示 材质切换 按钮,可选 true(真), false(假)
live2d_settings['canSwitchHitokoto'] = true; // 显示 一言切换 按钮,可选 true(真), false(假)
live2d_settings['canTakeScreenshot'] = true; // 显示 看板娘截图 按钮,可选 true(真), false(假)
live2d_settings['canTurnToHomePage'] = true; // 显示 返回首页 按钮,可选 true(真), false(假)
live2d_settings['canTurnToAboutPage'] = true; // 显示 跳转关于页 按钮,可选 true(真), false(假)

// 模型切换模式
live2d_settings['modelStorage'] = true; // 记录 ID (刷新后恢复),可选 true(真), false(假)
live2d_settings['modelRandMode'] = 'switch'; // 模型切换,可选 'rand'(随机), 'switch'(顺序)
live2d_settings['modelTexturesRandMode']= 'rand'; // 材质切换,可选 'rand'(随机), 'switch'(顺序)

// 提示消息选项
live2d_settings['showHitokoto'] = true; // 显示一言
live2d_settings['showF12Status'] = true; // 显示加载状态
live2d_settings['showF12Message'] = false; // 显示看板娘消息
live2d_settings['showF12OpenMsg'] = true; // 显示控制台打开提示
live2d_settings['showCopyMessage'] = true; // 显示 复制内容 提示
live2d_settings['showWelcomeMessage'] = true; // 显示进入面页欢迎词

//看板娘样式设置
live2d_settings['waifuSize'] = '280x250'; // 看板娘大小,例如 '280x250', '600x535'
live2d_settings['waifuTipsSize'] = '250x70'; // 提示框大小,例如 '250x70', '570x150'
live2d_settings['waifuFontSize'] = '12px'; // 提示框字体,例如 '12px', '30px'
live2d_settings['waifuToolFont'] = '14px'; // 工具栏字体,例如 '14px', '36px'
live2d_settings['waifuToolLine'] = '20px'; // 工具栏行高,例如 '20px', '36px'
live2d_settings['waifuToolTop'] = '0px' // 工具栏顶部边距,例如 '0px', '-60px'
live2d_settings['waifuMinWidth'] = '768px'; // 面页小于 指定宽度 隐藏看板娘,例如 'disable'(禁用), '768px'
live2d_settings['waifuEdgeSide'] = 'left:0'; // 看板娘贴边方向,例如 'left:0'(靠左 0px), 'right:30'(靠右 30px)
live2d_settings['waifuDraggable'] = 'disable'; // 拖拽样式,例如 'disable'(禁用), 'axis-x'(只能水平拖拽), 'unlimited'(自由拖拽)
live2d_settings['waifuDraggableRevert'] = true; // 松开鼠标还原拖拽位置,可选 true(真), false(假)

// 其他杂项设置
live2d_settings['l2dVersion'] = '1.4.2'; // 当前版本
live2d_settings['l2dVerDate'] = '2018.11.12'; // 版本更新日期
live2d_settings['homePageUrl'] = 'auto'; // 主页地址,可选 'auto'(自动), '{URL 网址}'
live2d_settings['aboutPageUrl'] = 'https://www.fghrsh.net/post/123.html'; // 关于页地址, '{URL 网址}'
live2d_settings['screenshotCaptureName']= 'live2d.png'; // 看板娘截图文件名,例如 'live2d.png'
  • live2d.js:模型核心文件
  • waifu-tips.json:提示语数据
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    {
    "waifu": {
    "console_open_msg": ["哈哈,你打开了控制台,是想要看看我的秘密吗?"],
    "copy_message": ["你都复制了些什么呀,转载要记得加上出处哦"],
    "screenshot_message": ["照好了嘛,是不是很可爱呢?"],
    "hidden_message": ["我们还能再见面的吧…"],
    "load_rand_textures": ["我还没有其他衣服呢", "我的新衣服好看嘛"],
    "hour_tips": {
    "t5-7": ["早上好!一日之计在于晨,美好的一天就要开始了"],
    "t7-11": ["上午好!工作顺利嘛,不要久坐,多起来走动走动哦!"],
    "t11-14": ["中午了,工作了一个上午,现在是午餐时间!"],
    "t14-17": ["午后很容易犯困呢,今天的运动目标完成了吗?"],
    "t17-19": ["傍晚了!窗外夕阳的景色很美丽呢,最美不过夕阳红~"],
    "t19-21": ["晚上好,今天过得怎么样?"],
    "t21-23": ["已经这么晚了呀,早点休息吧,晚安~"],
    "t23-5": ["你是夜猫子呀?这么晚还不睡觉,明天起的来嘛"],
    "default": ["嗨~ 快来逗我玩吧!"]
    },
    "referrer_message": {
    "localhost": ["欢迎阅读<span style=\"color:#0099cc;\">『", "』</span>", " - "],
    "baidu": ["Hello! 来自 百度搜索 的朋友<br>你是搜索 <span style=\"color:#0099cc;\">", "</span> 找到的我吗?"],
    "so": ["Hello! 来自 360搜索 的朋友<br>你是搜索 <span style=\"color:#0099cc;\">", "</span> 找到的我吗?"],
    "google": ["Hello! 来自 谷歌搜索 的朋友<br>欢迎阅读<span style=\"color:#0099cc;\">『", "』</span>", " - "],
    "default": ["Hello! 来自 <span style=\"color:#0099cc;\">", "</span> 的朋友"],
    "none": ["欢迎阅读<span style=\"color:#0099cc;\">『", "』</span>", " - "]
    },
    "referrer_hostname": {
    "example.com": ["示例网站"],
    "www.fghrsh.net": ["FGHRSH 的博客"]
    },
    "model_message": {
    "1": ["来自 Potion Maker 的 Pio 酱 ~"],
    "2": ["来自 Potion Maker 的 Tia 酱 ~"]
    },
    "hitokoto_api_message": {
    "lwl12.com": ["这句一言来自 <span style=\"color:#0099cc;\">『{source}』</span>", ",是 <span style=\"color:#0099cc;\">{creator}</span> 投稿的", "。"],
    "fghrsh.net": ["这句一言出处是 <span style=\"color:#0099cc;\">『{source}』</span>,是 <span style=\"color:#0099cc;\">FGHRSH</span> 在 {date} 收藏的!"],
    "jinrishici.com": ["这句诗词出自 <span style=\"color:#0099cc;\">《{title}》</span>,是 {dynasty}诗人 {author} 创作的!"],
    "hitokoto.cn": ["这句一言来自 <span style=\"color:#0099cc;\">『{source}』</span>,是 <span style=\"color:#0099cc;\">{creator}</span> 在 hitokoto.cn 投稿的。"]
    }
    },
    "mouseover": [
    { "selector": ".container a[href^='http']", "text": ["要看看 <span style=\"color:#0099cc;\">{text}</span> 么?"] },
    { "selector": ".fui-home", "text": ["点击前往首页,想回到上一页可以使用浏览器的后退功能哦"] },
    { "selector": ".fui-chat", "text": ["一言一语,一颦一笑。一字一句,一颗赛艇。"] },
    { "selector": ".fui-eye", "text": ["嗯··· 要切换 看板娘 吗?"] },
    { "selector": ".fui-user", "text": ["喜欢换装 Play 吗?"] },
    { "selector": ".fui-photo", "text": ["要拍张纪念照片吗?"] },
    { "selector": ".fui-info-circle", "text": ["这里有关于我的信息呢"] },
    { "selector": ".fui-cross", "text": ["你不喜欢我了吗..."] },
    { "selector": "#tor_show", "text": ["翻页比较麻烦吗,点击可以显示这篇文章的目录呢"] },
    { "selector": "#comment_go", "text": ["想要去评论些什么吗?"] },
    { "selector": "#night_mode", "text": ["深夜时要爱护眼睛呀"] },
    { "selector": "#qrcode", "text": ["手机扫一下就能继续看,很方便呢"] },
    { "selector": ".comment_reply", "text": ["要吐槽些什么呢"] },
    { "selector": "#back-to-top", "text": ["回到开始的地方吧"] },
    { "selector": "#author", "text": ["该怎么称呼你呢"] },
    { "selector": "#mail", "text": ["留下你的邮箱,不然就是无头像人士了"] },
    { "selector": "#url", "text": ["你的家在哪里呢,好让我去参观参观"] },
    { "selector": "#textarea", "text": ["认真填写哦,垃圾评论是禁止事项"] },
    { "selector": ".OwO-logo", "text": ["要插入一个表情吗"] },
    { "selector": "#csubmit", "text": ["要[提交]^(Commit)了吗,首次评论需要审核,请耐心等待~"] },
    { "selector": ".ImageBox", "text": ["点击图片可以放大呢"] },
    { "selector": "input[name=s]", "text": ["找不到想看的内容?搜索看看吧"] },
    { "selector": ".previous", "text": ["去上一页看看吧"] },
    { "selector": ".next", "text": ["去下一页看看吧"] },
    { "selector": ".dropdown-toggle", "text": ["这里是菜单"] },
    { "selector": "c-player a.play-icon", "text": ["想要听点音乐吗"] },
    { "selector": "c-player div.time", "text": ["在这里可以调整<span style=\"color:#0099cc;\">播放进度</span>呢"] },
    { "selector": "c-player div.volume", "text": ["在这里可以调整<span style=\"color:#0099cc;\">音量</span>呢"] },
    { "selector": "c-player div.list-button", "text": ["<span style=\"color:#0099cc;\">播放列表</span>里都有什么呢"] },
    { "selector": "c-player div.lyric-button", "text": ["有<span style=\"color:#0099cc;\">歌词</span>的话就能跟着一起唱呢"] },
    { "selector": ".waifu #live2d", "text": ["干嘛呢你,快把手拿开", "鼠…鼠标放错地方了!"] }
    ],
    "click": [
    {
    "selector": ".waifu #live2d",
    "text": [
    "我...我...我真可爱!",
    "是...是不小心碰到了吧",
    "萝莉控是什么呀",
    "你看到我的小熊了吗",
    "再摸的话我可要报警了!⌇●﹏●⌇",
    "110吗,这里有个变态一直在摸我(ó﹏ò。)"
    ]
    }
    ],
    "seasons": [
    { "date": "01/01", "text": ["<span style=\"color:#0099cc;\">元旦</span>了呢,新的一年又开始了,今年是{year}年~"] },
    { "date": "02/14", "text": ["又是一年<span style=\"color:#0099cc;\">情人节</span>,{year}年找到对象了嘛~"] },
    { "date": "03/08", "text": ["今天是<span style=\"color:#0099cc;\">妇女节</span>!"] },
    { "date": "03/12", "text": ["今天是<span style=\"color:#0099cc;\">植树节</span>,要保护环境呀"] },
    { "date": "04/01", "text": ["悄悄告诉你一个秘密~<span style=\"background-color:#34495e;\">今天是愚人节,不要被骗了哦~</span>"] },
    { "date": "05/01", "text": ["今天是<span style=\"color:#0099cc;\">五一劳动节</span>,计划好假期去哪里了吗~"] },
    { "date": "06/01", "text": ["<span style=\"color:#0099cc;\">儿童节</span>了呢,快活的时光总是短暂,要是永远长不大该多好啊…"] },
    { "date": "09/03", "text": ["<span style=\"color:#0099cc;\">中国人民抗日战争胜利纪念日</span>,铭记历史、缅怀先烈、珍爱和平、开创未来。"] },
    { "date": "09/10", "text": ["<span style=\"color:#0099cc;\">教师节</span>,在学校要给老师问声好呀~"] },
    { "date": "10/01", "text": ["<span style=\"color:#0099cc;\">国庆节</span>,新中国已经成立69年了呢"] },
    { "date": "11/05-11/12", "text": ["今年的<span style=\"color:#0099cc;\">双十一</span>是和谁一起过的呢~"] },
    { "date": "12/20-12/31", "text": ["这几天是<span style=\"color:#0099cc;\">圣诞节</span>,主人肯定又去剁手买买买了~"] }
    ]
    }

在 Hexo 中使用

如果你用的是 Hexo,比如我用的是 Butterfly 主题,把 assets 整个文件夹复制到 source 目录中,然后再去 Config 文件中添加引入代码即可。

配置文件

比如修改 themes/butterfly/_config.yml,找到 inject 配置项,然后在 headbottom 中添加对应脚本引用,如下所示:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
inject:
head:
# 这里可以添加 CSS 等
bottom:
- <!-- 看板娘 -->
- <!-- waifu-tips.js 依赖 JQuery -->
- <script src="assets/jquery.min.js?v=3.3.1"></script>

- <!-- 实现拖动效果,需引入 JQuery UI -->
- <script src="assets/jquery-ui.min.js"></script>

- <!-- 使用 aotuload.js 引入看板娘 -->
- <script src="assets/autoload.js?v=1.4.2"></script>

- <script src="./assets/waifu-tips.js"></script>
- <script src="./assets/live2d.js"></script>

- <script type="text/javascript">
live2d_settings['modelId'] = 3;
live2d_settings['modelTexturesId'] = 0;
live2d_settings['modelStorage'] = true; // 记录 ID (刷新后恢复),可选 true(真), false(假)
live2d_settings['modelRandMode'] = 'switch'; // 模型切换,可选 'rand'(随机), 'switch'(顺序)
live2d_settings['modelTexturesRandMode'] = 'rand'; // 材质切换,可选 'rand'(随机), 'switch'(顺序)
live2d_settings['waifuSize'] = '280x250'; // 看板娘大小,例如 '280x250', '600x535'
live2d_settings['waifuEdgeSide'] = 'left:0'; // 看板娘贴边方向,例如 'left:0'(靠左 0px), 'right:30'(靠右 30px)
live2d_settings['waifuDraggable'] = 'axis-x'; // 拖拽样式,例如 'disable'(禁用), 'axis-x'(只能水平拖拽), 'unlimited'(自由拖拽)
live2d_settings['waifuDraggableRevert'] = true; // 松开鼠标还原拖拽位置,可选 true(真), false(假)

// 其他杂项设置
live2d_settings['l2dVersion'] = '1.4.2'; // 当前版本
live2d_settings['l2dVerDate'] = '2018.11.12'; // 版本更新日期
live2d_settings['homePageUrl'] = 'index.html'; // 主页地址,可选 'auto'(自动), '{URL 网址}'
live2d_settings['aboutPageUrl'] = 'https://www.fghrsh.net/post/123.html'; // 关于页地址, '{URL 网址}'

initModel("https://www.example.com/path/to/waifu-tips.json")
- </script>

只不过随便改个地方都会报错

initModel(“https://www.example.com/path/to/waifu-tips.json“)

改成 ——> 就不能用了

initModel(“https://文件路径/waifu-tips.json”)

我不理解 /_ \


不是Hexo的话就按正常格式引入到html文件中

其中的路径的assets部分记得改成自己的路径

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<!-- 看板娘 -->
<!-- waifu-tips.js 依赖 JQuery 库 -->
<script src="assets/jquery.min.js?v=3.3.1"></script>

<!-- 实现拖动效果,需引入 JQuery UI -->
<script src="assets/jquery-ui.min.js"></script>

<!-- 使用 aotuload.js 引入看板娘 -->
<script src="assets/autoload.js?v=1.4.2"></script>

<script src="./assets/waifu-tips.js"></script>
<script src="./assets/live2d.js"></script>

<script type="text/javascript">
live2d_settings['modelId'] = 3;
live2d_settings['modelTexturesId'] = 0;
live2d_settings['modelStorage'] = true; // 记录 ID (刷新后恢复),可选 true(真), false(假)
live2d_settings['modelRandMode'] = 'switch'; // 模型切换,可选 'rand'(随机), 'switch'(顺序)
live2d_settings['modelTexturesRandMode'] = 'rand'; // 材质切换,可选 'rand'(随机), 'switch'(顺序)
live2d_settings['waifuSize'] = '280x250'; // 看板娘大小,例如 '280x250', '600x535'
live2d_settings['waifuEdgeSide'] = 'left:0'; // 看板娘贴边方向,例如 'left:0'(靠左 0px), 'right:30'(靠右 30px)
live2d_settings['waifuDraggable'] = 'axis-x'; // 拖拽样式,例如 'disable'(禁用), 'axis-x'(只能水平拖拽), 'unlimited'(自由拖拽)
live2d_settings['waifuDraggableRevert'] = true; // 松开鼠标还原拖拽位置,可选 true(真), false(假)

// 其他杂项设置
live2d_settings['l2dVersion'] = '1.4.2'; // 当前版本
live2d_settings['l2dVerDate'] = '2018.11.12'; // 版本更新日期
live2d_settings['homePageUrl'] = 'index.html'; // 主页地址,可选 'auto'(自动), '{URL 网址}'
live2d_settings['aboutPageUrl'] = 'https://www.fghrsh.net/post/123.html'; // 关于页地址, '{URL 网址}'

initModel("https://www.example.com/path/to/waifu-tips.json")
</script>

重点提示

  1. waifu-tips.js 依赖 jQuery 库,所以必须先引入 jquery.min.js
  2. 要实现拖动效果,必须引入 jquery-ui.min.js
  3. autoload.js 会自动帮你加载模型,配置信息都写在 waifu-tips.js 中。
  4. waifu-tips.json 中可以修改对话提示语,也可以换成你自己的模型文件。

还有个目前没有解决的问题,配置好之后只能在主页显示,不能在文章也显示,后面找时间再看看吧…


小结

就是这些啦,虽然中间坑不少,但是一旦配置好了,页面就能自动显示一个萌萌的 Live2D 看板娘!希望你也能顺利搞定,遇到问题欢迎随时问我~

*(ฅ>ω<ฅ)

文章作者: Tokepson
文章链接: https://toke648.github.io/2025/06/21/%E7%9C%8B%E6%9D%BF%E5%A8%98%E9%85%8D%E7%BD%AE/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 Tokepson的博客

评论
avatar
Tokepson
技术爱好者、二次元爱好者、创客
喜欢编曲,绘画,写作,编程 以及任何与知识、学习、探索和创造有关的事物
人生就是一段寻找自我的过程。
够了,事到如今,能够拥有这个,这样就够了。。。
前往小站...
公告
本站的评论系统采用Waline国际版, 因此国内无法使用(要不换个别的吧...)

主域名:
https://toke648.github.io/
https://gannia.top/

备用域名:
暂无

小站域名:
暂无

想产出一些高质量的长文。。。