mirror of
https://github.com/scratchfoundation/scratch-vm.git
synced 2025-01-11 10:39:56 -05:00
- Consolidated BLE enums for brevity
- Added IOs from documentation to BoostIO enumotor follows the speed set by Scratch and not the highest possible speed. - Cleaned up line breaks in codebrake rather than float when stopping. - Cleaned up documentationensors - Deleted unused MOTOR_OUTPUT from BoostMode-enumbased on BoostMode-enum - Set default-value for "set motor power to"-block to be all motors after feedback from @ericrosenbaum - Implemented check in getMotorPosition() to see if motor is actually there before reporting position
This commit is contained in:
parent
40c022ca8e
commit
7fc705b741
1 changed files with 85 additions and 70 deletions
|
@ -22,16 +22,14 @@ const log = require('../../util/log');
|
|||
const iconURI = '';
|
||||
|
||||
/**
|
||||
* Boost BLE service UUID.
|
||||
* @type {string}
|
||||
* Boost BLE UUIDs.
|
||||
* @enum {string}
|
||||
*/
|
||||
const BLEService = '00001623-1212-efde-1623-785feabcd123';
|
||||
|
||||
/**
|
||||
* Boost BLE characteristic UUID.
|
||||
* @type {string}
|
||||
*/
|
||||
const BLECharacteristic = '00001624-1212-efde-1623-785feabcd123';
|
||||
const BoostBLE = {
|
||||
service: '00001623-1212-efde-1623-785feabcd123',
|
||||
characteristic: '00001624-1212-efde-1623-785feabcd123'
|
||||
}
|
||||
|
||||
/**
|
||||
* A time interval to wait (in milliseconds) while a block that sends a BLE message is running.
|
||||
|
@ -51,13 +49,23 @@ const BLESendRateMax = 20;
|
|||
* @enum {number}
|
||||
*/
|
||||
const BoostIO = {
|
||||
MOTORINT: 0x27,
|
||||
MOTOREXT: 0x26,
|
||||
LED: 0x17,
|
||||
TILT: 0x28,
|
||||
COLOR: 0x25,
|
||||
MOTOR_WEDO: 0x01,
|
||||
MOTOR_SYSTEM: 0x02,
|
||||
BUTTON: 0x05,
|
||||
LIGHT: 0x08,
|
||||
LIGHT1:0x09,
|
||||
LIGHT2:0x0A,
|
||||
VOLTAGE: 0x14,
|
||||
CURRENT: 0x15,
|
||||
PIEZO: 0x16,
|
||||
LED: 0x17,
|
||||
TILT_EXTERNAL: 0x22,
|
||||
MOTION_SENSOR: 0x23,
|
||||
COLOR: 0x25,
|
||||
MOTOREXT: 0x26,
|
||||
MOTORINT: 0x27,
|
||||
TILT: 0x28,
|
||||
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -86,6 +94,11 @@ const BoostPort = {
|
|||
D: 2
|
||||
};
|
||||
|
||||
/**
|
||||
* Enum for indexed colors read by the Boost Vision Sensor
|
||||
* @readonly
|
||||
* @enum {number}
|
||||
*/
|
||||
const BoostColor = {
|
||||
NONE: 255,
|
||||
RED: 9,
|
||||
|
@ -101,7 +114,6 @@ const BoostColor = {
|
|||
* @readonly
|
||||
* @enum {number}
|
||||
*/
|
||||
|
||||
const BoostMessage = {
|
||||
HUB_PROPERTIES: 0x01,
|
||||
HUB_ACTIONS: 0x02,
|
||||
|
@ -125,7 +137,6 @@ const BoostMessage = {
|
|||
* @readonly
|
||||
* @enum {number}
|
||||
*/
|
||||
|
||||
const BoostOutputSubCommand = {
|
||||
START_POWER_PAIR: 0x02,
|
||||
SET_ACC_TIME: 0x05,
|
||||
|
@ -148,7 +159,6 @@ const BoostOutputSubCommand = {
|
|||
* @readonly
|
||||
* @enum {number}
|
||||
*/
|
||||
|
||||
const BoostOutputExecution = {
|
||||
// Startup information
|
||||
BUFFER_IF_NECESSARY: 0x00,
|
||||
|
@ -156,8 +166,6 @@ const BoostOutputExecution = {
|
|||
// Completion information
|
||||
NO_ACTION: 0x00,
|
||||
COMMAND_FEEDBACK: 0x01,
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
@ -167,7 +175,6 @@ const BoostOutputExecution = {
|
|||
* @readonly
|
||||
* @enum {number}
|
||||
*/
|
||||
|
||||
const BoostMotorEndState = {
|
||||
FLOAT: 0,
|
||||
HOLD: 126,
|
||||
|
@ -175,11 +182,10 @@ const BoostMotorEndState = {
|
|||
}
|
||||
|
||||
/**
|
||||
* Enum for Boost Motor Acceleration/Deceleration profiles
|
||||
* Enum for Boost Motor acceleration/deceleration profiles
|
||||
* @readyonly
|
||||
* @enum {number}
|
||||
*/
|
||||
|
||||
const BoostMotorProfile = {
|
||||
DO_NOT_USE: 0x00,
|
||||
ACCELERATION: 0x01,
|
||||
|
@ -192,7 +198,6 @@ const BoostMotorProfile = {
|
|||
* @readonly
|
||||
* @enum {number}
|
||||
*/
|
||||
|
||||
const BoostIOEvent = {
|
||||
ATTACHED: 0x01,
|
||||
DETACHED: 0x00,
|
||||
|
@ -200,7 +205,7 @@ const BoostIOEvent = {
|
|||
}
|
||||
|
||||
/**
|
||||
* Enum for modes for input sensors on the Boost.
|
||||
* Enum for selected sensor modes.
|
||||
* @enum {number}
|
||||
*/
|
||||
const BoostMode = {
|
||||
|
@ -208,7 +213,6 @@ const BoostMode = {
|
|||
LED: 1, // Set LED to accept RGB values
|
||||
COLOR: 0, // Read indexed colors from Vision Sensor
|
||||
MOTOR_SENSOR: 2, // Set motors to report their position
|
||||
MOTOR_OUTPUT: 0,
|
||||
UNKNOWN: 0 // Anything else will use the default mode (mode 0)
|
||||
};
|
||||
|
||||
|
@ -384,28 +388,28 @@ class BoostMotor {
|
|||
}
|
||||
|
||||
/**
|
||||
* @return {int} -
|
||||
* @return {int} - this motor's current position, in the range of [-MIN_INT32,MAX_INT32]
|
||||
*/
|
||||
get position () {
|
||||
return this._position;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {int} value -
|
||||
* @param {int} value - set this motor's current position.
|
||||
*/
|
||||
set position (value) {
|
||||
this._position = value;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return {int} -
|
||||
* @return {int} - this motor's current zero position, which the current position is relative to.
|
||||
*/
|
||||
get positionZero () {
|
||||
return this._positionZero;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {int} value -
|
||||
* @param {int} value - set this motor's zero position.
|
||||
*/
|
||||
set positionZero (value) {
|
||||
this._positionZero = value;
|
||||
|
@ -450,10 +454,10 @@ class BoostMotor {
|
|||
BoostOutputExecution.EXECUTE_IMMEDIATELY ^ BoostOutputExecution.COMMAND_FEEDBACK,
|
||||
BoostOutputSubCommand.START_SPEED,
|
||||
[this._power * this._direction,
|
||||
this._power * this._direction,
|
||||
this._power* this._direction,
|
||||
BoostMotorProfile.DO_NOT_USE]);
|
||||
|
||||
this._parent.send(BLECharacteristic, cmd);
|
||||
this._parent.send(BoostBLE.characteristic, cmd);
|
||||
|
||||
this._status = BoostOutputCommandFeedback.BUFFER_EMPTY_COMMAND_IN_PROGRESS;
|
||||
this._clearTimeout();
|
||||
|
@ -485,19 +489,19 @@ class BoostMotor {
|
|||
BoostOutputSubCommand.START_SPEED_FOR_DEGREES,
|
||||
[...numberToInt32Array(degrees),
|
||||
this._power * this._direction, // power in range 0-100
|
||||
0xFF, // max speed
|
||||
BoostMotorEndState.FLOAT,
|
||||
this._power * this._direction, // max speed
|
||||
BoostMotorEndState.BRAKE,
|
||||
BoostMotorProfile.DO_NOT_USE] // byte for using acceleration/braking profile
|
||||
);
|
||||
|
||||
this._status = BoostOutputCommandFeedback.BUFFER_EMPTY_COMMAND_IN_PROGRESS;
|
||||
|
||||
this._parent.send(BLECharacteristic, cmd);
|
||||
this._parent.send(BoostBLE.characteristic, cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* Start active braking on this motor. After a short time, the motor will turn off.
|
||||
* // TODO: rename this to coastAfter?
|
||||
* // TODO: eliminate this function by changing turnOff() to use BoostMotorEndState.BRAKE?
|
||||
*/
|
||||
startBraking () {
|
||||
if (this._power === 0) return;
|
||||
|
@ -511,7 +515,7 @@ class BoostMotor {
|
|||
BoostMotorProfile.DO_NOT_USE]
|
||||
);
|
||||
|
||||
this._parent.send(BLECharacteristic, cmd);
|
||||
this._parent.send(BoostBLE.characteristic, cmd);
|
||||
|
||||
this._status = BoostOutputCommandFeedback.IDLE;
|
||||
this._setNewTimeout(this.turnOff, BoostMotor.BRAKE_TIME_MS);
|
||||
|
@ -533,7 +537,7 @@ class BoostMotor {
|
|||
BoostMotorProfile.DO_NOT_USE]
|
||||
);
|
||||
|
||||
this._parent.send(BLECharacteristic, cmd, useLimiter);
|
||||
this._parent.send(BoostBLE.characteristic, cmd, useLimiter);
|
||||
|
||||
this._status = BoostOutputCommandFeedback.IDLE;
|
||||
}
|
||||
|
@ -615,7 +619,6 @@ class Boost {
|
|||
this._sensors = {
|
||||
tiltX: 0,
|
||||
tiltY: 0,
|
||||
distance: 0,
|
||||
color: 0,
|
||||
};
|
||||
|
||||
|
@ -662,10 +665,11 @@ class Boost {
|
|||
|
||||
/**
|
||||
* @return {number} - the latest value received from the distance sensor.
|
||||
*/
|
||||
*//*
|
||||
get distance () {
|
||||
return this._sensors.distance;
|
||||
}
|
||||
*/
|
||||
|
||||
/**
|
||||
* @return {number} - the latest color value received from the vision sensor.
|
||||
|
@ -717,7 +721,7 @@ class Boost {
|
|||
...rgb]
|
||||
);
|
||||
|
||||
return this.send(BLECharacteristic, cmd);
|
||||
return this.send(BoostBLE.characteristic, cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -732,7 +736,7 @@ class Boost {
|
|||
false
|
||||
);
|
||||
|
||||
return this.send(BLECharacteristic, cmd);
|
||||
return this.send(BoostBLE.characteristic, cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -752,7 +756,7 @@ class Boost {
|
|||
}
|
||||
this._ble = new BLE(this._runtime, this._extensionId, {
|
||||
filters: [{
|
||||
services: [BLEService],
|
||||
services: [BoostBLE.service],
|
||||
manufacturerData: {
|
||||
0: {
|
||||
dataPrefix: [0x97, 0x03, 0x00, 0x40],
|
||||
|
@ -783,7 +787,6 @@ class Boost {
|
|||
this._sensors = {
|
||||
tiltX: 0,
|
||||
tiltY: 0,
|
||||
distance: 0,
|
||||
color: 0
|
||||
};
|
||||
|
||||
|
@ -819,7 +822,7 @@ class Boost {
|
|||
}
|
||||
|
||||
return this._ble.write(
|
||||
BLEService,
|
||||
BoostBLE.service,
|
||||
uuid,
|
||||
Base64Util.uint8ArrayToBase64(message),
|
||||
'base64'
|
||||
|
@ -880,8 +883,8 @@ class Boost {
|
|||
*/
|
||||
_onConnect () {
|
||||
this._ble.startNotifications(
|
||||
BLEService,
|
||||
BLECharacteristic,
|
||||
BoostBLE.service,
|
||||
BoostBLE.characteristic,
|
||||
this._onMessage
|
||||
);
|
||||
}
|
||||
|
@ -949,6 +952,7 @@ class Boost {
|
|||
if (value > 0x7fffffff) {
|
||||
value = value - 0x100000000;
|
||||
}*/
|
||||
//console.log(data)
|
||||
this._motors[portID]._position = int32ArrayToNumber(data.slice(4,8))
|
||||
break;
|
||||
case BoostIO.CURRENT:
|
||||
|
@ -971,18 +975,16 @@ class Boost {
|
|||
case BoostOutputCommandFeedback.BUFFER_EMPTY_COMMAND_IN_PROGRESS:
|
||||
break;
|
||||
default:
|
||||
console.log(buf2hex(data))
|
||||
console.log("Got it but didn't find a motor on: " + portID)
|
||||
}
|
||||
break;
|
||||
case BoostMessage.PORT_INPUT_FORMAT:
|
||||
case BoostMessage.ERROR:
|
||||
//DEBUG
|
||||
console.log(buf2hex(data))
|
||||
console.log("Error in BLE message: " + buf2hex(data))
|
||||
break;
|
||||
default:
|
||||
//DEBUG
|
||||
console.log(buf2hex(data))
|
||||
//console.log(buf2hex(data))
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -998,45 +1000,48 @@ class Boost {
|
|||
// Record which port is connected to what type of device
|
||||
this._ports[portID] = type;
|
||||
|
||||
|
||||
// Record motor port
|
||||
if (type === BoostIO.MOTORINT || type === BoostIO.MOTOREXT) {
|
||||
this._motors[portID] = new BoostMotor(this, portID);
|
||||
}
|
||||
|
||||
// Set input format for tilt or distance sensor
|
||||
var typeString = ''
|
||||
|
||||
var m = null
|
||||
|
||||
switch(type) {
|
||||
case BoostIO.MOTORINT:
|
||||
case BoostIO.MOTOREXT:
|
||||
typeString = 'MOTOR_SENSOR'
|
||||
m = BoostMode.MOTOR_SENSOR
|
||||
break;
|
||||
case BoostIO.COLOR:
|
||||
typeString = 'COLOR'
|
||||
m = BoostMode.COLOR
|
||||
break;
|
||||
case BoostIO.LED:
|
||||
typeString = 'LED'
|
||||
m = BoostMode.LED
|
||||
this.setLEDMode();
|
||||
this.setLED(0x00FF00);
|
||||
break;
|
||||
case BoostIO.TILT:
|
||||
typeString = 'TILT'
|
||||
m = BoostMode.TILT
|
||||
break;
|
||||
default:
|
||||
typeString = 'UNKNOWN'
|
||||
m = BoostMode.UNKNOWN
|
||||
}
|
||||
|
||||
const cmd = this.generateInputCommand(
|
||||
portID,
|
||||
BoostMode[typeString],
|
||||
m,
|
||||
1,
|
||||
true
|
||||
);
|
||||
|
||||
this.send(BLECharacteristic, cmd);
|
||||
this.send(BoostBLE.characteristic, cmd);
|
||||
}
|
||||
|
||||
/**
|
||||
* Clear the sensor or motor present at port 1 or 2.
|
||||
* Clear the sensors or motors present on the ports.
|
||||
* @param {number} portID - the port to clear.
|
||||
* @private
|
||||
*/
|
||||
|
@ -1045,8 +1050,8 @@ class Boost {
|
|||
if (type === BoostIO.TILT) {
|
||||
this._sensors.tiltX = this._sensors.tiltY = 0;
|
||||
}
|
||||
if (type === BoostIO.DISTANCE) {
|
||||
this._sensors.distance = 0;
|
||||
if (type === BoostIO.COLOR) {
|
||||
this._sensors.color = 0;
|
||||
}
|
||||
this._ports[portID] = 'none';
|
||||
this._motors[portID] = null;
|
||||
|
@ -1219,7 +1224,7 @@ class Scratch3BoostBlocks {
|
|||
MOTOR_ID: {
|
||||
type: ArgumentType.STRING,
|
||||
menu: 'MOTOR_ID',
|
||||
defaultValue: BoostMotorLabel.A
|
||||
defaultValue: BoostMotorLabel.ALL
|
||||
},
|
||||
POWER: {
|
||||
type: ArgumentType.NUMBER,
|
||||
|
@ -1355,7 +1360,7 @@ class Scratch3BoostBlocks {
|
|||
description: 'the value returned by the distance sensor'
|
||||
}),
|
||||
blockType: BlockType.REPORTER
|
||||
},
|
||||
},*/
|
||||
{
|
||||
opcode: 'isTilted',
|
||||
text: formatMessage({
|
||||
|
@ -1371,7 +1376,7 @@ class Scratch3BoostBlocks {
|
|||
defaultValue: BoostTiltDirection.ANY
|
||||
}
|
||||
}
|
||||
},*/
|
||||
},
|
||||
{
|
||||
opcode: 'getTiltAngle',
|
||||
text: formatMessage({
|
||||
|
@ -1918,19 +1923,29 @@ class Scratch3BoostBlocks {
|
|||
* @return {number}
|
||||
*/
|
||||
getMotorPosition (args) {
|
||||
var portID = null
|
||||
switch(args.MOTOR_REPORTER_ID) {
|
||||
|
||||
case BoostMotorLabel.A:
|
||||
return this._peripheral._motors[BoostPort.A].position - this._peripheral._motors[BoostPort.A].positionZero
|
||||
portID = BoostPort.A
|
||||
break;
|
||||
case BoostMotorLabel.B:
|
||||
return this._peripheral._motors[BoostPort.B].position - this._peripheral._motors[BoostPort.B].positionZero
|
||||
portID = BoostPort.B
|
||||
break;
|
||||
case BoostMotorLabel.C:
|
||||
return this._peripheral._motors[BoostPort.C].position - this._peripheral._motors[BoostPort.C].positionZero
|
||||
portID = BoostPort.C
|
||||
break;
|
||||
case BoostMotorLabel.D:
|
||||
return this._peripheral._motors[BoostPort.D].position - this._peripheral._motors[BoostPort.D].positionZero
|
||||
portID = BoostPort.D
|
||||
break;
|
||||
default:
|
||||
log.warn("Asked for a motor position that doesnt exist!")
|
||||
return false;
|
||||
}
|
||||
if(portID && this._peripheral._motors[portID]) {
|
||||
return this._peripheral._motors[portID].position - this._peripheral._motors[portID].positionZero
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in a new issue