chart_engine 1.0.8 copy "chart_engine: ^1.0.8" to clipboard
chart_engine: ^1.0.8 copied to clipboard

outdated

Chart generator with interchangeable chart engines, like ChartJS and ApexCharts.

example/main.dart

import 'dart:html';

//import 'package:chart_engine/chart_engine_apexcharts.dart';
//import 'package:chart_engine/chart_engine_chartjs.dart';
import 'package:chart_engine/chart_engine_all.dart';

void main() async {

  await createLineChart();
  await createTimeSeriesChart();

  await createBarChart();

  await createScatterChart();
  await createScatterTimedChart();

  await createGaugeChart();

  querySelector('#chart-version').text = '${ ChartEngine.VERSION }' ;


}

Future createLineChart() async {

  var series = ChartSeries(
      ['Jan','Feb','Mar'],
      {
        'A': [10,20,5] ,
        'B': [15,25,55] ,
        'C': [100,130,140]
      }
  ) ;

  series.title = 'Line Chart Example' ;
  series.xTitle = 'Months' ;
  series.yTitle = 'Count' ;
  series.options.straightLines = true ;

  // Render the same ChartSeries using 2 engines:

  var charEngine1 = ChartEngineApexCharts() ;
  var charEngine2 = ChartEngineChartJS() ;

  await charEngine1.load() ;
  await charEngine2.load() ;

  charEngine1.renderLineChart( querySelector('#apexcharts-line1-output') , series ) ;
  charEngine2.renderLineChart( querySelector('#chartjs-line1-output') , series ) ;

  series.options.fillLines = true ;

  charEngine1.renderLineChart( querySelector('#apexcharts-line2-output') , series ) ;
  charEngine2.renderLineChart( querySelector('#chartjs-line2-output') , series ) ;

}


Future createTimeSeriesChart() async {

  // Declare using pair of x(DateTime) and y(value) entries.
  var series = ChartTimeSeries(
      {
        'A': [ [ DateTime(2020 , 03, 30) , 10 ] , [ DateTime(2020 , 03, 31) , 20 ] , [ DateTime(2020 , 04, 01) , 5 ] , [ DateTime(2020 , 04, 02) , -10 ] , [ DateTime(2020 , 04, 03) , 1 ] ] ,
        'B': [ [ DateTime(2020 , 03, 30) , 15 ] , [ DateTime(2020 , 03, 31) , 25 ] , [ DateTime(2020 , 04, 01) , 55 ] , [ DateTime(2020 , 04, 02) , 30 ] , [ DateTime(2020 , 04, 03) , -10 ] ] ,
        'C': [ [ 100 , DateTime(2020 , 03, 30) ] , [ DateTime(2020 , 03, 31) , 130 ] , [ DateTime(2020 , 04, 01) , 140 ] , [ DateTime(2020 , 04, 02) , -20 ] , [ DateTime(2020 , 04, 03) , -55 ] ] ,
      }
  ) ;

  series.title = 'Time Series Chart Example' ;
  series.xTitle = 'Months' ;
  series.yTitle = 'Count' ;

  // Render the same ChartSeries using 2 engines:

  var charEngine1 = ChartEngineApexCharts() ;
  var charEngine2 = ChartEngineChartJS() ;

  // Simultaneous load engines:
  await Future.wait( [ charEngine1.load() , charEngine2.load() ] ) ;

  charEngine1.renderTimeSeriesChart( querySelector('#apexcharts-time_series-output') , series ) ;
  charEngine2.renderTimeSeriesChart( querySelector('#chartjs-time_series-output') , series ) ;

}

Future createBarChart() async {

  var series = ChartSeries(
      ['Jan','Feb','Mar'],
      {
        'A': [10,20,5] ,
        'B': [15,25,55] ,
        'C': [100,130,140] ,
      }
  ) ;

  series.xTitle = 'Months' ;
  series.yTitle = 'Count' ;

  // Render the same ChartSeries using 2 engines:

  var charEngine1 = ChartEngineApexCharts() ;
  var charEngine2 = ChartEngineChartJS() ;

  // Simultaneous load engines:
  await Future.wait( [ charEngine1.load() , charEngine2.load() ] ) ;

  series.title = 'Bar Chart Example' ;
  charEngine1.renderBarChart( querySelector('#apexcharts-bar-output') , series ) ;
  charEngine2.renderBarChart( querySelector('#chartjs-bar-output') , series ) ;

  series.title = 'Horizontal Bar Chart Example' ;
  charEngine1.renderHorizontalBarChart( querySelector('#apexcharts-horizontal-bar-output') , series ) ;
  charEngine2.renderHorizontalBarChart( querySelector('#chartjs-horizontal-bar-output') , series ) ;

}

