2023-04-24 10:27:08 +00:00
|
|
|
{
|
|
|
|
let log = function() {};//print
|
|
|
|
let gatt;
|
2023-04-24 09:42:16 +00:00
|
|
|
|
2023-04-24 09:56:01 +00:00
|
|
|
Bangle.enableBTHRMLog = function() {
|
|
|
|
log = print;
|
|
|
|
};
|
|
|
|
|
2023-04-24 09:42:16 +00:00
|
|
|
Bangle.setHRMPower = function(isOn, app) {
|
|
|
|
// Do app power handling
|
|
|
|
if (!app) app="?";
|
|
|
|
log("setHRMPower ->", isOn, app);
|
|
|
|
if (Bangle._PWR===undefined) Bangle._PWR={};
|
|
|
|
if (Bangle._PWR.HRM===undefined) Bangle._PWR.HRM=[];
|
|
|
|
if (isOn && !Bangle._PWR.HRM.includes(app)) Bangle._PWR.HRM.push(app);
|
|
|
|
if (!isOn && Bangle._PWR.HRM.includes(app)) Bangle._PWR.HRM = Bangle._PWR.HRM.filter(a=>a!=app);
|
|
|
|
isOn = Bangle._PWR.HRM.length;
|
|
|
|
// so now we know if we're really on
|
|
|
|
if (isOn) {
|
|
|
|
log("setHRMPower on", app);
|
|
|
|
if (!gatt) {
|
|
|
|
log("HRM not already on");
|
|
|
|
NRF.requestDevice({ filters: [{ services: ['180D'] }] }).then(function(device) {
|
|
|
|
log("Found device "+device.id);
|
|
|
|
device.on('gattserverdisconnected', function(reason) {
|
|
|
|
gatt = undefined;
|
|
|
|
});
|
|
|
|
return device.gatt.connect();
|
|
|
|
}).then(function(g) {
|
|
|
|
log("Connected");
|
|
|
|
gatt = g;
|
|
|
|
return gatt.getPrimaryService(0x180D);
|
|
|
|
}).then(function(service) {
|
|
|
|
return service.getCharacteristic(0x2A37);
|
|
|
|
}).then(function(characteristic) {
|
|
|
|
log("Got characteristic");
|
|
|
|
characteristic.on('characteristicvaluechanged', function(event) {
|
|
|
|
var dv = event.target.value;
|
|
|
|
var flags = dv.getUint8(0);
|
|
|
|
// 0 = 8 or 16 bit
|
|
|
|
// 1,2 = sensor contact
|
|
|
|
// 3 = energy expended shown
|
|
|
|
// 4 = RR interval
|
|
|
|
var bpm = (flags&1) ? (dv.getUint16(1)/100/* ? */) : dv.getUint8(1); // 8 or 16 bit
|
|
|
|
/* var idx = 2 + (flags&1); // index of next field
|
|
|
|
if (flags&8) idx += 2; // energy expended
|
|
|
|
if (flags&16) {
|
|
|
|
var interval = dv.getUint16(idx,1); // in milliseconds
|
|
|
|
}*/
|
|
|
|
Bangle.emit('HRM',{
|
|
|
|
bpm:bpm,
|
|
|
|
confidence:100
|
|
|
|
});
|
|
|
|
});
|
|
|
|
return characteristic.startNotifications();
|
|
|
|
}).then(function() {
|
|
|
|
log("Ready");
|
|
|
|
console.log("Done!");
|
|
|
|
}).catch(function(err) {
|
2023-04-24 10:27:08 +00:00
|
|
|
console.log("BTHRM Error",err);
|
2023-04-24 09:42:16 +00:00
|
|
|
gatt = undefined;
|
2023-04-24 10:27:08 +00:00
|
|
|
// retry connection if we got a connect timeout
|
|
|
|
if (err == "Connection Timeout")
|
|
|
|
setTimeout(Bangle.setHRMPower, 1000, isOn, app);
|
2023-04-24 09:42:16 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
} else { // not on
|
|
|
|
log("setHRMPower off", app);
|
|
|
|
if (gatt) {
|
|
|
|
log("HRM connected - disconnecting");
|
|
|
|
try {gatt.disconnect();}catch(e) {
|
|
|
|
log("HRM disconnect error", e);
|
|
|
|
}
|
|
|
|
gatt = undefined;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
2023-04-24 10:27:08 +00:00
|
|
|
// disconnect when swapping apps
|
|
|
|
E.on("kill", function() {
|
|
|
|
if (gatt) {
|
|
|
|
log("HRM connected - disconnecting");
|
|
|
|
try {gatt.disconnect();}catch(e) {
|
|
|
|
log("HRM disconnect error", e);
|
|
|
|
}
|
|
|
|
gatt = undefined;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
}
|