先上图:
【H5实现iPhoneX上的Animoji】
文章插图
前段时间突发奇想,想到前端是不是可以利用摄像头设备增强页面的交互能力 。
比如我们见过有些页面设计,页面元素会随着鼠标的移动而移动,结合元素的层次感,可以形成视差效果 。
那么,如果能获取到人脸在屏幕前的移动变化,就可以做到页面元素跟随人脸变化,而不是跟随鼠标变化,这可能是种更棒的视差体验 。
于是动手实践后,就有了这个效果:
文章插图
做出来后,我又想到,如果把这个应用在3D游戏里,比如CS,就可以实现一个场景:玩家在屏幕前把脑袋往右边伸,屏幕里的那个躲在转角处的土匪人物,就能看到左边更大的视野 。
想想还不错吧?
然而我不是做游戏的,这个idea我发挥不了,如果有做3D页游的程序猿看到,可以试试看 。
又过了一两个星期,我又想到了上的,也可以通过这样的方式实现 。
于是动手实践后,就有了你最先看到的那张图的效果 。
但是我的3D这方面还不是很擅长,所以没能实现让那坨便便的表情跟随人的表情变化 。
Live Demo
视差DEMO
源码
源码仓库://AR-s…
源码克隆下来后,安装依赖项:
文章插图
npm
以及安装到全局:
npm-g -
启动命令:
// 启动run dev:// 启动视差 run dev实现方式
通过计算机的摄像设备捕捉画面,使用.js识别人脸,3D引擎使用的Three.js 。
.js可以捕捉到人脸在屏幕中的各个位置:
文章插图
在项目启动后,应用会不断的获取上图[41]点的坐标,当位置变化后,3D物体也做相应的变化 。
- TfidfVectorizer计算TF-IDF 四、实现
- mysql存储animoji_无需iPhoneX
- 【Ubuntu】基于C++实现人脸识别
- 转 Andriod实现推送的解决方案
- 差值查找—Java实现
- 站在风口上的程序员,就应该有高收入!
- Spark Streaming 实现数据实时统计案例
- 文字转语音真人发声如何实现?不妨借助这些工具
- 软件开发:站在风口上的低代码
- 年薪30万-50万,站在风口上的大数据面临150万的人才紧缺