0

多亏了这篇文章,我已经设法运行了以下代码。Add Microsoft's Emotion API to HTML website

<HTML>
<head>
    <title>JSSample</title>
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.0/jquery.min.js"></script>
<body>
<script type="text/javascript">
$(function() {
        $.ajax({
            url: "https://api.projectoxford.ai/emotion/v1.0/recognize",
            beforeSend: function(xhrObj){
                // Request headers
                xhrObj.setRequestHeader("Content-Type","application/json");
                xhrObj.setRequestHeader("Ocp-Apim-Subscription-Key","my-key-here");
            },
            type: "POST",
            // Request body
             data: '{"url": "https://oxfordportal.blob.core.windows.net/emotion/recognition1.jpg"}',
        })
        .done(function(data) {
            alert("success");

        })
        .fail(function(error) {
        console.log(error.getAllResponseHeaders());

            alert("fail");
        });
    });
</script>
</body>
</head>
</html>

这似乎是个愚蠢的问题,但我一直想知道如何从 HTML 文件中获取情绪输出?即,我想生成一个文本文件,而不是成功警报,该文件显示每种情绪的 Emotions API 的输出(就像在他们的网站上所做的那样)。

4

3 回答 3

0

data是一个数组,每个面一个项目。如果您只想转储文本,可以调用JSON.stringify(data). 如果您想在 HTML 中漂亮地打印它,请查看如何使用 JavaScript 漂亮地打印 JSON?.

于 2016-01-20T16:23:24.323 回答
0

一种解决方案可能是阅读有关Blob的信息。您可以从 done() 中的 ajax 调用中获取响应并创建您需要的文本文件。这是我在 JSFiddle 上找到的使用 Blob 的示例:

var saveData = (function () {
    var a = document.createElement("a");
    document.body.appendChild(a);
    a.style = "display: none";
    return function (data, fileName) {
        var json = JSON.stringify(data),
            blob = new Blob([json], {type: "octet/stream"}),
            url = window.URL.createObjectURL(blob);
        a.href = url;
        a.download = fileName;
        a.click();
        window.URL.revokeObjectURL(url);
    };
}());

var data = { x: 42, s: "hello, world", d: new Date() },
    fileName = "my-download.json";

saveData(data, fileName);

资源

于 2016-01-20T15:45:56.663 回答
0

我已经在我的网站HowHappy.co.uk中完成了这项工作,该网站也在 GitHub 上:https ://github.com/martinkearn/How-Happy

我在网站中显示数据的方式是在 Javascript 中枚举人脸数组,并使用基本的 CSS 在正确的位置显示矩形,并使用 Bootstrap 弹出框显示详细数据。

这个回复太多了,所以我建议你看看 GitHub repo,但这里有一些关键位

Javascript

var dataString = JSON.stringify(response); 
var data = JSON.parse(dataString); 

    //draw rectangle for each face
    $.each(data.Faces, function (index, value) {

        var rect = document.createElement('div');
        rect.className = "rect";
        rect.style.height = value.faceRectangle.height + "px";
        rect.style.width = value.faceRectangle.width + "px";
        rect.style.left = value.faceRectangle.left + "px";
        rect.style.top = value.faceRectangle.top + "px";
        rect.id = "rect" + index;

        $('#result').append(rect);

        //add popover
        var popoverBody = "Happiness: " + Number((value.scores.happiness).toFixed(2))
            + "<br>Fear: " + Number((value.scores.fear).toFixed(2))
            + "<br>Anger: " + Number((value.scores.anger).toFixed(2))
            + "<br>Contempt: " + Number((value.scores.contempt).toFixed(2))
            + "<br>Disgust: " + Number((value.scores.disgust).toFixed(2))
            + "<br>Neutral: " + Number((value.scores.neutral).toFixed(2))
            + "<br>Sadness: " + Number((value.scores.sadness).toFixed(2))
            + "<br>Surprise: " + Number((value.scores.surprise).toFixed(2));
        $('#rect' + index).popover({
            title: (index + 1)
            content: popoverBody,
            html: "true",
            trigger: "click"
        });

    });

CSS

.rect {
    position: absolute;
    border-color: #FFEA0E;
    border-style: solid;
    border-width: 4px;
    z-index: 10;
}

#result {
    position: relative;
    text-align: center;
    margin: 0 auto;
    width: auto;
}

#resultDetails {
    font-size: 3rem;
    text-align: center;
}
于 2016-05-03T15:11:10.103 回答