Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/386.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/angularjs/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript D3多折线图鼠标悬停问题_Javascript_Angularjs_D3.js_Tooltip_Mouseover - Fatal编程技术网

Javascript D3多折线图鼠标悬停问题

Javascript D3多折线图鼠标悬停问题,javascript,angularjs,d3.js,tooltip,mouseover,Javascript,Angularjs,D3.js,Tooltip,Mouseover,我在这篇文章中找到了我面临的问题 “nemesv”为实际问题提供了解决方案 var myApp = angular.module('app', []); myApp.directive("lineChart", function() { return { restrict: 'E', scope: { data: '=', id: '@' }, link: function (scope, element, attrs) {

我在这篇文章中找到了我面临的问题

“nemesv”为实际问题提供了解决方案

var myApp = angular.module('app', []);
myApp.directive("lineChart", function() {
  return {
    restrict: 'E',
    scope: {
      data: '=',
      id: '@'
    },
    link: function (scope, element, attrs) {
      scope.$watch( 'data', function ( data ) {
        d3.select("#"+attrs.id).select("svg").remove();
        if (data) {
          var margin = {top: 20, right: 20, bottom: 30, left: 40},
              width = element[ 0 ].parentElement.offsetWidth - margin.left - margin.right,
              height = element[ 0 ].parentElement.offsetHeight - margin.top - margin.bottom;
          var parseDate = d3.time.format("%d-%b-%y").parse;
          var bisectDate = d3.bisector(function(d) { return d[0]; }).left;
          var x = d3.time.scale()
              .range([0, width]);
          var y = d3.scale.linear()
              .range([height, 0]);
          var xAxis = d3.svg.axis()
              .scale(x)
              .orient("bottom")
              .innerTickSize(-height)
              .ticks(4)
              .outerTickSize(0)
              .tickPadding(5)
              .tickFormat(function(d) { return d3.time.format('%d/%m %H:%M')(new Date(d)); });
          var yAxis = d3.svg.axis()
              .scale(y)
              .orient("left")
              .innerTickSize(-width)
              .outerTickSize(0)
              .tickPadding(10);
          var line = d3.svg.line()
              .x(function(d) { return x(d[0]); })
              .y(function(d) { return y(d[1]); });
          var svg = d3.select(element[0]).append("svg")
              .attr("width", '100%')
              .attr("height", '100%')
              .attr('viewBox','0 0 '+ element[ 0 ].parentElement.offsetWidth +' '+ element[ 0 ].parentElement.offsetHeight )
            .append("g")
              .attr("transform", "translate(" + margin.left + "," + margin.top + ")");
          var minX = d3.min(data, function (item) { return d3.min(item.values, function (d) { return d[0]; }); });
          var maxX = d3.max(data, function (item) { return d3.max(item.values, function (d) { return d[0]; }); });
          var minY = d3.min(data, function (item) { return d3.min(item.values, function (d) { return d[1]; }); });
          var maxY = d3.max(data, function (item) { return d3.max(item.values, function (d) { return d[1]; }); });
          x.domain([minX, maxX]);
          y.domain([0, maxY]);
          svg.append("g")
              .attr("class", "x axis")
              .attr("transform", "translate(0," + height + ")")
              .call(xAxis);
          svg.append("g")
              .attr("class", "y axis")
              .call(yAxis);
          var domaine = svg.selectAll(".domaine")
              .data(data)
              .enter().append("g")
              .attr("class", "domaine");
          domaine.append("path")
              .attr("class", "line")
              .attr("d", function (d) {
                  return line(d.values);
              })
              .style("stroke", function (d) {
                return d.color;
              });
          var focus = svg.append("g")
              .attr("class", "focus")
              .style("display", "none");

          for(var i=0;i<data.length;i++){
              focus.append("g")
                .attr("class", "focus"+i)
                .append("circle")
                .attr("r", 4.5);
              svg.select(".focus"+i)
                .append("text")
                .attr("x", 9)
                .attr("dy", ".35em");
          }
          svg.append("rect")
              .attr("class", "overlay")
              .attr("width", width)
              .attr("height", height)
              .on("mouseover", function() { focus.style("display", null); })
              .on("mouseout", function() { focus.style("display", "none"); })
              .on("mousemove", mousemove);
          function mousemove() {
              var x0 = x.invert(d3.mouse(this)[0]);
              var series = data.map(function(e) {
                    var i = bisectDate(e.values, x0, 1),
                        d0 = e.values[i - 1],
                        d1 = e.values[i];
                    return x0 - d0[0] > d1[0] - x0 ? d1 : d0;
                  });
              for(var i=0; i<series.length;i++){
                var selectedFocus = svg.selectAll(".focus"+i);
                selectedFocus.attr("transform", "translate(" + x(series[i][0]) + "," + y(series[i][1]) + ")");
                selectedFocus.select("text").text(series[i][1]);
              }
            }
        }
      });
    }
  };
});
function MainCtrl($scope) {
$scope.lineData = [{"key": "users","color": "#16a085","values": [[1413814800000,4034.418],[1413815400000,5604.155000000001],[1413816000000,6343.079],[1413816600000,7308.226],[1413817200000,9841.185],[1413817800000,6571.891],[1413818400000,4660.6005000000005],[1413819000000,4555.4795],[1413819600000,5963.723],[1413820200000,9179.9595]]},{"key": "users 2","color": "#d95600","values": [[1413814800000,3168.183],[1413815400000,1530.8435],[1413816000000,2416.071],[1413816600000,1274.309],[1413817200000,1105.0445],[1413817800000,2086.0299999999997],[1413818400000,712.642],[1413819000000,1676.725],[1413819600000,3721.46],[1413820200000,2887.7975]]}];
}
var myApp=angular.module('app',[]);
指令(“折线图”,函数(){
返回{
限制:'E',
范围:{
数据:'=',
id:“@”
},
链接:函数(范围、元素、属性){
范围:$watch(‘数据’、函数(数据){
d3.选择(“#”+attrs.id)。选择(“svg”).remove();
如果(数据){
var margin={顶部:20,右侧:20,底部:30,左侧:40},
宽度=元素[0]。parentElement.offsetWidth-margin.left-margin.right,
高度=元素[0]。parentElement.offsetHeight-margin.top-margin.bottom;
var parseDate=d3.time.format(“%d-%b-%y”).parse;
var-bisectDate=d3.bisector(函数(d){返回d[0];});
var x=d3.time.scale()
.范围([0,宽度]);
变量y=d3.scale.linear()
.范围([高度,0]);
var xAxis=d3.svg.axis()
.比例(x)
.orient(“底部”)
.1尺寸(高度)
.滴答声(4)
.outerTickSize(0)
.1(5)
.tickFormat(函数(d){返回d3.time.format('%d/%m%H:%m')(新日期(d));});
var yAxis=d3.svg.axis()
.比例(y)
.东方(“左”)
.innerTickSize(-宽度)
.outerTickSize(0)
.1(10);
var line=d3.svg.line()
.x(函数(d){返回x(d[0]);})
.y(函数(d){返回y(d[1]);});
var svg=d3.select(元素[0]).append(“svg”)
.attr(“宽度”,“100%”)
.attr(“高度”,“100%”)
.attr('viewBox','0'+元素[0]。parentElement.offsetWidth+''+元素[0]。parentElement.offsetHeight)
.附加(“g”)
.attr(“转换”、“平移”(+margin.left+)、“+margin.top+”);
var minX=d3.min(数据,函数(item){返回d3.min(item.values,函数(d){返回d[0];});});
var maxX=d3.max(数据,函数(item){返回d3.max(item.values,函数(d){返回d[0];});});
var minY=d3.min(数据,函数(item){返回d3.min(item.values,函数(d){返回d[1];});});
var maxY=d3.max(数据,函数(item){返回d3.max(item.values,函数(d){返回d[1];});});
x、 域([minX,maxX]);
y、 域([0,maxY]);
svg.append(“g”)
.attr(“类”、“x轴”)
.attr(“变换”、“平移(0)”、“高度+”)
.呼叫(xAxis);
svg.append(“g”)
.attr(“类”、“y轴”)
.呼叫(yAxis);
var domaine=svg.selectAll(“.domaine”)
.数据(数据)
.enter().append(“g”)
.attr(“类别”、“领地”);
domaine.append(“路径”)
.attr(“类”、“行”)
.attr(“d”,函数(d){
返回线(d值);
})
.样式(“笔划”,功能(d){
返回d.color;
});
var focus=svg.append(“g”)
.attr(“类”、“焦点”)
.样式(“显示”、“无”);
对于(var i=0;i d1[0]-x0?d1:d0;
});
对于(var i=0;i