首页 > 其他分享 >Vue+live2d实现虚拟人物互动(一次体验叙述)

Vue+live2d实现虚拟人物互动(一次体验叙述)

时间:2024-08-05 18:52:59浏览次数:9  
标签:Vue 人物 wanko 用法 width live2d 虚拟 model

目录

故事的开头:

最终的实现效果:

实现步骤:

第一步:下载重要文件

第二步:创建vue项目文件,将刚下载文件拷贝到public目录下

第三步:在index.html文件中引入js

第四步:使用,去创建人物

初步用法

基础用法

人物模型替换

高级用法(只有一些模型提供)

事件监听

显示对话框

完整代码:

参考文章:

结语:


故事的开头:

故事的开头是这样的,因为有一个模块是做类似文心一言那样的界面,但是我感觉这样有点太单调了,突发奇想就有了这样的对话(如下图)。

 很显然,最开始这样的想法比较不切合实际(因为我们都只是个大二学生),文本转语音这个很容易,我早在这个想法提出前就已经利用百度的api给做好了,但是要在web端的页面去实现出一个虚拟人物,这未免有点太过于扯蛋了。但是,既然想法已经有了,就只放在哪里不去试试吗?很显然,我并不是这样的人,在这一天,我去广泛的查询了csdn,掘金以及知乎甚至b站都去查找了。最终终于摸索出来了一个开源的别人写好了的东西!!!既然感觉没问题了,那就尝试下页面的大致思路(如下图) 

画的比较丑,毕竟当时只是急匆匆去做一个大概想法。 

最终的实现效果:

<iframe allowfullscreen="true" data-mediaembed="csdn" frameborder="0" id="8DvG8kIG-1722758923535" src="https://live.csdn.net/v/embed/414965"></iframe>

拿来测试

实现步骤:

第一步:下载重要文件

首先我们需要去下载点live2d以及人物模型的配置

live2d看板娘资源文件_html看板娘资源-CSDN文库

下载好后是这样的:

解压后这个文件夹里面是这样的:

第二步:创建vue项目文件,将刚下载文件拷贝到public目录下

第三步:在index.html文件中引入js

	<!-- 看板娘 -->
	<script type="text/javascript" src="./live2dw/lib/L2Dwidget.min.js"></script>

然后我们就可以在自己需要的模块中去创建自己的人物了

第四步:使用,去创建人物

初步用法
基础用法

我们第一步下载的那个文件提供了很多人物模型

window.L2Dwidget
				//对人物的属性配置
				.init({
					pluginRootPath: '../live2dw/', //人物文件夹的位置
					pluginJsPath: 'lib/',
					pluginModelPath: 'live2d-widget-model-wanko/assets/',
					model: {
						jsonPath: '../live2dw/live2d-widget-model-wanko/assets/wanko.model.json'
					},
					display: { //人物的属性配置
						position: 'left',
						width: 350,
						height: 800,
						hOffset: 200, // 横向偏移
						vOffset: -100 // 纵向偏移
					}, 
				});