Future createScatterChart() async {

  // Declare using pair of x(height:cm) and y(weight: kg) entries.
  var series = ChartSeriesPair(
      {
        'A': [ [167.08, 61.25], [171.75, 66.77], [174.96, 75.11], [175.79, 88.40], [173.48, 78.86] ] ,
        'B': [ [175.77, 50.87], [174.98, 72.38], [166.27, 52.59], [172.75, 66.85], [184.17, 90.71] ] ,
        'C': [ [180.59, 98.12], [165.89, 58.20], [166.42, 50.33], [181.33, 78.01], [181.66, 101.91] ] ,
      }
  ) ;

  series.title = 'Scatter Chart Example' ;
  series.xTitle = 'Height' ;
  series.yTitle = 'Weight' ;

  // Swap X and Y values, including xTitle and yTitle.
  var series2 = series.swapXY() ;

  // Render the same ChartSeries using 2 engines:

  var charEngine1 = ChartEngineApexCharts() ;
  var charEngine2 = ChartEngineChartJS() ;

  // Simultaneous load engines:
  await Future.wait( [ charEngine1.load() , charEngine2.load() ] ) ;

  charEngine1.renderScatterChart( querySelector('#apexcharts-scatter-output') , series2 ) ;
  charEngine2.renderScatterChart( querySelector('#chartjs-scatter-output') , series2 ) ;

}


Future createScatterTimedChart() async {

  // Declare using pair of x(DateTime) and y(value) entries.
  var series = ChartTimeSeries(
      {
        'A': [ [ DateTime(2020 , 03, 30) , 10 ] , [ DateTime(2020 , 03, 31) , 20 ] , [ DateTime(2020 , 04, 01, 10) , 5 ] , [ DateTime(2020 , 04, 02, 3) , -10 ] , [ DateTime(2020 , 04, 03, 11) , 1 ] ] ,
        'B': [ [ DateTime(2020 , 03, 30, 2) , 15 ] , [ DateTime(2020 , 03, 31, 3) , 25 ] , [ DateTime(2020 , 04, 01, 12) , 55 ] , [ DateTime(2020 , 04, 02, 14) , 30 ] , [ DateTime(2020 , 04, 03, 2) , -10 ] ] ,
        'C': [ [ 100 , DateTime(2020 , 03, 30, 5) ] , [ DateTime(2020 , 03, 31, 4) , 130 ] , [ DateTime(2020 , 04, 01, 20) , 140 ] , [ DateTime(2020 , 04, 02, 23) , -20 ] , [ DateTime(2020 , 04, 03, 18) , -55 ] ] ,
      }
  ) ;

  series.title = 'Scatter Timed Chart Example' ;
  series.xTitle = 'Months' ;
  series.yTitle = 'Count' ;

  // Render the same ChartSeries using 2 engines:

  var charEngine1 = ChartEngineApexCharts() ;
  var charEngine2 = ChartEngineChartJS() ;

  // Simultaneous load engines:
  await Future.wait( [ charEngine1.load() , charEngine2.load() ] ) ;

  charEngine1.renderScatterTimedChart( querySelector('#apexcharts-scatter_timed-output') , series ) ;
  charEngine2.renderScatterTimedChart( querySelector('#chartjs-scatter_timed-output') , series ) ;

}

Future createGaugeChart() async {

  // Using Set: 1 value per category.
  // For Gauge needs to be in range of 0% to 100%.
  var set = ChartSet(
      {
        'A': 60 ,
        'B': 75 ,
        'C': 50 ,
      }
  ) ;

  set.title = 'Gauge Chart Example' ;

  var charEngine1 = ChartEngineApexCharts() ;
  var charEngine2 = ChartEngineChartJS() ;

  // Simultaneous load engines:
  await Future.wait( [ charEngine1.load() , charEngine2.load() ] ) ;

  charEngine1.renderGaugeChart( querySelector('#apexcharts-gauge-output') , set ) ;
  charEngine2.renderGaugeChart( querySelector('#chartjs-gauge-output') , set ) ;

}
42
likes
0
pub points
58%
popularity

Publisher

unverified uploader

Chart generator with interchangeable chart engines, like ChartJS and ApexCharts.

Repository (GitHub)
View/report issues

License

unknown (LICENSE)

Dependencies

amdjs, dom_tools, intl, swiss_knife

More

Packages that depend on chart_engine