将AngularJS连接到Plotly

3

我希望使用AngularJS从服务器获取数据,并使用Plotly绘制数据。我正在后台运行一个服务器。下面是我使用的HTML代码。我认为它非常简单明了。

<!DOCTYPE html>
<html>
<head>
    <title>Testign Plotly</title>
    <script type="text/javascript" src='plotly.min.js'></script>
    <script type="text/javascript" src='jquery.min.js'></script>
    <script type="text/javascript" src='angular.min.js'></script>
    <script type="text/javascript" src='plotApp.js'></script>
</head>
<body ng-app='myApp'>
<div id="graph" style="width:600px;height:250px;"></div>
<script type="text/javascript" ng-controller='plotXY'>

    // var data = [{
    //     x:[1,2,3,4],
    //     y:[5,3,6,12],
    // }];

    Plotly.plot( $('#graph')[0], {{data}}  , {margin: {t:0}});
</script>
<hr><div ng-controller='plotXY'>{{data}}</div>

</body>
</html>

我有一个名为plotApp.js的AngularJS脚本,如下所示,非常简单...

var app = angular.module('myApp', []);

app.controller('plotXY', function($scope, $http){

    $scope.data = {};

    $scope.refresh = function(){
        $http.get('http://localhost:8080/data').success(function(data){
            $scope.data = {};
            for(k in data){$scope.data[k] = data[k].map(Number);}
            $scope.data = [$scope.data];
        });
    };

    $scope.refresh();
});

现在,这个编译好的HTML(从浏览器中保存)如下所示...
<!DOCTYPE html>
<html><head>
<meta http-equiv="content-type" content="text/html; charset=windows-1252"><style type="text/css">@charset "UTF-8";[ng\:cloak],[ng-cloak],[data-ng-cloak],[x-ng-cloak],.ng-cloak,.x-ng-cloak,.ng-hide:not(.ng-hide-animate){display:none !important;}ng\:form{display:block;}.ng-animate-shim{visibility:hidden;}.ng-anchor{position:absolute;}</style>
    <title>Testign Plotly</title>
    <script type="text/javascript" src="Testign%20Plotly_files/plotly.js"></script><style></style>
    <script type="text/javascript" src="Testign%20Plotly_files/jquery.js"></script>
    <script type="text/javascript" src="Testign%20Plotly_files/angular.js"></script>
    <script type="text/javascript" src="Testign%20Plotly_files/plotApp.js"></script>
</head>
<body class="ng-scope" ng-app="myApp">
<div id="graph" style="width:600px;height:250px;"></div>
<script class="ng-scope" type="text/javascript" ng-controller="plotXY">

    // var data = [{
    //     x:[1,2,3,4],
    //     y:[5,3,6,12],
    // }];

    Plotly.plot( $('#graph')[0], {{data}}  , {margin: {t:0}});
</script>
<hr><div class="ng-scope ng-binding" ng-controller="plotXY">[{"y":[1.26642e-14,2.8044e-14,6.1484e-14,1.33457e-13],"x":[-10,-9,-8,-7]}]</div>
</body></html>

从上面代码中可以看出,位于 div 标签内的部分得到了正确数据的更新,但是脚本标签内的部分没有!

顺便说一下,如果我使用被注释掉的 data 变量,我就能够看到绘图结果。因此,Plotly 是可以工作的。

我想让客户端从服务器获取数据并让 Plotly 显示它。如果我从服务器创建整个页面并发送过去,我是可以做到的。然而,我认为这种方式更好。但出于某种原因,我似乎无法将 Plotly 中的数据源连接到 angularJS 中的数据源。我会非常感激一些帮助……

1个回答

0

Plotly 更新数据的方法似乎是通过 Plotly.restyle()

var update = {x: [[0,1,2], y: [[5,2,4]]};
Plotly.restyle(graphDiv, update, 0);

确保在更新数组时使用双重数组。Plotly支持通过数组同时更新多个跟踪,因此[[0,1,2],[1,3,4]]将更新两个跟踪。


原来你必须使用一个“指令”。这是我在这里得到了很多帮助后写的一个小教程:http://codepen.io/omolluska/post/rapid-prototyping-of-systems-for-visual-display-iii - ssm
有趣。我认为我仍然会使用 Plotly.restyle() 而不是 newPlot() 来仅更新轨迹,而不是重新绘制整个图形。 - Durd

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接