通过在mounted(vue2写法)/onMounted(() => {}(vue3写法)周期内,写下该代码就可以加载配置的文件。当然有一些模型是提供去触摸对话的。那么我们就可以提供一个事件监听。

人物模型替换

只需要将打框框的地方给替换成其他人物名称(基础用法图片中model-xxx,xxx就是名称)就好了

高级用法(只有一些模型提供)
事件监听
L2Dwidget.on('*', (name) => {
    console.log('事件为: ' + name)
})
显示对话框
L2Dwidget.init({
    dialog: {
        enable: true,
        script: {
            'tap body': 'xxxx',
            'tap face': 'xxxxx',
        }
    }
});
完整代码:
<template>
	<div class="app" ref="box">
		<div class="box1"></div>
    <div class="box2">
      <el-container>
  <el-header>
    Header
  </el-header>
  <el-main>
    Main
  </el-main>
  <el-footer>
    Footer
  </el-footer>
</el-container>
    </div>
	</div>
</template>
<script>
	export default {
		mounted() {
			window.L2Dwidget
				//此处是对点击人物时触发事件的监听
				.on('*', (name) => {
				})
				//对人物的属性配置
				.init({
					pluginRootPath: '../live2dw/', //人物文件夹的位置
					pluginJsPath: 'lib/',
					pluginModelPath: 'live2d-widget-model-wanko/assets/',
					model: {
						jsonPath: '../live2dw/live2d-widget-model-wanko/assets/wanko.model.json'
					},
					dialog: {
						enable: true, //是否开启对话框
            script: {
              'tap body': '你好呀!这里是,ai智能小助手!!!',
              'hover .app': '嘿!需要帮助吗?',
              'tap face': '汪汪'
						}
					},
					display: { //人物的属性配置
						position: 'left',
						width: 350,
						height: 800,
						hOffset: 200, // 横向偏移
						vOffset: -100 // 纵向偏移
					}, 
				});
		}
	}
</script>
<style>
	body {
		margin: 0;
		width: 100%;
		
	}
	.app {
		width: 100%;
		height: 100%;
    display: inline-flex;
	}
  
 .box1{
  width: 50%;
  height: 700px;
  border: 1px solid red;
  
 }
  .box2{
    width: 50%;
    height: 700px;
    border: 1px solid red;
  }
</style>

参考文章:

https://juejin.cn/post/6844904032423641096

http://t.csdnimg.cn/6ydbx

结语:

感谢观看!!!!

标签:Vue,人物,wanko,用法,width,live2d,虚拟,model
From: https://blog.csdn.net/m0_75148088/article/details/140907008

相关文章

  • Vuex简介及数据管理
    Vuex1.Vuex简介Vuex就是一个vue的状态管理工具(状态就是数据)。其实vuex就是一个插件,帮忙管理Vue通用的数据而已。日常生活中的购物车数据、个人信息等。在Vue中特点为:多个组件使用,多个组件共同维护这份数据。vuex优势:共同维护一份数据,数据集中化管理响应式变化操作简洁(v......
  • 懂个锤子Vue VueRouter路由深入浅出
    VueRouter路由深入浅出VueRouter介绍:VueRouter是Vue.js官方的路由管理器:极大地简化了在单页面应用程序SPA-SinglePageApplication:中构建导航和页面切换的复杂性;单页面应用程序SPA单页面应用程序SPA,SinglePageApplication:在用户首次访问时加载整个应用程序......
  • Parallels Desktop19.3.0虚拟机软件可以让你在Mac上同时运行Windows、Linux等多个系统
    ParallelsDesktop19,一个虚拟机软件,可以让你在Mac上同时运行Windows、Linux等多个系统。听起来是不是很厉害?但其实它还有更多隐藏的小技巧等着你去发现。如果你还在因为Mac和Windows之间的不兼容而苦恼,那么ParallelsDesktop19就是你的救星。它可以帮助你轻松地在Mac上运行Win......
  • vue2 - 最新详细实现高德地图绘制动态热力图详细教程,在某区域或城市地图上做“热力图
    效果图在vue2、nuxt2项目开发中,详解引入使用高德地图接收热力图数据并渲染“热力图”效果功能,在地图上的某个区域或某个城市(可多个)、省份等自由绘制对应的热力图层,各城市地区同时加载渲染热力流量区域用以对比,根据不同的颜色代表人口密度、客流量、旅游人数、交通流量......
  • Vue的混入(mixin)
    一、mixin是什么我们在开发组件的过程中,常常会遇到一些具有相同逻辑和功能的组件。如果每个组件各写一套方法会导致代码冗余,后期更改的时候也要一个个的改非常的浪费时间和精力。mixins就是将这些多个相同的逻辑抽离出来,各个组件只需要引入mixins,就能实现一次写代码,多组件受益......
  • 计算机毕业设计django+vue二手车管理系统【开题+程序+论文】
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着汽车消费市场的日益成熟与二手车交易量的持续增长,构建一个高效、便捷、信息透明的二手车管理系统显得尤为重要。传统二手车交易往往存......
  • AnyGo for Mac(虚拟定位软件)永久破解下载 兼容最新系统
    AnyGoforMac是一款专为Mac用户设计的虚拟定位软件,它允许用户轻松模拟地理位置,改变设备在地图上的显示位置。这款软件以其简洁的操作界面和强大的功能而著称,用户只需简单几步即可实现虚拟定位,无需复杂的设置。AnyGo支持多种应用场景,无论是游戏定位、社交软件位置模拟还是其他需......
  • ssm+vue高校疫情防控系统的设计与实现【开题+程序+论文】-计算机毕业设计
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着全球新冠疫情的持续影响,高等教育机构作为人员密集、流动性大的场所,其疫情防控工作显得尤为重要。传统的疫情管理模式往往依赖于人工统计、纸质报......
  • ssm+vue高校社团管理系统【开题+程序+论文】-计算机毕业设计
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着高等教育的普及与深化,高校社团作为学生自我管理与发展的重要平台,日益成为校园文化不可或缺的一部分。然而,传统的高校社团管理方式往往依赖于纸质......
  • ssm+vue高校本科成绩管理系统设计【开题+程序+论文】-计算机毕业设计
    本系统(程序+源码)带文档lw万字以上文末可获取一份本项目的java源码和数据库参考。系统程序文件列表开题报告内容研究背景随着高校教育规模的不断扩大和信息化技术的飞速发展,传统的手工或简单电子化管理方式已难以满足高校本科成绩管理的复杂需求。当前,高校本科生成绩管理......