jQuery 動(dòng)態(tài)人臉掃描是一種常用的人臉檢測(cè)技術(shù),可以在網(wǎng)頁(yè)上實(shí)現(xiàn)實(shí)時(shí)監(jiān)測(cè)人臉并進(jìn)行相關(guān)操作。
$(function() { // 獲取視頻流 navigator.mediaDevices.getUserMedia({ video: true }) .then(function(stream) { // 創(chuàng)建視頻元素 var video = document.createElement('video'); video.srcObject = stream; video.play(); // 創(chuàng)建 canvas 元素 var canvas = document.createElement('canvas'); canvas.width = video.videoWidth; canvas.height = video.videoHeight; var ctx = canvas.getContext('2d'); // 定時(shí)執(zhí)行掃描人臉代碼 setInterval(function() { // 將視頻畫(huà)面繪制到 canvas ctx.drawImage(video, 0, 0, canvas.width, canvas.height); // 通過(guò)算法檢測(cè)人臉位置 var faceX = 0; var faceY = 0; var faceWidth = 0; var faceHeight = 0; // 算法待完善... // 在 canvas 上繪制人臉框 ctx.beginPath(); ctx.lineWidth = '4'; ctx.strokeStyle = 'red'; ctx.rect(faceX, faceY, faceWidth, faceHeight); ctx.stroke(); }, 100); }) .catch(function(err) { console.log('getUserMedia error: ' + err); }); });
上面的代碼使用了 navigator.mediaDevices.getUserMedia 方法獲取攝像頭視頻流,并使用 setInterval 定時(shí)執(zhí)行人臉檢測(cè)代碼。人臉檢測(cè)的算法需要根據(jù)實(shí)際情況進(jìn)行調(diào)整,此處未給出具體實(shí)現(xiàn)。最后,使用 canvas 繪制人臉框來(lái)顯示掃描結(jié)果。
通過(guò)上述代碼,我們可以實(shí)現(xiàn)簡(jiǎn)單的動(dòng)態(tài)人臉掃描,可以用于多種應(yīng)用場(chǎng)景,如刷臉簽到、人臉支付等。