前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >帮B站开启圣诞节模式~

帮B站开启圣诞节模式~

作者头像
mixlab
发布2018-12-27 11:46:46
4370
发布2018-12-27 11:46:46
举报

给bilibili上的所有视频里的人物都带上圣诞帽,

开启节日模式,

长按二维码查看视频效果。

def CodeFun

( video ,FaceRecognition ):

采用的技术栈

face-api.js

chrome插件开发

步骤

STEP1

在manifest.json里设置加载face-api.js库。

代码语言:javascript
复制
"lib/face-api.min.js"
"js/content_script.js"

这样的话,在网页加载的时候,就可以通过content_script.js,调用face-api,并注入js代码至b站。

STEP2

通过开发者工具查找到b站视频的class属性,在网站加载时添加一个蒙板,用于绘制圣诞帽。

代码语言:javascript
复制
let videoContainer = document.querySelector('.bilibili-player-video');

let faceMask = document.createElement('div');

faceMask.setAttribute('id', 'mix-faceMask');

videoContainer.appendChild(faceMask);

添加的faceMask的style需要设置成:

代码语言:javascript
复制
position: absolute;

face-api加载预训练模型(可以从github或者自己的服务器下载)

代码语言:javascript
复制
await faceapi.loadSsdMobilenetv1Model('https://justadudewhohacks.github.io/face-api.js/models');

STEP3

获取视频的某一帧,检测人脸。

代码语言:javascript
复制
let videoEl=document.querySelector('.bilibili-player-video video');

const detections = await faceapi.detectAllFaces(videoEl, faceDetectionOptions);

STEP4

把检测到的人脸区域,绘制上圣诞帽,圣诞帽我这里直接转成base64的形式,写在了content_script.js里。

代码语言:javascript
复制
let baseImg=new Image();

baseImg.src='data:image/png;base64,...';

根据每一帧检测到人脸的结果,绘制圣诞帽。

代码语言:javascript
复制
let c = document.createElement('canvas');

for (let index = 0; index < detections.length; index++) {

        let box = detections[index].box;

        let x = box.x, y = box.y, w = box.width, h = box.height;

        ctx.drawImage(baseImg, x - w * 0.25, y -0.85 * h, w, h);

};

至此,自动戴圣诞帽的功能就完成啦~

return 圣诞模式

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-12-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 无界社区mixlab 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
人脸识别
腾讯云神图·人脸识别(Face Recognition)基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、比对、搜索、验证、五官定位、活体检测等多种功能,为开发者和企业提供高性能高可用的人脸识别服务。 可应用于在线娱乐、在线身份认证等多种应用场景,充分满足各行业客户的人脸属性识别及用户身份确认等需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档