Blame view

samples/lineWithDateBasedData.html 5.77 KB
aaa287d94   Jeff Chen   NN
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
  <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
  <html>
  
      <head>
          <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
          <title>amCharts examples</title>
          <link rel="stylesheet" href="style.css" type="text/css">
          <script src="../amcharts/amcharts.js" type="text/javascript"></script>
  		<script src="../amcharts/serial.js" type="text/javascript"></script>
          <script type="text/javascript">
              var chart;
              var chartData = [];
              var chartCursor;
  
  
  
              AmCharts.ready(function () {
                  // generate some data first
                  generateChartData();
  
                  // SERIAL CHART
                  chart = new AmCharts.AmSerialChart();
                  chart.pathToImages = "../amcharts/images/";
                  chart.dataProvider = chartData;
                  chart.categoryField = "date";
                  chart.balloon.bulletSize = 5;
  
                  // listen for "dataUpdated" event (fired when chart is rendered) and call zoomChart method when it happens
                  chart.addListener("dataUpdated", zoomChart);
  
                  // AXES
                  // category
                  var categoryAxis = chart.categoryAxis;
                  categoryAxis.parseDates = true; // as our data is date-based, we set parseDates to true
                  categoryAxis.minPeriod = "DD"; // our data is daily, so we set minPeriod to DD
                  categoryAxis.dashLength = 1;
                  categoryAxis.minorGridEnabled = true;
                  categoryAxis.twoLineMode = true;
                  categoryAxis.dateFormats = [{
                      period: 'fff',
                      format: 'JJ:NN:SS'
                  }, {
                      period: 'ss',
                      format: 'JJ:NN:SS'
                  }, {
                      period: 'mm',
                      format: 'JJ:NN'
                  }, {
                      period: 'hh',
                      format: 'JJ:NN'
                  }, {
                      period: 'DD',
                      format: 'DD'
                  }, {
                      period: 'WW',
                      format: 'DD'
                  }, {
                      period: 'MM',
                      format: 'MMM'
                  }, {
                      period: 'YYYY',
                      format: 'YYYY'
                  }];
  
                  categoryAxis.axisColor = "#DADADA";
  
                  // value
                  var valueAxis = new AmCharts.ValueAxis();
                  valueAxis.axisAlpha = 0;
                  valueAxis.dashLength = 1;
                  chart.addValueAxis(valueAxis);
  
                  // GRAPH
                  var graph = new AmCharts.AmGraph();
                  graph.title = "red line";
                  graph.valueField = "visits";
                  graph.bullet = "round";
                  graph.bulletBorderColor = "#FFFFFF";
                  graph.bulletBorderThickness = 2;
                  graph.bulletBorderAlpha = 1;
                  graph.lineThickness = 2;
                  graph.lineColor = "#5fb503";
                  graph.negativeLineColor = "#efcc26";
                  graph.hideBulletsCount = 50; // this makes the chart to hide bullets when there are more than 50 series in selection
                  chart.addGraph(graph);
  
                  // CURSOR
                  chartCursor = new AmCharts.ChartCursor();
                  chartCursor.cursorPosition = "mouse";
                  chartCursor.pan = true; // set it to fals if you want the cursor to work in "select" mode
                  chart.addChartCursor(chartCursor);
  
                  // SCROLLBAR
                  var chartScrollbar = new AmCharts.ChartScrollbar();
                  chart.addChartScrollbar(chartScrollbar);
  
                  chart.creditsPosition = "bottom-right";
  
                  // WRITE
                  chart.write("chartdiv");
              });
  
              // generate some random data, quite different range
              function generateChartData() {
                  var firstDate = new Date();
                  firstDate.setDate(firstDate.getDate() - 500);
  
                  for (var i = 0; i < 500; i++) {
                      // we create date objects here. In your data, you can have date strings
                      // and then set format of your dates using chart.dataDateFormat property,
                      // however when possible, use date objects, as this will speed up chart rendering.
                      var newDate = new Date(firstDate);
                      newDate.setDate(newDate.getDate() + i);
  
                      var visits = Math.round(Math.random() * 40) - 20;
  
                      chartData.push({
                          date: newDate,
                          visits: visits
                      });
                  }
              }
  
              // this method is called when chart is first inited as we listen for "dataUpdated" event
              function zoomChart() {
                  // different zoom methods can be used - zoomToIndexes, zoomToDates, zoomToCategoryValues
                  chart.zoomToIndexes(chartData.length - 40, chartData.length - 1);
              }
  
              // changes cursor mode from pan to select
              function setPanSelect() {
                  if (document.getElementById("rb1").checked) {
                      chartCursor.pan = false;
                      chartCursor.zoomable = true;
                  } else {
                      chartCursor.pan = true;
                  }
                  chart.validateNow();
              }
  
          </script>
      </head>
  
      <body>
          <div id="chartdiv" style="width: 100%; height: 400px;"></div>
          <div style="margin-left:35px;">
              <input type="radio" name="group" id="rb1" onclick="setPanSelect()">Select
              <input type="radio" checked="true" name="group" id="rb2" onclick="setPanSelect()">Pan
  		</div>
      </body>
  
  </html>