Добавление метки для гистограммы GRaphael вызывает ошибку paper.labelise

Я пытаюсь реализовать простую гистограмму с метками. Я использую пример barchart на github графаэль.

Я получаю следующую ошибку, когда пытаюсь добавить функцию метки в свой код ниже. Также, похоже, есть открытая проблема по этому поводу на Github.

TypeError: paper.labelise is not a function

Номер строки, на которую указывает ошибка, - это строка 344 в g.bar.js.

У кого-нибудь есть обходной путь для этой ошибки? Я использую Raphaël 2.0.2 и g.Raphael 0.51.

Код из этого номера строки как часть g.bar.js: -

var label = paper.labelise(multi ? labels[j] && labels[j][i] : labels[i], multi ? values[j][i] : values[i], total);

Пример кода, который вызывает эту ошибку: -

<!--<!doctype html>-->
<html lang="en">
<head>
  <meta charset="utf-8">
  <title>Static Bar Charts</title>
  <link rel="stylesheet" href="css/demo.css" type="text/css" media="screen" charset="utf-8">
  <link rel="stylesheet" href="css/demo-print.css" type="text/css" media="print" charset="utf-8">
  <script src="https://raw.github.com/DmitryBaranovskiy/g.raphael/master/raphael-min.js" type="text/javascript" charset="utf-8"></script>
  <script src="https://raw.github.com/DmitryBaranovskiy/g.raphael/master/g.raphael.js" type="text/javascript" charset="utf-8"></script>
  <script src="https://raw.github.com/DmitryBaranovskiy/g.raphael/master/g.bar.js" type="text/javascript" charset="utf-8"></script>
  <script type="text/javascript" charset="utf-8">
      window.onload = function () {
          var r = Raphael("holder"),
                  data1 = [[55, 20, 13, 32, 5, 1, 2, 10], [10, 2, 1, 5, 32, 13, 20, 55], [12, 20, 30]],
                  data2 = [[55, 20, 13, 32, 5, 1, 2, 10], [10, 2, 1, 5, 32, 13, 20, 55], [12, 20, 30]],
                  data3 = [[55, 20, 13, 32, 5, 1, 2, 10], [10, 2, 1, 5, 32, 13, 20, 55], [12, 20, 30]],
                  txtattr = { font: "12px 'Fontin Sans', Fontin-Sans, sans-serif" };

          r.text(160, 10, "Single Series Chart").attr(txtattr);
//          r.text(480, 10, "Multiline Series Chart").attr(txtattr);
//          r.text(160, 250, "Multiple Series Stacked Chart").attr(txtattr);
//          r.text(480, 250, 'Multiline Series Stacked Vertical Chart. Type "round"').attr(txtattr);
          var labels = ["Company X", "Company Y", "Company Z"]
          var barChart = r.barchart(10, 10, 300, 220, [[9,5,2]], 0, {stacked: true, type: "soft"}) .label([labels]);
          //r.barchart(10, 10, 300, 220, [[55, 20, 13, 32, 5, 1, 2, 10]], 0, {type: "sharp"}).label([['C', 'D', 'E', 'G', 'L', 'M', 'P', 'S1']]);
          //barChart.label(['a','b','c']);
//          r.barchart(330, 10, 300, 220, data1);
//          r.barchart(10, 250, 300, 220, data2, {stacked: true});
//          r.barchart(330, 250, 300, 220, data3, {stacked: true, type: "round"});
      };
  </script>
</head>
<body class="raphael" id="g.raphael.dmitry.baranovskiy.com">
<div id="holder"></div>
<p>
  Demo of <a href="http://g.raphaeljs.com/">G Raphael</a> JavaScript library.
</p>
</body>
</html>

person boddhisattva    schedule 30.08.2013    source источник


Ответы (1)


Я знаю, что уже поздно, но это третий результат в Google при поиске той же проблемы. Как я решил использовать этот файл для g.bar.js

https://raw.githubusercontent.com/jhurt/g.raphael/master/g.bar.js

А потом я просто:

barChart.label([['label1','label2']], true);
person HMJ    schedule 13.08.2014