From 55ccc4e77a45985678d493074af5ee7c69efacbb Mon Sep 17 00:00:00 2001 From: Kevin Andersen Date: Wed, 13 Mar 2019 14:35:53 -0400 Subject: [PATCH] Implemented pingDevice() which, like the WeDo 2.0 extension, tries to read from the Boost Hub at a given interval. If it doesn't hear back from the hub, it assumes the device has been disconnected. --- src/extensions/scratch3_boost/index.js | 40 ++++++++++++++++++++++++-- 1 file changed, 37 insertions(+), 3 deletions(-) diff --git a/src/extensions/scratch3_boost/index.js b/src/extensions/scratch3_boost/index.js index 51df8e6d7..87b22679e 100644 --- a/src/extensions/scratch3_boost/index.js +++ b/src/extensions/scratch3_boost/index.js @@ -40,6 +40,12 @@ const BoostBLE = { const BoostMotorMaxPower = 100; +/** + * A time interval to wait (in milliseconds) in between battery check calls. + * @type {number} + */ +const BoostPingInterval = 5000; + /** * Enum for Boost sensor and actuator types. * @readonly @@ -594,9 +600,17 @@ class Boost { */ this._rateLimiter = new RateLimiter(BoostBLE.sendRateMax); + /** + * An interval id for the battery check interval. + * @type {number} + * @private + */ + this._pingDeviceId = null; + this.disconnect = this.disconnect.bind(this); this._onConnect = this._onConnect.bind(this); this._onMessage = this._onMessage.bind(this); + this._pingDevice = this._pingDevice.bind(this); } /** @@ -698,13 +712,13 @@ class Boost { } this._ble = new BLE(this._runtime, this._extensionId, { filters: [{ - services: [BoostBLE.service], + services: [BoostBLE.service]/* , manufacturerData: { 0: { dataPrefix: [0x97, 0x03, 0x00, 0x40], mask: [0xFF, 0xFF, 0, 0xFF] } - } + } */ }], optionalServices: [] }, this._onConnect, this.disconnect); @@ -736,6 +750,11 @@ class Boost { if (this._ble) { this._ble.disconnect(); } + + if (this._pingDevice) { + window.clearInterval(this._pingDeviceId); + this._pingDeviceId = null; + } } /** @@ -831,6 +850,7 @@ class Boost { BoostBLE.characteristic, this._onMessage ); + this._pingDeviceId = window.setInterval(this._pingDevice, BoostPingInterval); } /** @@ -925,6 +945,20 @@ class Boost { } } + /** + * Ping the Boost hub. If the Boost hub has disconnected + * for some reason, the BLE socket will get an error back and automatically + * close the socket. + */ + + _pingDevice () { + this._ble.read( + BoostBLE.service, + BoostBLE.characteristic, + false + ); + } + /** * Register a new sensor or motor connected at a port. Store the type of * sensor or motor internally, and then register for notifications on input @@ -958,7 +992,7 @@ class Boost { case BoostIO.LED: mode = BoostMode.LED; this.setLEDMode(); - this.setLED(0x00FF00); + this.setLED(0x0000FF); break; case BoostIO.TILT: mode = BoostMode.TILT;