Angular 2 ng2-диаграммы пончик добавить текст

Я использую ng2-диаграммы на основе chart.js. Я пытаюсь добавить текст в середину кольцевой диаграммы, но не могу установить текст или зарегистрировать плагин. Кто-нибудь может помочь? До сих пор я нашел несколько неполных ответов, как это сделать в javascript, но я борюсь с реализацией angular 2 и typescript для chart.js.

мой файл шаблона:

    <div style="display: block" class="donut">
  <canvas #mycanvas baseChart
          [data]="doughnutChartData"
          [labels]="doughnutChartLabels"
          [chartType]="doughnutChartType"
          [options]="doughnutChartOptions"
          [datasets]="doughnutChartDatasets"
          (chartHover)="chartHovered($event)"
          (chartClick)="chartClicked($event)"></canvas>
</div>
<script>
  Chart.pluginService.register({
    afterDraw: function (chart) {
      if (chart.config.options.elements.center) {
        var helpers = Chart.helpers;
        var centerX = (chart.chartArea.left + chart.chartArea.right) / 2;
        var centerY = (chart.chartArea.top + chart.chartArea.bottom) / 2;

        var ctx = chart.chart.ctx;
        ctx.save();
        var fontSize = helpers.getValueOrDefault(chart.config.options.elements.center.fontSize, Chart.defaults.global.defaultFontSize);
        var fontStyle = helpers.getValueOrDefault(chart.config.options.elements.center.fontStyle, Chart.defaults.global.defaultFontStyle);
        var fontFamily = helpers.getValueOrDefault(chart.config.options.elements.center.fontFamily, Chart.defaults.global.defaultFontFamily);
        var font = helpers.fontString(fontSize, fontStyle, fontFamily);
        ctx.font = font;
        ctx.fillStyle = helpers.getValueOrDefault(chart.config.options.elements.center.fontColor, Chart.defaults.global.defaultFontColor);
        ctx.textAlign = 'center';
        ctx.textBaseline = 'middle';
        ctx.fillText(chart.config.options.elements.center.text, centerX, centerY);
        ctx.restore();
      }
    },
  })
</script>

и ts файл: app.component.ts

 import { Component } from '@angular/core';


@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  title = 'app works!';

  colors = {
    indigo: '#14143e',
    pink: '#fd1c49',
    orange: '#ff6e00',
    yellow: '#f0c800',
    mint: '#00efab',
    cyan: '#05d1ff',
    purple: '#841386',
    white: '#fff'
  };


  // Doughnut
  public doughnutChartLabels:string[] = ['Drive Score', ''];
  public doughnutChartData:number[] = [85, 15];
  public doughnutChartType:string = 'doughnut';

  public doughnutChartOptions: any = {
    cutoutPercentage: 80,
    elements: {
      center: {
        text: 'Hello',
        fontColor: '#000',
        fontFamily: "'Helvetica Neue', 'Helvetica', 'Arial', sans-serif",
        fontSize: 24,
        fontStyle: 'normal'
      }
    }
  };
  public doughnutChartDatasets: any[] = [
    {
      data: [300, 50, 100],
      options: this.doughnutChartOptions,
      backgroundColor: [
        "#FF6384",
        "#36A2EB",
        "#FFCE56"
      ],
      hoverBackgroundColor: [
        "#FF6384",
        "#36A2EB",
        "#FFCE56"
      ]
    }];

  // events
  public chartClicked(e:any):void {
    console.log(e);
  }

  public chartHovered(e:any):void {
    console.log(e);
  }

  constructor(){

  }




}

person playerone    schedule 28.04.2017    source источник
comment
Вам нужно переместить скрипт из вашего шаблона в component.ts. Может быть, поместите их в ngAfterViewInit ().   -  person wannadream    schedule 28.04.2017
comment
Спасибо!! теперь работает! Мне пришлось скопировать его в ngAfterViewInit (), как вы сказали.   -  person playerone    schedule 29.04.2017


Ответы (1)


Скопировал ваш код в Plunker, работает нормально:

плункер: https://plnkr.co/edit/UGH3BKiWmgFqFWf78ZUE?p=preview

Я думаю, что добавление скрипта таким образом не сработает, потому что angular его очистит. Попробуйте добавить сценарий после сценария chart.js на вашей странице в <script> или, желательно, в его собственном файле.

person Ahmed Musallam    schedule 28.04.2017
comment
да, спасибо, я скопировал его в ngAfterViewInit, как сказал @wannadream, и он работает. - person playerone; 29.04.2017
comment
Пожалуйста, дайте ссылку на плункер, который показывает решение. Вышеупомянутый плункер предоставляет только круговую диаграмму - person Kesty; 22.05.2017
comment
Как передать ответ webapi, такой как динамическое число, такое как 99, внутри текста пончика ng2, любая идея? - person Mohamed Sahir; 07.11.2017