Ошибка: недопустимое значение для <path> attribute d = ".. для круговой диаграммы

0

Я создаю диаграмму пончиков в d3.js и AngularJS. У меня есть функция drawGraph функции директивной ссылки. Данные представляют собой массив объектов и поступают с сервера. Вот как выглядит функция.

Функция:

scope.drawGraph = function(data){
            console.log(data);
            var width = 560,
                height = 400,
                radius = Math.min(width, height) / 2.6,
                legendRectSize = 18,
                legendSpacing = 4; 

            var color = d3.scale.category20();

            var pie = d3.layout.pie()
                        .value(function(d) { return d.amount; })
                        .sort(null);

            var arc = d3.svg.arc()
                        .innerRadius(radius - 90)
                        .outerRadius(radius - 70);

            var svg = d3.select("#chart").append("svg")
                        .attr("width", width)
                        .attr("height", height)
                        .append("g")
                        .attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");

            var path = svg.selectAll("path")
                        .data(pie(data))
                        .enter().append("path")
                        .attr("fill", function(d, i) {return color(i); })
                        .attr("d", arc);

            var ticks = svg.selectAll("line").data(pie(data)).enter().append("line");
                        ticks.attr("x1", 0)
                        .attr("x2", 0)
                        .attr("y1", -radius+10)
                        .attr("y2", -radius+70)
                        .attr("stroke", "gray")
                        .attr("transform", function(d) {
                          return "rotate(" + (d.startAngle+d.endAngle)/2 * (180/Math.PI) + ")";
                        });

            var labels = svg.selectAll("text").data(pie(data)).enter().append("text");
                        labels.attr("class", "value")
                       .attr("transform", function(d) {
                           var dist=radius+5;
                           var winkel=(d.startAngle+d.endAngle)/2;
                           var x=dist*Math.sin(winkel);
                           var y=-dist*Math.cos(winkel);
                           return "translate(" + x + "," + y + ")";
                        })
                        .attr("dy", "0.35em")
                        .attr("text-anchor", "middle")
                        .style('fill', 'rgba(0, 0, 0, 0.498039)')
                        .text(function(d){
                            return d.data.category;
                        });
        };

scope.drawGraph(scope.data); // Function call

scope.data:

[{amount: 100, category: 'food'},{amount: 150, category: 'fuel'}, {amount: 50, category: 'grocery'},{amount: 250, category: 'Entertainment'}]

Вот что возвращает консоль:

Ошибка: недопустимое значение для атрибута d = "M5.134096196425442e-15, -83.84615384615384A83.84615384615384,883.84615384615384 0 1,1 NaN, NaNLNaN, NaNA63.84615384615384,63.84615384615384 0 1,0 3,909449397278089e-15, -63. 84615384615384Z"

А также:

Ошибка: недопустимое значение для атрибута d = "MNaN, NaNA83.84615384615384,83.84615384615384 0 1,1 NaN, NaNLNaN, NaNA63.84615384615384,63.84615384615384 0 1,0 NaN, NaNZ"

Ошибка: недопустимое значение для атрибута transform = "rotate (NaN)"

Ошибка: недопустимое значение для атрибута transform = "translate (NaN, NaN)"

Я относительно новичок в d3.js.

Заранее спасибо.

  • 0
    Пожалуйста, вставьте ваши данные json scope.data, чтобы мы могли помочь вам
  • 0
    это массив объектов. Я добавил это в коде. Спасибо
Теги:
d3.js

1 ответ

1
Лучший ответ

Я использовал ваш код для создания скрипки и не столкнулся с проблемой, которую вы получили.

играть на скрипке

<div id="chart" style="height:500px;">
    <svg></svg>
</div>
  • 0
    Благодарю. но я все еще получаю ошибку.
  • 0
    @Mak JSFiddle работает для меня без каких-либо ошибок. Вы сталкиваетесь с ошибками при выполнении скрипта или в вашем собственном коде? Может быть, вы могли бы сделать JSFiddle, который поможет воспроизвести ошибку для остальных из нас.
Показать ещё 1 комментарий

Ещё вопросы

Сообщество Overcoder
Наверх
Меню