mirror of
https://gitlab.silvrtree.co.uk/martind2000/censis-archive.git
synced 2025-01-25 18:16:17 +00:00
”2016-07-04”
This commit is contained in:
parent
7fb8d179e6
commit
450cc64b0a
@ -23,8 +23,6 @@ var BLUVIB = function(p) {
|
|||||||
enable: '9FB70002-EF7D-40C8-9C1E-5052BC101EFA',
|
enable: '9FB70002-EF7D-40C8-9C1E-5052BC101EFA',
|
||||||
notify: '9FB70003-EF7D-40C8-9C1E-5052BC101EFA',
|
notify: '9FB70003-EF7D-40C8-9C1E-5052BC101EFA',
|
||||||
period: '9FB70004-EF7D-40C8-9C1E-5052BC101EFA'
|
period: '9FB70004-EF7D-40C8-9C1E-5052BC101EFA'
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
this.$result = {temp: null, tempMax: null, tempMin: null};
|
this.$result = {temp: null, tempMax: null, tempMin: null};
|
||||||
@ -42,7 +40,8 @@ var BLUVIB = function(p) {
|
|||||||
|
|
||||||
this.onNotification = function(d) {
|
this.onNotification = function(d) {
|
||||||
|
|
||||||
this.readRaw('BluVib', d);
|
console.log(d);
|
||||||
|
//this.readRaw('BluVib', d);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -78,13 +77,17 @@ var BLUVIB = function(p) {
|
|||||||
|
|
||||||
|
|
||||||
var configData = new Uint8Array(1);
|
var configData = new Uint8Array(1);
|
||||||
// Turn on gyro, accel, and mag, 2G range, Disable wake on motion
|
configData[0] = 0x74;
|
||||||
configData[0] = 0x76;
|
/*
|
||||||
|
configData[1] = 0x01;
|
||||||
|
configData[2] = 0x01;
|
||||||
|
configData[3] = 0x01;
|
||||||
|
*/
|
||||||
ble.write(this.deviceID,
|
ble.write(this.deviceID,
|
||||||
this.serviceDef.service,
|
this.serviceDef.service,
|
||||||
this.serviceDef.enable,
|
this.serviceDef.enable,
|
||||||
configData.buffer,
|
configData.buffer,
|
||||||
function(m) { console.log('Started BluVib.',m); },
|
function(m) { console.log('Started BluVib.', m); },
|
||||||
this.onError);
|
this.onError);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -1,8 +1,3 @@
|
|||||||
body {
|
|
||||||
font-family: Ubuntu, "Helvetica Neue", Helvetica, arial, sans-serif;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#lightR, #projR { color: red !important; }
|
#lightR, #projR { color: red !important; }
|
||||||
|
|
||||||
@ -17,7 +12,6 @@ body {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
.h105 {
|
.h105 {
|
||||||
height: 100px;
|
height: 100px;
|
||||||
}
|
}
|
||||||
@ -82,57 +76,6 @@ body {
|
|||||||
/* Smartphones (portrait and landscape) ----------- */
|
/* Smartphones (portrait and landscape) ----------- */
|
||||||
@media only screen and (min-device-width: 320px) and (max-device-width: 480px) {
|
@media only screen and (min-device-width: 320px) and (max-device-width: 480px) {
|
||||||
/* Styles */
|
/* Styles */
|
||||||
.time, .date, .temp {
|
|
||||||
font-family: 'Ubuntu Condensed', sans-serif;
|
|
||||||
font-size: 33px;
|
|
||||||
/*color: #ff0000;*/
|
|
||||||
}
|
|
||||||
|
|
||||||
.time {
|
|
||||||
font-size: 50px;
|
|
||||||
line-height: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.time span.hour:after {
|
|
||||||
content: "\a";
|
|
||||||
white-space: pre;
|
|
||||||
}
|
|
||||||
|
|
||||||
.temp {
|
|
||||||
font-size: 70px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.temp::after {
|
|
||||||
content: "°";
|
|
||||||
}
|
|
||||||
|
|
||||||
.wd-we {
|
|
||||||
font-size: 75%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mo {
|
|
||||||
font-size: 85%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mo.mo-1, .mo.mo-10 {
|
|
||||||
font-size: 70%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mo.mo-2 {
|
|
||||||
font-size: 65%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mo.mo-8 {
|
|
||||||
font-size: 80%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mo.mo-9 {
|
|
||||||
font-size: 55%;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mo.mo-11, .mo.mo-12 {
|
|
||||||
font-size: 60%;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -258,3 +201,13 @@ color:#78909C;
|
|||||||
{
|
{
|
||||||
color:#2196F3;
|
color:#2196F3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* svg classes */
|
||||||
|
|
||||||
|
svg text {
|
||||||
|
font-family:'Ubuntu Condensed',sans-serif;
|
||||||
|
font-size:12;
|
||||||
|
fill: #bad649;
|
||||||
|
text-align:right;
|
||||||
|
}
|
||||||
|
@ -1,9 +1,14 @@
|
|||||||
@import "app/libs/mui/src/sass/mui/colors";
|
@import "app/libs/mui/src/sass/mui/colors";
|
||||||
|
|
||||||
|
|
||||||
$mui-body-bg-color: mui-color('grey', '100');
|
$mui-body-bg-color: /*#003F5a*/ mui-color('grey', '800');
|
||||||
|
$mui-base-font-color: rgba(#FFF, 0.87) !default;
|
||||||
|
$mui-base-font-family: Ubuntu, "Helvetica Neue", Helvetica, Arial, Verdana, Tahoma !default;
|
||||||
|
|
||||||
|
$mui-panel-bg-color : /*#004c6d*/ mui-color('grey', '900');
|
||||||
|
|
||||||
//$mui-accent-color: #bad649;
|
//$mui-accent-color: #bad649;
|
||||||
$mui-accent-color: #004c6d;
|
$mui-accent-color: #00aeef;
|
||||||
$mui-btn-accent-font-color: #004c6d;
|
$mui-btn-accent-font-color: #004c6d;
|
||||||
//$mui-accent-color-dark: mui-color('green', 'A100');
|
//$mui-accent-color-dark: mui-color('green', 'A100');
|
||||||
$mui-accent-color-dark: #004c6d;
|
$mui-accent-color-dark: #004c6d;
|
||||||
|
File diff suppressed because one or more lines are too long
@ -92,14 +92,21 @@
|
|||||||
<!-- build:vendor -->
|
<!-- build:vendor -->
|
||||||
<script type="text/javascript" src="libs/jquery/dist/jquery.js"></script>
|
<script type="text/javascript" src="libs/jquery/dist/jquery.js"></script>
|
||||||
<script type="text/javascript" src="libs/mui/packages/cdn/js/mui.js"></script>
|
<script type="text/javascript" src="libs/mui/packages/cdn/js/mui.js"></script>
|
||||||
|
<script type="text/javascript" src="libs/ejs/ejs.js"></script>
|
||||||
<script type="text/javascript"
|
<script type="text/javascript"
|
||||||
src="libs/bluebird/js/browser/bluebird.js"></script>
|
src="libs/bluebird/js/browser/bluebird.js"></script>
|
||||||
|
|
||||||
|
<script type="text/javascript" src="libs/jsfft/complex_array.js"></script>
|
||||||
|
<script type="text/javascript" src="libs/jsfft/fft.js"></script>
|
||||||
|
|
||||||
<!-- endbuild -->
|
<!-- endbuild -->
|
||||||
|
|
||||||
<!-- build:standards -->
|
<!-- build:standards -->
|
||||||
<script type="text/javascript"
|
<script type="text/javascript"
|
||||||
src="js/standards/bluetooth_company_identifiers.js"></script>
|
src="js/standards/bluetooth_company_identifiers.js"></script>
|
||||||
<script type="text/javascript" src="js/standards/capability.js"></script>
|
<script type="text/javascript" src="js/standards/capability.js"></script>
|
||||||
|
<script type="text/javascript" src="js/standards/generic_access.js"></script>
|
||||||
|
<script type="text/javascript" src="js/standards/deviceInformation.js"></script>
|
||||||
<script type="text/javascript" src="js/standards/battery.js"></script>
|
<script type="text/javascript" src="js/standards/battery.js"></script>
|
||||||
<script type="text/javascript" src="js/standards/button.js"></script>
|
<script type="text/javascript" src="js/standards/button.js"></script>
|
||||||
<script type="text/javascript" src="js/mandecoder.js"></script>
|
<script type="text/javascript" src="js/mandecoder.js"></script>
|
||||||
@ -118,6 +125,12 @@
|
|||||||
src="js/device/CC2650/cc2650_humidity.js"></script>
|
src="js/device/CC2650/cc2650_humidity.js"></script>
|
||||||
<!-- endbuild -->
|
<!-- endbuild -->
|
||||||
|
|
||||||
|
<script type="text/javascript"
|
||||||
|
src="js/device/fmc/TSL.js"></script>
|
||||||
|
|
||||||
|
<script type="text/javascript"
|
||||||
|
src="js/device/sensorworks/bluvib.js"></script>
|
||||||
|
|
||||||
<!-- build:js -->
|
<!-- build:js -->
|
||||||
<script type="text/javascript" src="js/index.js"></script>
|
<script type="text/javascript" src="js/index.js"></script>
|
||||||
<!-- endbuild -->
|
<!-- endbuild -->
|
||||||
|
@ -81,10 +81,6 @@ CC2650_ACCEL = function(p) {
|
|||||||
}
|
}
|
||||||
calcData = this.processData(data);
|
calcData = this.processData(data);
|
||||||
|
|
||||||
message = 'Gyro <br/>' + 'X: ' + calcData.gyro.x + '<br/>' + 'Y: ' + calcData.gyro.y + '<br/>' + 'Z: ' + calcData.gyro.z + '<br/>' + 'Accel <br/>' + 'X: ' + calcData.accel.x + '<br/>' + 'Y: ' + calcData.accel.y + '<br/>' + 'Z: ' + calcData.accel.z + '<br/>' + 'Mag <br/>' + 'X: ' + calcData.mag.x + '<br/>' + 'Y: ' + calcData.mag.y + '<br/>' + 'Z: ' + calcData.mag.z + '<br/>';
|
|
||||||
|
|
||||||
this.state = message;
|
|
||||||
|
|
||||||
this.$result[this.frames.gyroID + '-x'].text(gString(calcData.gyro.x));
|
this.$result[this.frames.gyroID + '-x'].text(gString(calcData.gyro.x));
|
||||||
this.$result[this.frames.gyroID + '-y'].text(gString(calcData.gyro.y));
|
this.$result[this.frames.gyroID + '-y'].text(gString(calcData.gyro.y));
|
||||||
this.$result[this.frames.gyroID + '-z'].text(gString(calcData.gyro.z));
|
this.$result[this.frames.gyroID + '-z'].text(gString(calcData.gyro.z));
|
||||||
@ -109,12 +105,11 @@ CC2650_ACCEL = function(p) {
|
|||||||
this.data.mag.y = this.storeData(calcData.mag.y, this.data.mag.y);
|
this.data.mag.y = this.storeData(calcData.mag.y, this.data.mag.y);
|
||||||
this.data.mag.z = this.storeData(calcData.mag.z, this.data.mag.z);
|
this.data.mag.z = this.storeData(calcData.mag.z, this.data.mag.z);
|
||||||
|
|
||||||
// Console.log(JSON.stringify(this.data));
|
|
||||||
// Console.log(this.state);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
this.startService = function() {
|
this.startService = function() {
|
||||||
|
|
||||||
|
this.maxLength = 500;
|
||||||
if (this.deviceID !== null) {
|
if (this.deviceID !== null) {
|
||||||
|
|
||||||
console.log('Starting CC2650 Accelerometer Service on ', this.deviceID);
|
console.log('Starting CC2650 Accelerometer Service on ', this.deviceID);
|
||||||
@ -154,8 +149,12 @@ CC2650_ACCEL = function(p) {
|
|||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
this.advancedGraph = function(mode, data, subID) {
|
this.advancedGraphFFT = function(mode, data, subID) {
|
||||||
|
|
||||||
|
var startX;
|
||||||
|
var _cdata;
|
||||||
|
var xstep;
|
||||||
|
var scalePos;
|
||||||
var lm;
|
var lm;
|
||||||
var ceiling;
|
var ceiling;
|
||||||
var elm;
|
var elm;
|
||||||
@ -168,9 +167,27 @@ CC2650_ACCEL = function(p) {
|
|||||||
var text1ID;
|
var text1ID;
|
||||||
var lineID;
|
var lineID;
|
||||||
var max;
|
var max;
|
||||||
|
var yscale = 125;
|
||||||
|
var height = 125;
|
||||||
|
|
||||||
|
var yOffset;
|
||||||
|
|
||||||
|
var reducer = function(p, v) {
|
||||||
|
return (Math.abs(p) > Math.abs(v) ? Math.abs(p) : Math.abs(v));
|
||||||
|
};
|
||||||
|
|
||||||
var parts = ['x', 'y', 'z'];
|
var parts = ['x', 'y', 'z'];
|
||||||
|
var _newData = {x: [],y: [],z: []};
|
||||||
|
|
||||||
|
var fnFillNewData = function(c_value, i) {
|
||||||
|
ceiling = reducer(c_value.real ,ceiling);
|
||||||
|
_newData[lm].push(c_value.real);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (subID === 'gyro') {
|
||||||
|
height = 300;
|
||||||
|
yscale = 300;
|
||||||
|
}
|
||||||
|
|
||||||
_data = data || this.data;
|
_data = data || this.data;
|
||||||
|
|
||||||
@ -179,6 +196,111 @@ CC2650_ACCEL = function(p) {
|
|||||||
// LineID = [this.frameID , _subID , '-line'].join('');
|
// LineID = [this.frameID , _subID , '-line'].join('');
|
||||||
text1ID = [this.frameID, _subID, '-txt1'].join('');
|
text1ID = [this.frameID, _subID, '-txt1'].join('');
|
||||||
text2ID = [this.frameID, _subID, '-txt2'].join('');
|
text2ID = [this.frameID, _subID, '-txt2'].join('');
|
||||||
|
ceiling = 0;
|
||||||
|
if (_data.x.length > 0) {
|
||||||
|
|
||||||
|
max = 2;
|
||||||
|
|
||||||
|
for (var lineMode = 0; lineMode < parts.length; lineMode++) {
|
||||||
|
|
||||||
|
lm = parts[lineMode];
|
||||||
|
|
||||||
|
_cdata = new complex_array.ComplexArray(_data[lm]);
|
||||||
|
|
||||||
|
_cdata.FFT();
|
||||||
|
|
||||||
|
_cdata.forEach(fnFillNewData);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (ceiling > 500) {
|
||||||
|
max = (ceiling > max) ? (Math.ceil((Math.round(ceiling) + 1) / 50) * 50) : max;
|
||||||
|
} else {
|
||||||
|
max = (ceiling > max) ? (Math.ceil((Math.round(ceiling) + 1) / 10) * 10) : max;
|
||||||
|
}
|
||||||
|
ceiling = max;
|
||||||
|
|
||||||
|
floor = ceiling * -1;
|
||||||
|
ceilingLimit = ceiling;
|
||||||
|
|
||||||
|
scalePos = (yscale / 2) / ceiling;
|
||||||
|
|
||||||
|
xstep = (680 - 46) / this.maxLength;
|
||||||
|
|
||||||
|
yOffset = ((height - (14 + 12)) / 2) + 12;
|
||||||
|
|
||||||
|
for (lineMode = 0; lineMode < parts.length; lineMode++) {
|
||||||
|
|
||||||
|
lm = parts[lineMode];
|
||||||
|
startX = 46 + (this.maxLength - _newData[lm].length) * xstep;
|
||||||
|
|
||||||
|
calcArray = [];
|
||||||
|
|
||||||
|
lineID = this.frameID + _subID + '-' + lm + '-line';
|
||||||
|
for (var x = 0; x < _newData[lm].length; x++) {
|
||||||
|
|
||||||
|
calcArray.push((startX + (x * xstep)).toFixed(2) + ',' + (yOffset - ((_newData[lm][x]) * scalePos)).toFixed(
|
||||||
|
2));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
elm = document.getElementById(lineID);
|
||||||
|
|
||||||
|
elm.setAttribute('points', calcArray.join(' '));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
elm = document.getElementById(text1ID);
|
||||||
|
elm.textContent = ceilingLimit;
|
||||||
|
|
||||||
|
elm = document.getElementById(text2ID);
|
||||||
|
elm.textContent = floor;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
this.previousCeil = ceiling;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
this.advancedGraph = function(mode, data, subID) {
|
||||||
|
|
||||||
|
var startX;
|
||||||
|
var xstep;
|
||||||
|
var scalePos;
|
||||||
|
var lm;
|
||||||
|
var ceiling;
|
||||||
|
var elm;
|
||||||
|
var text2ID;
|
||||||
|
var ceilingLimit;
|
||||||
|
var calcArray;
|
||||||
|
var floor;
|
||||||
|
var _subID;
|
||||||
|
var _data;
|
||||||
|
var text1ID;
|
||||||
|
var lineID;
|
||||||
|
var max;
|
||||||
|
var yscale = 125;
|
||||||
|
var height = 125;
|
||||||
|
|
||||||
|
var yOffset;
|
||||||
|
|
||||||
|
var reducer = function(p, v) {
|
||||||
|
return (Math.abs(p) > Math.abs(v) ? Math.abs(p) : Math.abs(v));
|
||||||
|
};
|
||||||
|
|
||||||
|
var parts = ['x', 'y', 'z'];
|
||||||
|
|
||||||
|
_data = data || this.data;
|
||||||
|
|
||||||
|
_subID = subID || '';
|
||||||
|
|
||||||
|
text1ID = [this.frameID, _subID, '-txt1'].join('');
|
||||||
|
text2ID = [this.frameID, _subID, '-txt2'].join('');
|
||||||
|
|
||||||
|
if (mode === 'gyro') {
|
||||||
|
height = 300;
|
||||||
|
yscale = 300;
|
||||||
|
}
|
||||||
|
|
||||||
if (_data.x.length > 0) {
|
if (_data.x.length > 0) {
|
||||||
|
|
||||||
@ -186,10 +308,8 @@ CC2650_ACCEL = function(p) {
|
|||||||
|
|
||||||
for (var lineMode = 0; lineMode < parts.length; lineMode++) {
|
for (var lineMode = 0; lineMode < parts.length; lineMode++) {
|
||||||
lm = parts[lineMode];
|
lm = parts[lineMode];
|
||||||
ceiling = _data[lm].reduce(function(p, v) {
|
|
||||||
return (Math.abs(p) > Math.abs(v) ? Math.abs(p) : Math.abs(v));
|
|
||||||
});
|
|
||||||
|
|
||||||
|
ceiling = _data[lm].reduce(reducer);
|
||||||
|
|
||||||
if (ceiling > 500) {
|
if (ceiling > 500) {
|
||||||
max = (ceiling > max) ? (Math.ceil((Math.round(ceiling) + 1) / 50) * 50) : max;
|
max = (ceiling > max) ? (Math.ceil((Math.round(ceiling) + 1) / 50) * 50) : max;
|
||||||
@ -203,23 +323,24 @@ CC2650_ACCEL = function(p) {
|
|||||||
floor = ceiling * -1;
|
floor = ceiling * -1;
|
||||||
ceilingLimit = ceiling;
|
ceilingLimit = ceiling;
|
||||||
|
|
||||||
var scalePos = (124 / 2) / ceiling;
|
scalePos = (yscale / 2) / ceiling;
|
||||||
var scaleNeg = (124 / 2) / floor;
|
|
||||||
var xstep = (680 - 46) / 100;
|
|
||||||
|
|
||||||
//Var xstep = 2.34;
|
xstep = (680 - 46) / this.maxLength;
|
||||||
|
|
||||||
|
// YOffset should be about 71;
|
||||||
|
yOffset = ((height - (14 + 12)) / 2) + 12;
|
||||||
|
|
||||||
for (lineMode = 0; lineMode < parts.length; lineMode++) {
|
for (lineMode = 0; lineMode < parts.length; lineMode++) {
|
||||||
|
|
||||||
lm = parts[lineMode];
|
lm = parts[lineMode];
|
||||||
var startX = 46 + (100 - _data[lm].length) * xstep;
|
startX = 46 + (this.maxLength - _data[lm].length) * xstep;
|
||||||
|
|
||||||
calcArray = [];
|
calcArray = [];
|
||||||
|
|
||||||
lineID = this.frameID + _subID + '-' + lm + '-line';
|
lineID = this.frameID + _subID + '-' + lm + '-line';
|
||||||
for (var x = 0; x < _data[lm].length; x++) {
|
for (var x = 0; x < _data[lm].length; x++) {
|
||||||
|
|
||||||
calcArray.push((startX + (x * xstep)).toFixed(2) + ',' + (71 - ((_data[lm][x]) * scalePos)).toFixed(
|
calcArray.push((startX + (x * xstep)).toFixed(2) + ',' + (yOffset - ((_data[lm][x]) * scalePos)).toFixed(
|
||||||
2));
|
2));
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -245,7 +366,7 @@ CC2650_ACCEL = function(p) {
|
|||||||
// Nothing to animate yet
|
// Nothing to animate yet
|
||||||
|
|
||||||
// return -1;
|
// return -1;
|
||||||
this.advancedGraph(0, this.data.gyro, 'gyro');
|
this.advancedGraphFFT(0, this.data.gyro, 'gyro');
|
||||||
this.advancedGraph(0, this.data.accel, 'accel');
|
this.advancedGraph(0, this.data.accel, 'accel');
|
||||||
this.advancedGraph(0, this.data.mag, 'mag');
|
this.advancedGraph(0, this.data.mag, 'mag');
|
||||||
// This.simpleGraph(this.data.temp, 'temp');
|
// This.simpleGraph(this.data.temp, 'temp');
|
||||||
@ -265,7 +386,9 @@ CC2650_ACCEL = function(p) {
|
|||||||
var _width = settings.width || 300;
|
var _width = settings.width || 300;
|
||||||
var _height = settings.height || 150;
|
var _height = settings.height || 150;
|
||||||
var _fill = settings.fill || 'blue';
|
var _fill = settings.fill || 'blue';
|
||||||
|
|
||||||
|
var viewbox = [0,0,_width, _height].join(' ');
|
||||||
|
|
||||||
var svg = document.createElementNS(xmlns, 'svg');
|
var svg = document.createElementNS(xmlns, 'svg');
|
||||||
|
|
||||||
svg.setAttribute('id', svgID);
|
svg.setAttribute('id', svgID);
|
||||||
@ -277,30 +400,31 @@ CC2650_ACCEL = function(p) {
|
|||||||
|
|
||||||
svg.setAttributeNS('http://www.w3.org/2000/xmlns/', 'xmlns:xlink', 'http://www.w3.org/1999/xlink');
|
svg.setAttributeNS('http://www.w3.org/2000/xmlns/', 'xmlns:xlink', 'http://www.w3.org/1999/xlink');
|
||||||
|
|
||||||
svg.setAttributeNS(xmlns, 'viewBox', '0 0 700 150');
|
svg.setAttributeNS(xmlns, 'viewBox', viewbox);
|
||||||
// Svg.setAttributeNS(xmlns, 'style', 'width:700px;height:150px;');
|
// Svg.setAttributeNS(xmlns, 'style', 'width:700px;height:150px;');
|
||||||
|
|
||||||
|
|
||||||
svg = this.graphAddXAxis(svg, {y: 12, x2: 680, colour: '#004c6d', id: text1ID});
|
svg = this.graphAddXAxis(svg, {y: 12, x2: 680, colour: '#004c6d', id: text1ID});
|
||||||
svg = this.graphAddXAxis(svg, {y: 136, x2: 680, colour: '#004c6d', id: text2ID});
|
svg = this.graphAddXAxis(svg, {y: _height - 14, x2: 680, colour: '#004c6d', id: text2ID});
|
||||||
svg = this.graphAddXAxis(svg, {y: 71, x2: 680, colour: '#004c6d', text: '0'});
|
svg = this.graphAddXAxis(svg, {y: ((_height - (14 + 12)) / 2) + 12, x2: 680, colour: '#004c6d', text: '0'});
|
||||||
|
|
||||||
return svg;
|
return svg;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
this.generateBlankGraph = function(subID) {
|
this.generateBlankGraph = function(subID, height) {
|
||||||
|
|
||||||
|
var _height = height || 150;
|
||||||
var _subID = subID || '';
|
var _subID = subID || '';
|
||||||
var xlineID = this.frameID + _subID + '-x-line';
|
var xlineID = this.frameID + _subID + '-x-line';
|
||||||
var ylineID = this.frameID + _subID + '-y-line';
|
var ylineID = this.frameID + _subID + '-y-line';
|
||||||
var zlineID = this.frameID + _subID + '-z-line';
|
var zlineID = this.frameID + _subID + '-z-line';
|
||||||
|
|
||||||
var svg = this.generateBlankGraphBase(_subID,{width: '700',height: 150});
|
var svg = this.generateBlankGraphBase(_subID,{width: '700',height: _height});
|
||||||
|
|
||||||
svg = this.graphAddLine(svg, xlineID, 'rgba(255,0,0,0.5)');
|
svg = this.graphAddLine(svg, xlineID, 'rgba(255,0,99,1)');
|
||||||
svg = this.graphAddLine(svg, ylineID, 'rgba(0,255,0,0.5)');
|
svg = this.graphAddLine(svg, ylineID, 'rgba(46,255,0,1)');
|
||||||
svg = this.graphAddLine(svg, zlineID, 'rgba(0,0,255,0.5)');
|
svg = this.graphAddLine(svg, zlineID, 'rgba(0,191,255,1)');
|
||||||
|
|
||||||
return svg;
|
return svg;
|
||||||
|
|
||||||
@ -308,61 +432,81 @@ CC2650_ACCEL = function(p) {
|
|||||||
|
|
||||||
this.insertFrame = function(mode) {
|
this.insertFrame = function(mode) {
|
||||||
|
|
||||||
|
var _graph;
|
||||||
|
var row;
|
||||||
|
var elm;
|
||||||
var frame;
|
var frame;
|
||||||
var title;
|
var title;
|
||||||
var modeID = mode + 'ID';
|
var modeID = mode + 'ID';
|
||||||
|
var height = 150;
|
||||||
this.frames[modeID] = this.frameID + '-' + mode;
|
this.frames[modeID] = this.frameID + '-' + mode;
|
||||||
|
|
||||||
|
|
||||||
var titles = {
|
var titles = {
|
||||||
gyro: 'Gyroscope', accel: 'Accelerometer', mag: 'Magnetometer'
|
gyro: 'Gyroscope', accel: 'Accelerometer', mag: 'Magnetometer'
|
||||||
};
|
};
|
||||||
var modes = ['gyro', 'accel', 'mag'];
|
|
||||||
|
|
||||||
console.log('FrameID: ', this.frames[modeID]);
|
console.log('FrameID: ', this.frames[modeID]);
|
||||||
|
|
||||||
title = [titles[mode], ' - ', this.deviceID].join(' ');
|
title = [titles[mode], ' - ', this.deviceID].join(' ');
|
||||||
|
|
||||||
frame = $('<div />', {
|
frame = $('<div></div>', {
|
||||||
class: 'mui-panel', id: this.frames[modeID]
|
class: 'mui-panel', id: this.frames[modeID]
|
||||||
});
|
});
|
||||||
|
|
||||||
$('<div />', {class: 'mui-row'}).append($('<div />', {
|
if (mode === 'gyro') {
|
||||||
class: 'mui-col-xs-12 mui--text-title mui-ellipsis-2', text: title
|
height = 300;
|
||||||
})).appendTo(frame);
|
}
|
||||||
|
|
||||||
|
if (mode === 'mag') {
|
||||||
|
|
||||||
|
elm = $('<div></div>', {class: 'mui-row'});
|
||||||
|
|
||||||
|
elm.append($('<div></div>', { class: 'mui-col-xs-8 mui--text-title mui-ellipsis-2', text: title}));
|
||||||
|
|
||||||
|
// Elm.append($('<div></div>', {class: 'mui-col-xs-4 mui--text-right'}).append(button));
|
||||||
|
|
||||||
|
frame.append(elm);
|
||||||
|
|
||||||
|
} else {
|
||||||
|
$('<div></div>', {class: 'mui-row'}).append($('<div></div>', {
|
||||||
|
class: 'mui-col-xs-12 mui--text-title mui-ellipsis-2', text: title
|
||||||
|
})).appendTo(frame);
|
||||||
|
|
||||||
|
}
|
||||||
this.$frame.append(frame);
|
this.$frame.append(frame);
|
||||||
this.$id[modeID] = $('#' + this.frames[modeID]);
|
this.$id[modeID] = $('#' + this.frames[modeID]);
|
||||||
|
|
||||||
// Call the parent displayForm first...
|
// Call the parent displayForm first...
|
||||||
|
|
||||||
var row = $('<div />', {class: 'mui-row'});
|
row = $('<div></div>', {class: 'mui-row'});
|
||||||
|
|
||||||
$('<div />', {
|
$('<div></div>', {
|
||||||
class: 'mui-col-xs-4 mui--text-accent mui--text-center', text: 'X'
|
class: 'mui-col-xs-4 mui--text-accent mui--text-center', text: 'X'
|
||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
$('<div />', {
|
$('<div></div>', {
|
||||||
class: 'mui-col-xs-4 mui--text-accent mui--text-center', text: 'Y'
|
class: 'mui-col-xs-4 mui--text-accent mui--text-center', text: 'Y'
|
||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
$('<div />', {
|
$('<div></div>', {
|
||||||
class: 'mui-col-xs-4 mui--text-accent mui--text-center', text: 'Z'
|
class: 'mui-col-xs-4 mui--text-accent mui--text-center', text: 'Z'
|
||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
|
|
||||||
this.$id[modeID].append(row);
|
this.$id[modeID].append(row);
|
||||||
|
|
||||||
row = $('<div />', {class: 'mui-row'});
|
row = $('<div></div>', {class: 'mui-row'});
|
||||||
|
|
||||||
$('<div />', {
|
$('<div></div>', {
|
||||||
class: 'mui-col-xs-4 mui--text-dark mui--text-center',
|
class: 'mui-col-xs-4 mui--text-light mui--text-center',
|
||||||
text: '--',
|
text: '--',
|
||||||
id: this.frames[modeID] + '-x'
|
id: this.frames[modeID] + '-x'
|
||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
$('<div />', {
|
$('<div></div>', {
|
||||||
class: 'mui-col-xs-4 mui--text-dark mui--text-center',
|
class: 'mui-col-xs-4 mui--text-light mui--text-center',
|
||||||
text: '--',
|
text: '--',
|
||||||
id: this.frames[modeID] + '-y'
|
id: this.frames[modeID] + '-y'
|
||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
$('<div />', {
|
$('<div></div>', {
|
||||||
class: 'mui-col-xs-4 mui--text-dark mui--text-center',
|
class: 'mui-col-xs-4 mui--text-light mui--text-center',
|
||||||
text: '--',
|
text: '--',
|
||||||
id: this.frames[modeID] + '-z'
|
id: this.frames[modeID] + '-z'
|
||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
@ -373,9 +517,9 @@ CC2650_ACCEL = function(p) {
|
|||||||
this.$result[this.frames[modeID] + '-y'] = $('#' + this.frames[modeID] + '-y');
|
this.$result[this.frames[modeID] + '-y'] = $('#' + this.frames[modeID] + '-y');
|
||||||
this.$result[this.frames[modeID] + '-z'] = $('#' + this.frames[modeID] + '-z');
|
this.$result[this.frames[modeID] + '-z'] = $('#' + this.frames[modeID] + '-z');
|
||||||
|
|
||||||
row = $('<div />', {class: 'mui-row'});
|
row = $('<div></div>', {class: 'mui-row'});
|
||||||
|
|
||||||
var _graph = this.generateBlankGraph(mode);
|
_graph = this.generateBlankGraph(mode, height);
|
||||||
row.append($('<div>', {class: 'mui-col-sm-12'}).append(_graph));
|
row.append($('<div>', {class: 'mui-col-sm-12'}).append(_graph));
|
||||||
|
|
||||||
this.$id[modeID].append(row);
|
this.$id[modeID].append(row);
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
* Time: 10:13
|
* Time: 10:13
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
/* global CAPABILITY, inheritsFrom, capabilityManager, device */
|
/* global CAPABILITY, inheritsFrom, capabilityManager, EJS */
|
||||||
/* global ble */
|
/* global ble */
|
||||||
/* jshint browser: true , devel: true*/
|
/* jshint browser: true , devel: true*/
|
||||||
|
|
||||||
@ -84,73 +84,99 @@ var CC2650_BAR = function(p) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
this.animateGraph = function() {
|
this.animateGraph = function() {
|
||||||
this.simpleGraph(this.data.temp, 'temp');
|
/* This.simpleGraph(this.data.temp, 'temp');
|
||||||
this.simpleGraph(this.data.pressure, 'pressure');
|
this.simpleGraph(this.data.pressure, 'pressure');*/
|
||||||
|
|
||||||
|
var arcTemp = this.frameID + 'temp-arc';
|
||||||
|
var arcPressure = this.frameID + 'pressure-arc';
|
||||||
|
this.updateArc(this.data.temp, 'temp' , arcTemp, '°C', 50);
|
||||||
|
this.updateArc(this.data.pressure, 'pressure' , arcPressure, 'hPa');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
this.insertFrame = function() {
|
this.insertFrame = function() {
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
var blankChart;
|
|
||||||
|
|
||||||
// Call the parent displayForm first...
|
// Call the parent displayForm first...
|
||||||
this.superClass_.insertFrame.call(self);
|
this.superClass_.insertFrame.call(self);
|
||||||
|
|
||||||
var temp = this.frameID + '-t';
|
var temp = this.frameID + '-t';
|
||||||
var pressure = this.frameID + '-p';
|
var pressure = this.frameID + '-p';
|
||||||
var row = $('<div />', {class: 'mui-row'});
|
|
||||||
|
|
||||||
$('<div />', { class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Temp:'}).appendTo(row);
|
var arcB = this.frameID + 'temp-arcB';
|
||||||
|
var arcTemp = this.frameID + 'temp-arc';
|
||||||
|
|
||||||
$('<div />', { class: 'mui-col-xs-3 mui--text-dark', id: temp}).appendTo(row);
|
var pressureArcB = this.frameID + 'pressure-arcB';
|
||||||
$('<div />', { class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Pressure:'}).appendTo(row);
|
var arcPressure = this.frameID + 'pressure-arc';
|
||||||
|
|
||||||
$('<div />', { class: 'mui-col-xs-3 mui--text-dark', id: pressure}).appendTo(row);
|
var settings = {data: {baseID: this.frameID}};
|
||||||
|
var html = new EJS({url: './partials/cc2650_barometer_dial.ejs'}).render(settings);
|
||||||
|
|
||||||
this.$id.append(row);
|
this.$id.append(html);
|
||||||
|
|
||||||
if (/ipad/i.test(device.model)) {
|
document.getElementById(arcB).setAttribute('d', this.describeArc(150, 150, 100, 0, 240));
|
||||||
|
document.getElementById(arcTemp).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(0)));
|
||||||
|
|
||||||
tabBody = $('<div>', {class: 'mui-row'});
|
document.getElementById(pressureArcB).setAttribute('d', this.describeArc(150, 150, 100, 0, 240));
|
||||||
|
document.getElementById(arcPressure).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(0)));
|
||||||
|
|
||||||
tabBody.append($('<div>',{class: 'mui-col-md-6'}).append(this.generateBlankGraph('temp'))) ;
|
|
||||||
tabBody.append($('<div>',{class: 'mui-col-md-6'}).append(this.generateBlankGraph('pressure'))) ;
|
|
||||||
this.$id.append(tabBody);
|
|
||||||
|
|
||||||
} else {
|
/* Var row = $('<div />', {class: 'mui-row'});
|
||||||
|
|
||||||
var tabBody = $('<ul>',
|
$('<div />', { class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Temp:'}).appendTo(row);
|
||||||
{class: 'mui-tabs__bar mui-tabs__bar--justified'});
|
|
||||||
$('<li>', {class: 'mui--is-active tabOnWhite'}).append($('<a>',
|
|
||||||
{
|
|
||||||
text: 'Temperature',
|
|
||||||
'data-mui-toggle': 'tab',
|
|
||||||
'data-mui-controls': (temp + '-pane')
|
|
||||||
})).appendTo(tabBody);
|
|
||||||
$('<li>', {class: 'tabOnWhite'}).append($('<a>',
|
|
||||||
{
|
|
||||||
text: 'Pressure',
|
|
||||||
'data-mui-toggle': 'tab',
|
|
||||||
'data-mui-controls': (pressure + '-pane')
|
|
||||||
})).appendTo(tabBody);
|
|
||||||
|
|
||||||
this.$id.append(tabBody);
|
$('<div />', { class: 'mui-col-xs-3 mui--text-dark', id: temp}).appendTo(row);
|
||||||
|
$('<div />', { class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Pressure:'}).appendTo(row);
|
||||||
|
|
||||||
blankChart = this.generateBlankGraph('temp');
|
$('<div />', { class: 'mui-col-xs-3 mui--text-dark', id: pressure}).appendTo(row);
|
||||||
|
|
||||||
this.$id.append($('<div>',
|
this.$id.append(row);
|
||||||
{class: 'mui-tabs__pane mui--is-active', id: (temp + '-pane')}).append(
|
|
||||||
blankChart));
|
|
||||||
|
|
||||||
blankChart = this.generateBlankGraph('pressure');
|
if (/ipad/i.test(device.model)) {
|
||||||
|
|
||||||
this.$id.append($('<div>',
|
tabBody = $('<div>', {class: 'mui-row'});
|
||||||
{
|
|
||||||
class: 'mui-tabs__pane',
|
tabBody.append($('<div>',{class: 'mui-col-md-6'}).append(this.generateBlankGraph('temp'))) ;
|
||||||
id: (pressure + '-pane')
|
tabBody.append($('<div>',{class: 'mui-col-md-6'}).append(this.generateBlankGraph('pressure'))) ;
|
||||||
}).append(blankChart));
|
this.$id.append(tabBody);
|
||||||
}
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
var tabBody = $('<ul>',
|
||||||
|
{class: 'mui-tabs__bar mui-tabs__bar--justified'});
|
||||||
|
$('<li>', {class: 'mui--is-active tabOnWhite'}).append($('<a>',
|
||||||
|
{
|
||||||
|
text: 'Temperature',
|
||||||
|
'data-mui-toggle': 'tab',
|
||||||
|
'data-mui-controls': (temp + '-pane')
|
||||||
|
})).appendTo(tabBody);
|
||||||
|
$('<li>', {class: 'tabOnWhite'}).append($('<a>',
|
||||||
|
{
|
||||||
|
text: 'Pressure',
|
||||||
|
'data-mui-toggle': 'tab',
|
||||||
|
'data-mui-controls': (pressure + '-pane')
|
||||||
|
})).appendTo(tabBody);
|
||||||
|
|
||||||
|
this.$id.append(tabBody);
|
||||||
|
|
||||||
|
blankChart = this.generateBlankGraph('temp');
|
||||||
|
|
||||||
|
this.$id.append($('<div>',
|
||||||
|
{class: 'mui-tabs__pane mui--is-active', id: (temp + '-pane')}).append(
|
||||||
|
blankChart));
|
||||||
|
|
||||||
|
blankChart = this.generateBlankGraph('pressure');
|
||||||
|
|
||||||
|
this.$id.append($('<div>',
|
||||||
|
{
|
||||||
|
class: 'mui-tabs__pane',
|
||||||
|
id: (pressure + '-pane')
|
||||||
|
}).append(blankChart));
|
||||||
|
}*/
|
||||||
this.$result.temp = $('#' + temp);
|
this.$result.temp = $('#' + temp);
|
||||||
this.$result.pressure = $('#' + pressure);
|
this.$result.pressure = $('#' + pressure);
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
* Time: 10:13
|
* Time: 10:13
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
/* global CAPABILITY, inheritsFrom, capabilityManager, device */
|
/* global CAPABILITY, inheritsFrom, capabilityManager, EJS */
|
||||||
/* global ble */
|
/* global ble */
|
||||||
/* jshint browser: true , devel: true*/
|
/* jshint browser: true , devel: true*/
|
||||||
|
|
||||||
@ -87,28 +87,55 @@ var CC2650_HUM = function(p) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
this.animateGraph = function() {
|
this.animateGraph = function() {
|
||||||
this.simpleGraph(this.data.temp, 'temp');
|
/*
|
||||||
|
This.simpleGraph(this.data.temp, 'temp');
|
||||||
this.simpleGraph(this.data.humidity, 'humidity');
|
this.simpleGraph(this.data.humidity, 'humidity');
|
||||||
};
|
*/
|
||||||
|
var arcTemp = this.frameID + 'temp-arc';
|
||||||
|
var arcHumidity = this.frameID + 'humidity-arc';
|
||||||
|
this.updateArc(this.data.temp, 'temp' , arcTemp, '°C', 50);
|
||||||
|
this.updateArc(this.data.humidity, 'humidity' , arcHumidity, '%RH', 100);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
this.insertFrame = function() {
|
this.insertFrame = function() {
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
var blankChart;
|
|
||||||
|
|
||||||
// Call the parent displayForm first...
|
// Call the parent displayForm first...
|
||||||
this.superClass_.insertFrame.call(self);
|
this.superClass_.insertFrame.call(self);
|
||||||
|
|
||||||
var temp = this.frameID + '-t';
|
var temp = this.frameID + '-t';
|
||||||
var humidity = this.frameID + '-h';
|
var humidity = this.frameID + '-h';
|
||||||
var row = $('<div />', {class: 'mui-row'});
|
|
||||||
|
var arcB = this.frameID + 'temp-arcB';
|
||||||
|
var arcTemp = this.frameID + 'temp-arc';
|
||||||
|
|
||||||
|
|
||||||
|
var humidityArcB = this.frameID + 'humidity-arcB';
|
||||||
|
var arcHumidity = this.frameID + 'humidity-arc';
|
||||||
|
|
||||||
|
|
||||||
|
var settings = {data: {baseID: this.frameID}};
|
||||||
|
var html = new EJS({url: './partials/cc2650_humidity_dial.ejs'}).render(settings);
|
||||||
|
|
||||||
|
this.$id.append(html);
|
||||||
|
|
||||||
|
document.getElementById(arcB).setAttribute('d', this.describeArc(150, 150, 100, 0, 240));
|
||||||
|
document.getElementById(arcTemp).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(0)));
|
||||||
|
|
||||||
|
document.getElementById(humidityArcB).setAttribute('d', this.describeArc(150, 150, 100, 0, 240));
|
||||||
|
document.getElementById(arcHumidity).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(0)));
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
Var row = $('<div />', {class: 'mui-row'});
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Temp:'}).appendTo(row);
|
{class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Temp:'}).appendTo(row);
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-3 mui--text-dark', id: temp}).appendTo(row);
|
{class: 'mui-col-xs-3 mui--text-light', id: temp}).appendTo(row);
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{
|
{
|
||||||
class: 'mui-col-xs-3 mui--text-accent mui--text-right',
|
class: 'mui-col-xs-3 mui--text-accent mui--text-right',
|
||||||
@ -116,7 +143,7 @@ var CC2650_HUM = function(p) {
|
|||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-3 mui--text-dark', id: humidity}).appendTo(row);
|
{class: 'mui-col-xs-3 mui--text-light', id: humidity}).appendTo(row);
|
||||||
|
|
||||||
this.$id.append(row);
|
this.$id.append(row);
|
||||||
|
|
||||||
@ -157,7 +184,7 @@ var CC2650_HUM = function(p) {
|
|||||||
class: 'mui-tabs__pane',
|
class: 'mui-tabs__pane',
|
||||||
id: (humidity + '-pane')
|
id: (humidity + '-pane')
|
||||||
}).append(blankChart));
|
}).append(blankChart));
|
||||||
}
|
}*/
|
||||||
this.$result.temp = $('#' + temp);
|
this.$result.temp = $('#' + temp);
|
||||||
this.$result.humidity = $('#' + humidity);
|
this.$result.humidity = $('#' + humidity);
|
||||||
|
|
||||||
|
@ -95,7 +95,7 @@ var CC2650_LUX = function(p) {
|
|||||||
row);
|
row);
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-8 mui--text-dark', id: lux}).appendTo(row);
|
{class: 'mui-col-xs-8 mui--text-light', id: lux}).appendTo(row);
|
||||||
|
|
||||||
this.$id.append(row);
|
this.$id.append(row);
|
||||||
|
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
* Time: 10:13
|
* Time: 10:13
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
/* global CAPABILITY, inheritsFrom, capabilityManager */
|
/* global CAPABILITY, inheritsFrom, capabilityManager, EJS */
|
||||||
/* global ble */
|
/* global ble */
|
||||||
/* jshint browser: true , devel: true*/
|
/* jshint browser: true , devel: true*/
|
||||||
|
|
||||||
@ -87,15 +87,17 @@ var CC2650_TMP = function(p) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
this.animateGraph = function() {
|
this.animateGraph = function() {
|
||||||
this.simpleGraph(this.data.temp, 'temp');
|
// This.simpleGraph(this.data.temp, 'temp');
|
||||||
this.simpleGraph(this.data.ambient, 'ambient');
|
// debugger;
|
||||||
|
var arcTemp = this.frameID + 'temp-arc';
|
||||||
|
var arcAmbient = this.frameID + 'ambient-arc';
|
||||||
|
this.updateArc(this.data.temp, 'temp' , arcTemp, '°C', 50);
|
||||||
|
this.updateArc(this.data.ambient, 'ambient' , arcAmbient, '°C', 50);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
this.insertFrame = function() {
|
this.insertFrame = function() {
|
||||||
|
|
||||||
var liSetting;
|
|
||||||
var tabBody;
|
|
||||||
var blankChart;
|
|
||||||
var self = this;
|
var self = this;
|
||||||
// Console.log('Overloading...');
|
// Console.log('Overloading...');
|
||||||
// Call the parent displayForm first...
|
// Call the parent displayForm first...
|
||||||
@ -104,13 +106,33 @@ var CC2650_TMP = function(p) {
|
|||||||
|
|
||||||
var temp = this.frameID + '-t';
|
var temp = this.frameID + '-t';
|
||||||
var amb = this.frameID + '-a';
|
var amb = this.frameID + '-a';
|
||||||
var row = $('<div />', {class: 'mui-row'});
|
|
||||||
|
|
||||||
|
var arcB = this.frameID + 'temp-arcB';
|
||||||
|
var arcTemp = this.frameID + 'temp-arc';
|
||||||
|
|
||||||
|
var ambientArcB = this.frameID + 'ambient-arcB';
|
||||||
|
var arcAmbient = this.frameID + 'ambient-arc';
|
||||||
|
|
||||||
|
var settings = {data: {baseID: this.frameID}};
|
||||||
|
var html = new EJS({url: './partials/cc2650_thermopile_dial.ejs'}).render(settings);
|
||||||
|
|
||||||
|
this.$id.append(html);
|
||||||
|
|
||||||
|
document.getElementById(arcB).setAttribute('d', this.describeArc(150, 150, 100, 0, 240));
|
||||||
|
document.getElementById(arcTemp).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(0)));
|
||||||
|
|
||||||
|
document.getElementById(ambientArcB).setAttribute('d', this.describeArc(150, 150, 100, 0, 240));
|
||||||
|
document.getElementById(arcAmbient).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(0)));
|
||||||
|
|
||||||
|
|
||||||
|
/*Var row = $('<div />', {class: 'mui-row'});
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Temp:'}).appendTo(row);
|
{class: 'mui-col-xs-3 mui--text-accent mui--text-right', text: 'Temp:'}).appendTo(row);
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-3 mui--text-dark mui--text-left', id: temp}).appendTo(row);
|
{class: 'mui-col-xs-3 mui--text-light mui--text-left', id: temp}).appendTo(row);
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{
|
{
|
||||||
class: 'mui-col-xs-3 mui--text-accent mui--text-right',
|
class: 'mui-col-xs-3 mui--text-accent mui--text-right',
|
||||||
@ -118,7 +140,7 @@ var CC2650_TMP = function(p) {
|
|||||||
}).appendTo(row);
|
}).appendTo(row);
|
||||||
|
|
||||||
$('<div />',
|
$('<div />',
|
||||||
{class: 'mui-col-xs-3 mui--text-dark', id: amb}).appendTo(row);
|
{class: 'mui-col-xs-3 mui--text-light', id: amb}).appendTo(row);
|
||||||
|
|
||||||
this.$id.append(row);
|
this.$id.append(row);
|
||||||
|
|
||||||
@ -152,7 +174,7 @@ var CC2650_TMP = function(p) {
|
|||||||
this.$id.append($('<div>',{class: 'mui-tabs__pane',id: (amb + '-pane')}).append(blankChart));
|
this.$id.append($('<div>',{class: 'mui-tabs__pane',id: (amb + '-pane')}).append(blankChart));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
this.$result.temp = $('#' + temp);
|
this.$result.temp = $('#' + temp);
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* global MANUFACTUREDECODER */
|
/* global */
|
||||||
/* jshint browser: true , devel: true*/
|
/* jshint browser: true , devel: true*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -45,12 +45,47 @@ var CAPABILITY = function(p) {
|
|||||||
|
|
||||||
this.target = null;
|
this.target = null;
|
||||||
this.$frame = null;
|
this.$frame = null;
|
||||||
|
this.maxLength = 99;
|
||||||
|
|
||||||
this.previousCeil = 0;
|
this.previousCeil = 0;
|
||||||
|
|
||||||
capabilityManager.register({id: this.capabilityID, module: this});
|
capabilityManager.register({id: this.capabilityID, module: this});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
CAPABILITY.prototype.arrayToAscii = function(a) {
|
||||||
|
|
||||||
|
var _a = [].slice.call(a);
|
||||||
|
_a = _a.map(function(num) {
|
||||||
|
return String.fromCharCode(num);
|
||||||
|
});
|
||||||
|
|
||||||
|
return _a.join('');
|
||||||
|
};
|
||||||
|
|
||||||
|
CAPABILITY.prototype.arrayToHex = function(a) {
|
||||||
|
|
||||||
|
var _a = [].slice.call(a);
|
||||||
|
_a = _a.map(function(num) {
|
||||||
|
return ('00' + num.toString(16)).slice(-2);
|
||||||
|
});
|
||||||
|
|
||||||
|
return _a.join(', ');
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
CAPABILITY.prototype.readRaw = function(id, data) {
|
||||||
|
|
||||||
|
|
||||||
|
var a = new Uint8Array(data);
|
||||||
|
|
||||||
|
console.log(id, a);
|
||||||
|
console.log(id, this.arrayToAscii(a));
|
||||||
|
console.log(id, this.arrayToHex(a));
|
||||||
|
console.log(data);
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
CAPABILITY.prototype.setFrame = function() {
|
CAPABILITY.prototype.setFrame = function() {
|
||||||
this.$frame = (this.target !== null) ? $('#' + this.target) : null;
|
this.$frame = (this.target !== null) ? $('#' + this.target) : null;
|
||||||
};
|
};
|
||||||
@ -114,7 +149,7 @@ CAPABILITY.prototype.storeData = function(data, alt) {
|
|||||||
}
|
}
|
||||||
var target = alt || this.data;
|
var target = alt || this.data;
|
||||||
|
|
||||||
if (target.length === 99) {
|
if (target.length === this.maxLength) {
|
||||||
target = target.slice(1);
|
target = target.slice(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -242,6 +277,79 @@ CAPABILITY.prototype.animateGraph = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
CAPABILITY.prototype.polarToCartesian = function(centerX, centerY, radius, angleInDegrees) {
|
||||||
|
var angleInRadians = (angleInDegrees - 90) * Math.PI / 180.0;
|
||||||
|
|
||||||
|
return {
|
||||||
|
x: centerX + (radius * Math.cos(angleInRadians)),
|
||||||
|
y: centerY + (radius * Math.sin(angleInRadians))
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
CAPABILITY.prototype.describeArc = function(x, y, radius, startAngle, endAngle) {
|
||||||
|
|
||||||
|
var start = this.polarToCartesian(x, y, radius, endAngle);
|
||||||
|
var end = this.polarToCartesian(x, y, radius, startAngle);
|
||||||
|
|
||||||
|
var arcSweep = endAngle - startAngle <= 180 ? '0' : '1';
|
||||||
|
|
||||||
|
var d = [
|
||||||
|
'M', start.x, start.y,
|
||||||
|
'A', radius, radius, 0, arcSweep, 0, end.x, end.y
|
||||||
|
].join(' ');
|
||||||
|
|
||||||
|
return d;
|
||||||
|
};
|
||||||
|
|
||||||
|
CAPABILITY.prototype.setArc = function(percent) {
|
||||||
|
return (240 / 100) * percent;
|
||||||
|
};
|
||||||
|
|
||||||
|
CAPABILITY.prototype.updateArc = function(data, subID, elmID, suffix, limiter) {
|
||||||
|
|
||||||
|
|
||||||
|
var ceilingLimit;
|
||||||
|
var ceiling;
|
||||||
|
var _subID;
|
||||||
|
var _data;
|
||||||
|
var _limiter = limiter || null;
|
||||||
|
var _suffix = suffix || '';
|
||||||
|
var label;
|
||||||
|
|
||||||
|
_data = data || this.data;
|
||||||
|
|
||||||
|
_subID = subID || '';
|
||||||
|
label = '#' + this.frameID + _subID + '-label';
|
||||||
|
|
||||||
|
if (_data.length > 0) {
|
||||||
|
|
||||||
|
if (_limiter === null) {
|
||||||
|
ceiling = _data.reduce(function(p, v) {
|
||||||
|
return (Math.abs(p) > Math.abs(v) ? Math.abs(p) : Math.abs(v));
|
||||||
|
});
|
||||||
|
|
||||||
|
ceilingLimit = (Math.ceil((Math.round(ceiling) + 1) / 10) * 10);
|
||||||
|
if (ceilingLimit > 1000) {
|
||||||
|
ceilingLimit = (Math.ceil((Math.round(ceiling) + 1) / 50) * 50);
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
ceilingLimit = _limiter;
|
||||||
|
}
|
||||||
|
|
||||||
|
var latest = _data[_data.length - 1];
|
||||||
|
var scale = 100 / ceilingLimit;
|
||||||
|
var arcP = scale * latest;
|
||||||
|
|
||||||
|
document.getElementById(elmID).setAttribute('d', this.describeArc(150, 150, 100, 0, this.setArc(arcP)));
|
||||||
|
$(label).text(latest.toFixed(2) + _suffix);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
CAPABILITY.prototype.simpleGraph = function(data, subID) {
|
CAPABILITY.prototype.simpleGraph = function(data, subID) {
|
||||||
|
|
||||||
var ceilingLimit;
|
var ceilingLimit;
|
||||||
@ -272,8 +380,8 @@ CAPABILITY.prototype.simpleGraph = function(data, subID) {
|
|||||||
|
|
||||||
var calcArray = [];
|
var calcArray = [];
|
||||||
|
|
||||||
/*
|
/*
|
||||||
var ceilingLimit = Math.floor(ceiling / 10) * 10;
|
Var ceilingLimit = Math.floor(ceiling / 10) * 10;
|
||||||
if (ceilingLimit < ceiling) {
|
if (ceilingLimit < ceiling) {
|
||||||
ceilingLimit = Math.floor((ceiling + (ceiling * 0.25)) / 10) * 10;
|
ceilingLimit = Math.floor((ceiling + (ceiling * 0.25)) / 10) * 10;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user