首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么这个小提琴手不工作: tracking.js人脸检测实例

为什么这个小提琴手不工作: tracking.js人脸检测实例
EN

Stack Overflow用户
提问于 2015-05-08 12:21:18
回答 4查看 1.6K关注 0票数 1

我试图得到一个JSFiddle的friends.html工作的例子,但悬停效果并不像网站显示的那样有效。这是我的JSFiddle:

https://jsfiddle.net/lolptdr/25yqfyjo/6/

为了绕过MIME类型的抱怨,我不得不在raw.githubusercontent.com上使用一个代理,并将它更改为raw.githack.com,用于HTML中引用的外部脚本。没有其他控制台错误,那么还有什么问题吗?

为了达到trackingjs.com网站上显示的效果,我还能查些什么呢?

代码语言:javascript
复制
window.onload = function() {
  var img = document.getElementById('img');
  var tracker = new tracking.ObjectTracker('face');
  tracking.track(img, tracker);
  tracker.on('track', function(event) {
    event.data.forEach(function(rect) {
      plotRectangle(rect.x, rect.y, rect.width, rect.height);
    });
  });
  var friends = ['Thomas Middleditch', 'Martin Starr', 'Zach Woods'];
  var plotRectangle = function(x, y, w, h) {
    var rect = document.createElement('div');
    var arrow = document.createElement('div');
    var input = document.createElement('input');
    input.value = friends.pop();
    rect.onclick = function name() {
      input.select();
    };
    arrow.classList.add('arrow');
    rect.classList.add('rect');
    rect.appendChild(input);
    rect.appendChild(arrow);
    document.getElementById('photo').appendChild(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';
  };
};
代码语言:javascript
复制
* {
  margin: 0;
  padding: 0;
  font-family: Helvetica, Arial, sans-serif;
}
.demo-title {
  position: absolute;
  width: 100%;
  background: #2e2f33;
  z-index: 2;
  padding: .7em 0;
}
.demo-title a {
  color: #fff;
  border-bottom: 1px dotted #a64ceb;
  text-decoration: none;
}
.demo-title p {
  color: #fff;
  text-align: center;
  text-transform: lowercase;
  font-size: 15px;
}
.demo-frame {
  background: url(frame.png) no-repeat;
  width: 854px;
  height: 658px;
  position: fixed;
  top: 50%;
  left: 50%;
  margin: -329px 0 0 -429px;
  padding: 95px 20px 45px 34px;
  overflow: hidden;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
.demo-container {
  width: 100%;
  height: 530px;
  position: relative;
  background: #eee;
  overflow: hidden;
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
}
.dg.ac {
  z-index: 100 !important;
  top: 50px !important;
}
/* example's CSS */

#photo:hover .rect {
  opacity: .75;
  transition: opacity .75s ease-out;
}
.rect:hover * {
  opacity: 1;
}
.rect {
  border-radius: 2px;
  border: 3px solid white;
  box-shadow: 0 16px 28px 0 rgba(0, 0, 0, 0.3);
  cursor: pointer;
  left: -1000px;
  opacity: 0;
  position: absolute;
  top: -1000px;
}
.arrow {
  border-bottom: 10px solid white;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  height: 0;
  width: 0;
  position: absolute;
  left: 50%;
  margin-left: -5px;
  bottom: -12px;
  opacity: 0;
}
input {
  border: 0px;
  bottom: -42px;
  color: #a64ceb;
  font-size: 15px;
  height: 30px;
  left: 50%;
  margin-left: -90px;
  opacity: 0;
  outline: none;
  position: absolute;
  text-align: center;
  width: 180px;
  transition: opacity .35s ease-out;
}
#img {
  position: absolute;
  top: 50%;
  left: 50%;
  margin: -173px 0 0 -300px;
}
代码语言:javascript
复制
<script src="https://raw.githack.com/eduardolundgren/tracking.js/master/build/tracking.js"></script>
<script src="https://raw.githack.com/eduardolundgren/tracking.js/master/build/data/face.js"></script>
<div class="demo-title">
  <p><a href="http://trackingjs.com" target="_parent">tracking.js</a> - hover image to see all faces detected</p>
</div>
<div class="demo-frame">
  <div class="demo-container"> <span id="photo"><img id="img" src="https://raw.githubusercontent.com/eduardolundgren/tracking.js/master/examples/assets/faces.jpg" /></span>

  </div>
</div>

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2017-01-28 01:00:21

以上所有的答案都很好地说明了为什么失败的原因,但是下面是一个使用flickr映像的tracker.js在jsfiddle中的工作示例:http://jsfiddle.net/rambutan2000/v5v49bax/

Flickr似乎在标题中正确设置了访问控制-允许-原产地。我在使用代理(crossorigin.me)时取得了有限的成功。

