通过 tracking.js 在 canvas 上进行面部跟踪
Face tracking on canvas via tracking.js
tracking.js 使得在 <img>
上检测人脸变得相当容易。他们有一个 wonderful hello world example 为此,但我想知道是否有人想出如何在 <canvas>
元素上检测人脸。
我试过:
var canvas = document.getElementById('canvas'),
context = canvas.getContext('2d'),
img = img = context.getImageData(0, 0, canvas.width, canvas.height);
var tracker = new tracking.ObjectTracker(['face']);
tracker.setStepSize(1.7);
tracking.track('#canvas', tracker);
tracker.on('track', function(event) {
event.data.forEach(function(rect) {
window.plot(rect.x, rect.y, rect.width, rect.height);
});
});
window.plot = function(x, y, w, h) {
var rect = document.createElement('div');
document.querySelector('#preview').appendChild(rect);
rect.classList.add('rect');
rect.style.width = w + 'px';
rect.style.height = h + 'px';
rect.style.left = (img.offsetLeft + x) + 'px';
rect.style.top = (img.offsetTop + y) + 'px';
rect.style.borderColor = '#ff0000';
};
什么都没发生 :-/
我遇到了同样的问题。只是改变顺序。将 tracking.track('#canvas', tracker)
放在 tracker.on
- 部分后面,它应该可以工作。
但是如果你想 "highlight" 它在 canvas 上,你应该在上下文中绘制而不是绘图。也可以直接传imageData
tracker.track(imgData, width, height)
...玩得开心。
tracking.js 使得在 <img>
上检测人脸变得相当容易。他们有一个 wonderful hello world example 为此,但我想知道是否有人想出如何在 <canvas>
元素上检测人脸。
我试过:
var canvas = document.getElementById('canvas'),
context = canvas.getContext('2d'),
img = img = context.getImageData(0, 0, canvas.width, canvas.height);
var tracker = new tracking.ObjectTracker(['face']);
tracker.setStepSize(1.7);
tracking.track('#canvas', tracker);
tracker.on('track', function(event) {
event.data.forEach(function(rect) {
window.plot(rect.x, rect.y, rect.width, rect.height);
});
});
window.plot = function(x, y, w, h) {
var rect = document.createElement('div');
document.querySelector('#preview').appendChild(rect);
rect.classList.add('rect');
rect.style.width = w + 'px';
rect.style.height = h + 'px';
rect.style.left = (img.offsetLeft + x) + 'px';
rect.style.top = (img.offsetTop + y) + 'px';
rect.style.borderColor = '#ff0000';
};
什么都没发生 :-/
我遇到了同样的问题。只是改变顺序。将 tracking.track('#canvas', tracker)
放在 tracker.on
- 部分后面,它应该可以工作。
但是如果你想 "highlight" 它在 canvas 上,你应该在上下文中绘制而不是绘图。也可以直接传imageData
tracker.track(imgData, width, height)
...玩得开心。