Многострочный график D3 не отображает линию - PullRequest
0 голосов
/ 23 сентября 2018

Я пытаюсь создать многострочный график (всего две линии), но не могу отобразить путь для обеих линий.Есть какая-то проблема, если у меня есть одна строка, но она не работает, если я добавляю вторую.Это мой код:

function line({title, xAxis, yAxis, data, source, place}) {

  const {window} = new JSDOM('<!DOCTYPE html>');

  window.d3 = d3.select(window.document);

  const margin = {top: 50, right: 20, bottom: 200, left: 70};
  const width = 600 - margin.left - margin.right;
  const height = 500 - margin.top - margin.bottom;

  const heading = `${title} ${place}`;

  const x = d3.scaleTime().range([0, width]);
  const y = d3.scaleLinear().range([height, 0]);

  const valueLine = d3.line()
    .x((d) => x(d.key))
    .y((d) => y(d.value));

  const valueLineEngland = d3.line()
      .x((d) => x(d.key))
      .y((d) => y(d.valueEngland));

  window.d3.select('body')
    .attr('width', width)
    .attr('height', height + 50)
    .append('svg')
    .attr('class', 'radar-graphic')
    .attr('xmlns', 'http://www.w3.org/2000/svg')
    .attr('width',  width + margin.left + margin.right)
    .attr('height', height + margin.top + margin.bottom)
    .append('style').text(css);

  const svg = window.d3.select('svg').append('g')
    .attr('transform', 'translate(' + margin.left + ',' + margin.top + ')');

  const parseTime = d3.timeParse('%d-%b-%y');

  data.forEach((d) => d.key = parseTime(d.key));

  x.domain(d3.extent(data, (d) => d.key));
  y.domain([0, d3.max(data, (d) => d.value) + d3.max(data, (d) => d.value)*0.15]);
  // y.domain([0, d3.max(data, function(d) {
    //   return Math.max(d.value, d.valueEngland); })]);

  // add the Y gridlines
  svg.append("g")
      .attr("class", "grid")
      .call(make_y_gridlines()
          .tickSize(-width)
          .tickFormat("")
          .ticks(5)
      )

  // Add the valueline path.
  svg.append('path')
    .data([data])
    .attr('class', 'line')
    .attr("fill", "none")
    .attr("stroke", "steelblue")
    .attr("stroke-linejoin", "round")
    .attr("stroke-linecap", "round")
    .attr("stroke-width", 2)
    .attr('d', valueLine);

  svg.append('path')
      .data([data])
      .attr('class', 'lineEngland')
      .attr("fill", "none")
      .attr("stroke", "steelblue")
      .attr("stroke-linejoin", "round")
      .attr("stroke-linecap", "round")
      .attr("stroke-width", 2)
      .attr('d', valueLineEngland);


    // line labels

  svg.append('g')
  .classed('labels-group', true)
  .selectAll('text')
  .data(data)
  .enter()
  .append('text')
  .filter(function(d, i) { return i === (data.length - 1) })
  .classed('label',true)
  .attr("x", function (d) {
      return x(d.key) - 20;
  })
  .attr("y", function (d) {
      return y(d.value) - 8;
  })
  .style('font-family', 'Lato, Arial')
  .style('fill', 'black')
  .style('font-size', '14px')
  .text(function (d) {
      return d.value;
  });

  svg.append('g')
  .classed('labels-group', true)
  .selectAll('text')
  .data(data)
  .enter()
  .append('text')
  .filter(function(d, i) { return i === (data.length - 1) })
  .classed('label',true)
  .attr("x", function (d) {
      return x(d.key) - 20;
  })
  .attr("y", function (d) {
      return y(d.valueEngland) - 8;
  })
  .style('font-family', 'Lato, Arial')
  .style('fill', 'black')
  .style('font-size', '14px')
  .text(function (d) {
      return d.valueEngland;
  });



// Add the scatterplot
   svg.selectAll("dot")
       .data(data)
    .enter().append("circle")
    .filter(function(d, i) { return i === (data.length - 1) })
      .attr("r", 3.5)
      .attr("cx", function(d) { return x(d.key); })
      .attr("cy", function(d) { return y(d.value); })
      .style('fill', 'steelblue');

  svg.selectAll("dotEngland")
          .data(data)
       .enter().append("circle")
       .filter(function(d, i) { return i === (data.length - 1) })
         .attr("r", 3.5)
         .attr("cx", function(d) { return x(d.key); })
         .attr("cy", function(d) { return y(d.valueEngland); })
         .style('fill', 'red');

  //  title
  svg.append('text')
    .attr('x', (margin.left))
    .attr('y', 0 - (margin.top / 2))
    .attr('text-anchor', 'middle')
    .style('font-size', '20px')
    .style('font-weight', 'bold')
    .style('font-family', 'Lato, Arial')
    .style('fill', 'black')
    .text(heading);

  //  x axis
  svg.append('g')
    .attr('transform', 'translate(0,' + height + ')')
    .call(d3.axisBottom(x).ticks(5))
    .selectAll('text')
    .style('text-anchor', 'end')
    .attr('dx', '1.2em')
    .attr('dy', '1.1em')
    .attr('transform', 'rotate(0)');

function make_y_gridlines() {
    return d3.axisLeft(y)
  }

  // y axis
  svg.append('g')
  .attr("class", "axisSteelblue")
  .attr("class", "y axis")
    .call(d3.axisLeft(y).ticks(5));


  svg.append('text')
    .attr('transform', 'rotate(-90)')
    .attr('y', -65)
    .attr('x', 0 - (height / 6))
    .attr('dy', '1em')
    .attr("fill", "steelblue")
    .style('font-size', '11px')
    .style('color', 'steelblue')
    .style('text-anchor', 'middle')
    .style('font-style', 'italics')
    .style('font-family', 'Lato, Arial')
    .text(yAxis);

  svg.append('text')
      .attr('transform',
          'translate(' + (-19) + ' ,' +
        (height + margin.top + 20) + ')')
      .style('text-anchor', 'middle')
      .style('font-size', '10px')
      .style('font-family', 'Lato, Arial')
      .text("Source:");

  svg.append('text')
    .attr('transform',
      'translate(' + (59) + ' ,' +
      (height + margin.top + 20) + ')')
    .style('text-anchor', 'middle')
    .style('font-size', '10px')
    .style('font-family', 'Lato, Arial')
    .text(source);


    return [window.d3.select('body').html(), null];

};

Кажется, он не получает координаты должным образом, потому что я получаю результат NaN для некоторых точек линии.

Надеюсь, вы можете помочь мне понять, что это такоездесь происходит.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...