有三个js库可以是吸纳
face-api
tracking.js
tensorflow.js,注意由于是google的服务,可能你的网络无法直连,请确保你的网络能链接谷歌
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Face Detection</title>
<script src="https://cdn.jsdelivr.net/npm/@tensorflow/tfjs"></script>
<script src="https://cdn.jsdelivr.net/npm/@tensorflow-models/blazeface"></script>
</head>
<body>
<video id="video" width="720" height="560" autoplay></video>
<script>
const video = document.getElementById('video');
navigator.mediaDevices.getUserMedia({ video: {} })
.then(stream => {
video.srcObject = stream;
})
.catch(err => console.error(err));
async function run() {
const model = await blazeface.load();
video.addEventListener('play', async () => {
const canvas = document.createElement('canvas');
document.body.append(canvas);
canvas.width = video.width;
canvas.height = video.height;
const ctx = canvas.getContext('2d');
setInterval(async () => {
const predictions = await model.estimateFaces(video, false);
ctx.clearRect(0, 0, canvas.width, canvas.height);
predictions.forEach(prediction => {
ctx.beginPath();
ctx.lineWidth = "4";
ctx.strokeStyle = "blue";
ctx.rect(
prediction.topLeft[0],
prediction.topLeft[1],
prediction.bottomRight[0] - prediction.topLeft[0],
prediction.bottomRight[1] - prediction.topLeft[1]
);
ctx.stroke();
});
}, 100);
});
}
run();
</script>
</body>
</html>
网友回复
如何用html写出网页滚动视频播放卡片视觉差异效果的代码?
程序员如何低成本搭建代理进行科学上网学习技术?
threejs如何做个三维搭积木的游戏?
three如何实现标记多个起始路过地点位置后选择旅行工具(飞机汽车高铁等),最后三维模拟行驶动画导出mp4?
ai实时驱动的3d数字人可视频聊天的开源技术有吗
swoole+phpfpm如何实现不同域名指向不同目录的多租户模式?
如何用go替换nginx实现请求phpfpm解析运行php脚本?
有没有浏览器离线运行进行各种文档、图片、视频格式转换的开源工具?
如何使用go语言搭建一个web防火墙?
linux如何检测特定网络协议比如http协议中报文是否包含特点关键词并阻止返回给客户?


