face_camera.html 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <!doctype html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>tracking.js - face with camera</title>
  6. <link rel="stylesheet" href="assets/demo.css">
  7. <script src="../build/tracking-min.js"></script>
  8. <script src="../build/data/face-min.js"></script>
  9. <script src="../node_modules/dat.gui/build/dat.gui.min.js"></script>
  10. <script src="assets/stats.min.js"></script>
  11. <style>
  12. video, canvas {
  13. margin-left: 230px;
  14. margin-top: 120px;
  15. position: absolute;
  16. }
  17. </style>
  18. </head>
  19. <body>
  20. <div class="demo-title">
  21. <p><a href="http://trackingjs.com" target="_parent">tracking.js</a> - get user's webcam and detect faces</p>
  22. </div>
  23. <div class="demo-frame">
  24. <div class="demo-container">
  25. <video id="video" width="320" height="240" preload autoplay loop muted></video>
  26. <canvas id="canvas" width="320" height="240"></canvas>
  27. </div>
  28. </div>
  29. <script>
  30. window.onload = function() {
  31. var video = document.getElementById('video');
  32. var canvas = document.getElementById('canvas');
  33. var context = canvas.getContext('2d');
  34. var tracker = new tracking.ObjectTracker('face');
  35. tracker.setInitialScale(4);
  36. tracker.setStepSize(2);
  37. tracker.setEdgesDensity(0.1);
  38. tracking.track('#video', tracker, { camera: true });
  39. tracker.on('track', function(event) {
  40. context.clearRect(0, 0, canvas.width, canvas.height);
  41. event.data.forEach(function(rect) {
  42. context.strokeStyle = '#a64ceb';
  43. context.strokeRect(rect.x, rect.y, rect.width, rect.height);
  44. context.font = '11px Helvetica';
  45. context.fillStyle = "#fff";
  46. context.fillText('x: ' + rect.x + 'px', rect.x + rect.width + 5, rect.y + 11);
  47. context.fillText('y: ' + rect.y + 'px', rect.x + rect.width + 5, rect.y + 22);
  48. });
  49. });
  50. var gui = new dat.GUI();
  51. gui.add(tracker, 'edgesDensity', 0.1, 0.5).step(0.01);
  52. gui.add(tracker, 'initialScale', 1.0, 10.0).step(0.1);
  53. gui.add(tracker, 'stepSize', 1, 5).step(0.1);
  54. };
  55. </script>
  56. </body>
  57. </html>