Thi是这个示例的简化版本:world.html

首先,我必须获得跟踪器包含的有效URL,我使用了以下服务:http://rawgit.com。查看jsfiddle中的“外部资源”。

我基于一个使用XMLHttpRequest作为缓冲区检索图像数据的示例,然后将其加载到img元素中。这消除了img元素上的一些CORS问题,因为它来自代码而不是URL。其余部分是从上面引用的跟踪器示例中直接撕开的。

联署材料:

代码语言:javascript
复制
// use http://rawgit.com/ to get js urls from github
// use https://crossorigin.me/ to get around CORS for image reference
function _arrayBufferToBase64(buffer) {
    var binary = ''
    var bytes = new Uint8Array(buffer)
    var len = bytes.byteLength;
    for (var i = 0; i < len; i++) {
        binary += String.fromCharCode(bytes[i])
    }
    return window.btoa(binary);
}

window.plot = function(x, y, w, h) {
    var $rect = $("<div></div>");
    $rect.addClass("rect");
    $rect.offset({ top: y, left: x });
    $rect.width(w).height(h);    
    $("#demo-container").append($rect);    
};

var imgURL = 'https://c1.staticflickr.com/4/3943/15715482121_d7120a6e0b_z.jpg';  // Works!
//var imgURL = 'https://placeimg.com/640/480/people'; // Does not work
//var imgURL = 'https://crossorigin.me/https://placeimg.com/640/480/people'; // Works!


var oReq = new XMLHttpRequest();
oReq.open("GET", imgURL, true);
oReq.responseType = "arraybuffer";

oReq.onload = function (oEvent) {
    var arrayBuffer = oReq.response; // Note: not oReq.responseText
    if (arrayBuffer) {
        var x = imgURL.split('.');
        var ext = x[x.length - 1];
        var b64img = _arrayBufferToBase64(arrayBuffer);
        $("#img").attr('src', 'data:image/' + ext + ';base64,' + b64img).appendTo($('body'));        

        var img = document.getElementById('img');
        var tracker = new tracking.ObjectTracker(['face']);

        tracker.setStepSize(1.7);
                tracking.track('#img', tracker);

        tracker.on('track', function(event) {        
            event.data.forEach(function(rect) {
                console.log(rect);
              window.plot(rect.x, rect.y, rect.width, rect.height);
            });
        });
    }
};

oReq.send(null);

HTML:

代码语言:javascript
复制
<div id="demo-container">
  <img id="img" src="" />
</div>

CSS:

代码语言:javascript
复制
.rect {
  position:absolute;
  border-style: solid;
  border-width: 2px;
  border-color: blue;
}

#demo-container {
  position:absolute;
}
票数 1
EN

Stack Overflow用户

发布于 2015-10-01 15:22:45

这是一个快速的答案,但希望它能帮助你理解正在发生的事情。它失败了,因为代码试图加载这个资源:http://trackingjs.com/bower/tracking.js/examples/assets/frame.png

您可以看到它加载在原始页面:friends.html上,并且您可以看到您的JSFiddle也尝试加载它(尽管使用的是不同的主机,相同的相对路径)。当浏览器试图获取https://fiddle.jshell.net/25yqfyjo/7/show/frame.png时,会发生404,因为该文件不存在,这将停止执行。

在运行JSFiddle时,请查看开发人员工具。我的猜测是,不应该包含加载的另一个脚本(https://raw.githack.com/eduardolundgren/tracking.js/master/build/data/face.js),它似乎是二进制数据(呈现图片)。相反,请阅读http://trackingjs.com/的基本文档,并了解如何在您自己的照片上使用人脸检测。想必,它会更容易和工作。

票数 1
EN

Stack Overflow用户

发布于 2015-10-05 12:59:15

交叉起源:我更新了您的代码以使用DOMContentLoaded并手动触发事件,这样您就可以看到问题:https://jsfiddle.net/25yqfyjo/11/

所以我把这件事

代码语言:javascript
复制
// Create the event
var event = new CustomEvent("DOMContentLoaded", { "detail": "Content Loaded trigger" });

// Dispatch/Trigger/Fire the event
document.dispatchEvent(event);

您可以在控制台中看到错误:

Uncaught :未能在“CanvasRenderingContext2D”上执行“getImageData”:画布已被交叉原点污染 data.tracking.trackCanvasInternal_ @ Tracking.js:196(匿名函数)@ tracking.js:221img.onload @ tracking.js:472

这是因为您将图像从另一个URL加载到代码正在使用的画布中(尽管您看不到它,var tracker = new tracking.ObjectTracker('face');将使用画布),我认为为了JS的目的,您可以将图像更改为Base64编码的,这将纠正问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30123759

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档