-
Notifications
You must be signed in to change notification settings - Fork 35
/
StaticS3_GoogleChart_Iot_analytics.html
78 lines (58 loc) · 2.27 KB
/
StaticS3_GoogleChart_Iot_analytics.html
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
<!DOCTYPE html>
<html>
<!–– This project by Stephen Borsay for Soracom AWS Contest www.Embedded-IoT.net ––>
<!–– Check out my AWS IoT Course on Udemy https://www.udemy.com/exploring-aws-iot ––>
<head>
<script type="text/javascript" src="https://www.gstatic.com/charts/loader.js"></script>
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<div id="chart_div"></div>
<script>
$(document).ready(function(){
$("button").click(function(){
$.get( "https://YOUR_DATA_LOCATION_IN_S3_HERE", function( data ) {
//alert( "Data Loaded: " + data );
var temperature = data.match( /(?<=^")[0-9.]+/gm );
var humidity = data.match( /(?<=^"\d\d",")[0-9.]+/gm );
var timestamps = data.match( /(?<=^"\d\d","\d\d",")[0-9.]+/gm )
//use a string literal to output our values before graphing
alert(`Values in our temperature array to graph ${temperature}`);
alert(`Valuesin our humidity array to graph ${humidity}`);
alert(`Values in our timestamp array to graph ${timestamps}`);
google.charts.load('current', {packages: ['corechart', 'line']});
google.charts.setOnLoadCallback(drawBasic);
function drawBasic() {
var data = new google.visualization.DataTable();
data.addColumn('number', 'time');
data.addColumn('number', 'temperature');
data.addColumn('number', 'humidity');
//the followig three loops convert our strings in into numbers
for(var ts=0; ts<timestamps.length;ts++) timestamps[ts] = parseInt(timestamps[ts], 10);
for(var tem=0; tem<temperature.length;tem++) temperature[tem] = parseInt(temperature[tem], 10);
for(var hum=0; hum<humidity.length;hum++) humidity[hum] = parseInt(humidity[hum], 10);
for (i = 0; i < timestamps.length; i++) {
data.addRows([
[timestamps[i],temperature[i],humidity[i]]
]);
}
var options = {
hAxis: {
title: 'Time'
},
vAxis: {
title: 'Environmental Data'
}
};
var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
chart.draw(data, options);
}
});
});
});
</script>
</head>
<body>
<img src="YOUR_IMAGE.jpg" alt="Your Soracom AWS Project">
<br>
<button>Press to display our most recent data</button>
</body>
</html>