H5实现iPhoneX上的Animoji

简介: 先上图: 前段时间突发奇想,想到前端是不是可以利用摄像头设备增强页面的交互能力。 比如我们见过有些页面设计,页面元素会随着鼠标的移动而移动,结合元素的层次感,可以形成视差效果。 那么,如果能获取到人脸在屏幕前的移动变化,就可以做到页面元素跟随人脸变化,而不是跟随鼠标变化,这可能是种更棒的视差体验。

先上图:

7d3d65187af9afc1f1f062a1a19f3f1640b2c7f4

前段时间突发奇想,想到前端是不是可以利用摄像头设备增强页面的交互能力。

比如我们见过有些页面设计,页面元素会随着鼠标的移动而移动,结合元素的层次感,可以形成视差效果。

那么,如果能获取到人脸在屏幕前的移动变化,就可以做到页面元素跟随人脸变化,而不是跟随鼠标变化,这可能是种更棒的视差体验。

于是动手实践后,就有了这个效果:

0d213a1202b650493c67be786e6822f8ee9e4107

做出来后,我又想到,如果把这个应用在3D游戏里,比如CS,就可以实现一个场景:玩家在屏幕前把脑袋往右边伸,屏幕里的那个躲在转角处的土匪人物,就能看到左边更大的视野。

想想还不错吧?

然而我不是做游戏的,这个idea我发挥不了,如果有做3D页游的程序猿看到,可以试试看。

又过了一两个星期,我又想到了iPhoneX上的animoji,也可以通过这样的方式实现。

于是动手实践后,就有了你最先看到的那张图的效果。

但是我的3D这方面还不是很擅长,所以没能实现让那坨便便的表情跟随人的表情变化。

Live Demo

视差DEMO

Animoji

源码

源码仓库:github.com/jaweii/AR-s…

源码克隆下来后,安装依赖项:

 
  1. npm install

以及安装parcel到全局:

 
  1. npm install -g parcel-bundler

启动命令:

 
  1. // 启动Animoji demo
  2. npm run dev:animoji
  3. // 启动视差Demo
  4. npm run dev

实现方式

通过计算机的摄像设备捕捉画面,使用Clmtrackr.js识别人脸,3D引擎使用的Three.js。

Clmtrackr.js可以捕捉到人脸在屏幕中的各个位置:

f1757a5ee63105fab42c44235f4145eb831e4222

在项目启动后,应用会不断的获取上图[41]点的坐标,当位置变化后,3D物体也做相应的变化。

原文发布时间:2018年06月17日

本文来源:掘金 如需转载请联系原作者

相关文章
|
9月前
|
iOS开发 开发者
iPhoneX-关于底部的那个一个横条的问题
作为一个iOS开发者,每一次苹果的推陈出新,都会为引用适配和开发过程带来新的挑战,最近刚入手了一个iPhone X。把玩的还是很舒适的,但是应用的适配总是有一定的过程的,这种阵痛还是要忍受的。但是有一个体验就不是很好了,在看视频的时候视频底部永远会有那么一个被苹果称之为“HomeIndicator”的横条。我是没有什么强迫症,但是也很烦。所以今天就打算研究一下怎么去掉这个讨人厌的横条。
|
编解码 安全 Android开发
iPhone苹果手机如何设置使用非系统自带铃声
自从开始使用苹果手机,如何设置自定义的手机铃声成了困扰我的难题,每次听着系统自带的铃声响起都很不喜,拿到iPhone plus我就开始研究怎么设置自定义的铃声,试了很多办法,都不行。电脑是win10系统,查了很多方法,下了各种软件,都没解决这问题。网上讲的最多的是下载iTunes云云,我卸了装,装了卸的,反复各种试都行不通;就卡在win10环境下的iTunes与iPhone手机连接不上,提示如图的问题:
357 0
iPhone苹果手机如何设置使用非系统自带铃声
|
传感器 安全 小程序
小程序对IPhone全面屏手机底部黑线的安全区域处理
小程序对IPhone全面屏手机底部黑线的安全区域处理
300 0
小程序对IPhone全面屏手机底部黑线的安全区域处理
|
iOS开发
小米5X来了!颜值秒爆iPhone!
最近的科技圈不太平,上周,Hugo君刚聊完MIUI 9,这次,小米真正的重头戏要来了!
139 0
小米5X来了!颜值秒爆iPhone!
|
Shell iOS开发
Iphone攻与防-一
iphone-越狱机Hook APP 价值
1610 0
|
Web App开发 移动开发 安全
H5网页适配 iPhoneX,就是这么简单
  iPhoneX 取消了物理按键,改成底部小黑条,这一改动导致网页出现了比较尴尬的屏幕适配问题。对于网页而言,顶部(刘海部位)的适配问题浏览器已经做了处理,所以我们只需要关注底部与小黑条的适配问题即可(即常见的吸底导航、返回顶部等各种相对底部 fixed 定位的元素)。
3044 0
|
前端开发 安全 传感器