diff --git a/legoresources/Block icns/Blockcolor-icns.pdf b/legoresources/Block icns/Blockcolor-icns.pdf new file mode 100644 index 00000000..d997847d Binary files /dev/null and b/legoresources/Block icns/Blockcolor-icns.pdf differ diff --git a/legoresources/Block icns/icn_block_Large_motor.svg b/legoresources/Block icns/icn_block_Large_motor.svg new file mode 100644 index 00000000..077f27f6 --- /dev/null +++ b/legoresources/Block icns/icn_block_Large_motor.svg @@ -0,0 +1,193 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_buttons_green.svg b/legoresources/Block icns/icn_block_buttons_green.svg new file mode 100644 index 00000000..340411e0 --- /dev/null +++ b/legoresources/Block icns/icn_block_buttons_green.svg @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_buttons_red.svg b/legoresources/Block icns/icn_block_buttons_red.svg new file mode 100644 index 00000000..2ee8752a --- /dev/null +++ b/legoresources/Block icns/icn_block_buttons_red.svg @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_buttons_yellow.svg b/legoresources/Block icns/icn_block_buttons_yellow.svg new file mode 100644 index 00000000..2a49a878 --- /dev/null +++ b/legoresources/Block icns/icn_block_buttons_yellow.svg @@ -0,0 +1,35 @@ + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_color_sensor.svg b/legoresources/Block icns/icn_block_color_sensor.svg new file mode 100644 index 00000000..96c0f1fa --- /dev/null +++ b/legoresources/Block icns/icn_block_color_sensor.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_display.svg b/legoresources/Block icns/icn_block_display.svg new file mode 100644 index 00000000..fdcbe778 --- /dev/null +++ b/legoresources/Block icns/icn_block_display.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_gyro.svg b/legoresources/Block icns/icn_block_gyro.svg new file mode 100644 index 00000000..5730d1c5 --- /dev/null +++ b/legoresources/Block icns/icn_block_gyro.svg @@ -0,0 +1,101 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_medium_motor.svg b/legoresources/Block icns/icn_block_medium_motor.svg new file mode 100644 index 00000000..cdb56b26 --- /dev/null +++ b/legoresources/Block icns/icn_block_medium_motor.svg @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_touch_sensor.svg b/legoresources/Block icns/icn_block_touch_sensor.svg new file mode 100644 index 00000000..25e8163f --- /dev/null +++ b/legoresources/Block icns/icn_block_touch_sensor.svg @@ -0,0 +1,84 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/Block icns/icn_block_ultra_sonic.svg b/legoresources/Block icns/icn_block_ultra_sonic.svg new file mode 100644 index 00000000..31f0df26 --- /dev/null +++ b/legoresources/Block icns/icn_block_ultra_sonic.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/.DS_Store b/legoresources/SVGassets/.DS_Store new file mode 100644 index 00000000..5008ddfc Binary files /dev/null and b/legoresources/SVGassets/.DS_Store differ diff --git a/legoresources/SVGassets/Color Sensor.svg b/legoresources/SVGassets/Color Sensor.svg new file mode 100644 index 00000000..45efd1fd --- /dev/null +++ b/legoresources/SVGassets/Color Sensor.svg @@ -0,0 +1,246 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/EV3.svg b/legoresources/SVGassets/EV3.svg new file mode 100644 index 00000000..b1259fc7 --- /dev/null +++ b/legoresources/SVGassets/EV3.svg @@ -0,0 +1,146 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/Large Motor.png b/legoresources/SVGassets/Large Motor.png new file mode 100644 index 00000000..32bf7796 Binary files /dev/null and b/legoresources/SVGassets/Large Motor.png differ diff --git a/legoresources/SVGassets/Large Motor.svg b/legoresources/SVGassets/Large Motor.svg new file mode 100644 index 00000000..ee3d43a7 --- /dev/null +++ b/legoresources/SVGassets/Large Motor.svg @@ -0,0 +1,650 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/Medium Motor.svg b/legoresources/SVGassets/Medium Motor.svg new file mode 100644 index 00000000..1c45a248 --- /dev/null +++ b/legoresources/SVGassets/Medium Motor.svg @@ -0,0 +1,220 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/Touch sensor.svg b/legoresources/SVGassets/Touch sensor.svg new file mode 100644 index 00000000..130a40b9 --- /dev/null +++ b/legoresources/SVGassets/Touch sensor.svg @@ -0,0 +1,347 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/brickbuttons.svg b/legoresources/SVGassets/brickbuttons.svg new file mode 100644 index 00000000..d55c25c7 --- /dev/null +++ b/legoresources/SVGassets/brickbuttons.svg @@ -0,0 +1,138 @@ + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/color overview/LEGO-MakeCode-Colors.pdf b/legoresources/SVGassets/color overview/LEGO-MakeCode-Colors.pdf new file mode 100644 index 00000000..bc659245 Binary files /dev/null and b/legoresources/SVGassets/color overview/LEGO-MakeCode-Colors.pdf differ diff --git a/legoresources/SVGassets/gyro.svg b/legoresources/SVGassets/gyro.svg new file mode 100644 index 00000000..629039cf --- /dev/null +++ b/legoresources/SVGassets/gyro.svg @@ -0,0 +1,308 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/icn_port.svg b/legoresources/SVGassets/icn_port.svg new file mode 100644 index 00000000..64b2aad2 --- /dev/null +++ b/legoresources/SVGassets/icn_port.svg @@ -0,0 +1,89 @@ + + + + + + image/svg+xml + + + + + + + + + + + + B + diff --git a/legoresources/SVGassets/screen.svg b/legoresources/SVGassets/screen.svg new file mode 100644 index 00000000..9e5b21fb --- /dev/null +++ b/legoresources/SVGassets/screen.svg @@ -0,0 +1,166 @@ + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + diff --git a/legoresources/SVGassets/trash.svg b/legoresources/SVGassets/trash.svg new file mode 100644 index 00000000..38d77825 --- /dev/null +++ b/legoresources/SVGassets/trash.svg @@ -0,0 +1,12 @@ + + + + + + + + diff --git a/legoresources/SVGassets/ultra sonic.svg b/legoresources/SVGassets/ultra sonic.svg new file mode 100644 index 00000000..55887dd3 --- /dev/null +++ b/legoresources/SVGassets/ultra sonic.svg @@ -0,0 +1,535 @@ + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/libs/color-sensor/_locales/color-sensor-strings.json b/libs/color-sensor/_locales/color-sensor-strings.json index bfa0eca8..5c52059d 100644 --- a/libs/color-sensor/_locales/color-sensor-strings.json +++ b/libs/color-sensor/_locales/color-sensor-strings.json @@ -13,8 +13,8 @@ "LightCondition.Dark|block": "dark", "LightIntensityMode.Ambient|block": "ambient light", "LightIntensityMode.Reflected|block": "reflected light", - "sensors.ColorSensor.color|block": "`icons.colorSensor` %color| color", - "sensors.ColorSensor.light|block": "`icons.colorSensor` %color|%mode", + "sensors.ColorSensor.color|block": "`icons.colorSensor` %sensor| color", + "sensors.ColorSensor.light|block": "`icons.colorSensor` %sensor|%mode", "sensors.ColorSensor.onColorDetected|block": "on `icons.colorSensor` %sensor|detected color %color", "sensors.ColorSensor.onLightChanged|block": "on `icons.colorSensor` %sensor|%mode|%condition", "sensors.color1|block": "1", diff --git a/libs/color-sensor/color.ts b/libs/color-sensor/color.ts index 708ea066..0638c5c3 100644 --- a/libs/color-sensor/color.ts +++ b/libs/color-sensor/color.ts @@ -100,6 +100,8 @@ namespace sensors { //% block="on `icons.colorSensor` %sensor|detected color %color" //% blockId=colorOnColorDetected //% parts="colorsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=100 blockGap=8 //% group="Color Sensor" @@ -113,12 +115,14 @@ namespace sensors { /** * Get the current color from the color sensor. - * @param color the color sensor to query the request + * @param sensor the color sensor to query the request */ //% help=sensors/color-sensor/color - //% block="`icons.colorSensor` %color| color" + //% block="`icons.colorSensor` %sensor| color" //% blockId=colorGetColor //% parts="colorsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=99 //% group="Color Sensor" @@ -136,6 +140,8 @@ namespace sensors { //% block="on `icons.colorSensor` %sensor|%mode|%condition" //% blockId=colorOnLightChanged //% parts="colorsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=89 blockGap=8 //% group="Color Sensor" @@ -146,12 +152,14 @@ namespace sensors { /** * Measures the ambient or reflected light value from 0 (darkest) to 100 (brightest). - * @param color the color sensor port + * @param sensor the color sensor port */ //% help=sensors/color-sensor/light - //% block="`icons.colorSensor` %color|%mode" + //% block="`icons.colorSensor` %sensor|%mode" //% blockId=colorLight //% parts="colorsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=88 //% group="Color Sensor" @@ -171,15 +179,15 @@ namespace sensors { } } - //% whenUsed block="1" weight=95 fixedInstance + //% whenUsed block="1" weight=95 fixedInstance jres=icons.port1 export const color1: ColorSensor = new ColorSensor(1) - //% whenUsed block="3" weight=90 fixedInstance + //% whenUsed block="3" weight=90 fixedInstance jres=icons.port3 export const color3: ColorSensor = new ColorSensor(3) - //% whenUsed block="2" weight=90 fixedInstance + //% whenUsed block="2" weight=90 fixedInstance jres=icons.port2 export const color2: ColorSensor = new ColorSensor(2) - //% whenUsed block="4" weight=90 fixedInstance + //% whenUsed block="4" weight=90 fixedInstance jres=icons.port4 export const color4: ColorSensor = new ColorSensor(4) } diff --git a/libs/core/_locales/core-jsdoc-strings.json b/libs/core/_locales/core-jsdoc-strings.json index d59f4270..e546c150 100644 --- a/libs/core/_locales/core-jsdoc-strings.json +++ b/libs/core/_locales/core-jsdoc-strings.json @@ -55,12 +55,12 @@ "motors.Motor.move": "Moves the motor by a number of degrees", "motors.Motor.move|param|angle": "the degrees to rotate, eg: 360", "motors.Motor.move|param|power": "the power from ``100`` full forward to ``-100`` full backward, eg: 50", - "motors.Motor.power": "Sets the motor power level from ``-100`` to ``100``.", - "motors.Motor.power|param|power": "the power from ``100`` full forward to ``-100`` full backward, eg: 50", "motors.Motor.reset": "Resets the motor.", "motors.Motor.setBrake": "Sets the automatic brake on or off when the motor is off", "motors.Motor.setBrake|param|brake": "a value indicating if the motor should break when off", "motors.Motor.setReversed": "Reverses the motor polarity", + "motors.Motor.setSpeed": "Sets the motor speed level from ``-100`` to ``100``.", + "motors.Motor.setSpeed|param|speed": "the power from ``100`` full forward to ``-100`` full backward, eg: 50", "motors.Motor.speed": "Gets motor actual speed.", "motors.Motor.stop": "Stops the motor", "motors.Motor.tachoCount": "Gets motor tacho count.", diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index 2f10e924..76ee79a4 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -37,9 +37,9 @@ "control|block": "control", "motors.Motor.count|block": "`icons.motorLarge` %motor|count", "motors.Motor.move|block": "move `icons.motorLarge` %motor|by %angle|degrees at %power|%", - "motors.Motor.power|block": "power `icons.motorLarge` %motor|to %power|%", "motors.Motor.setBrake|block": "set `icons.motorLarge` %motor|brake %brake", "motors.Motor.setReversed|block": "set `icons.motorLarge` %motor|reversed %reversed", + "motors.Motor.setSpeed|block": "set speed `icons.motorLarge` %motor|to %speed|%", "motors.Motor.speed|block": "`icons.motorLarge` %motor|speed", "motors.Motor.stop|block": "stop `icons.motorLarge` %motor", "motors.Motor.tachoCount|block": "`icons.motorLarge` %motor|tacho count", diff --git a/libs/core/icons.jres b/libs/core/icons.jres index be203f27..03a5e0a5 100644 --- a/libs/core/icons.jres +++ b/libs/core/icons.jres @@ -4,30 +4,51 @@ "dataEncoding": "base64" }, "ultrasonicSensor": { - "icon": "" + "icon": "" }, "infraredSensor": { "icon": "" }, "motorMedium": { - "icon": "" + "icon": "" }, "motorLarge": { - "icon": "" + "icon": "" }, "touchSensor": { - "icon": "" + "icon": "" }, "gyroSensor": { - "icon": "" + "icon": "" }, "colorSensor": { - "icon": "" + "icon": "" }, "brickButtons": { - "icon": "" + "icon": "" }, "brickDisplay": { - "icon": "" + "icon": "" + }, + "port1": { + "icon": "" + }, + "port2": { + "icon": "" + }, + "port3": { + "icon": "" + }, + "port4": { + "icon": "" + }, + "portA": { + "icon": "" + }, + "portB": { + "icon": "" + }, + "portC": { + "icon": "" } } \ No newline at end of file diff --git a/libs/core/jres/icons/brickButtons-icon.png b/libs/core/jres/icons/brickButtons-icon.png index cb389b30..bac5b745 100644 Binary files a/libs/core/jres/icons/brickButtons-icon.png and b/libs/core/jres/icons/brickButtons-icon.png differ diff --git a/libs/core/jres/icons/brickDisplay-icon.png b/libs/core/jres/icons/brickDisplay-icon.png index 9e7bded6..9f7dcfa4 100644 Binary files a/libs/core/jres/icons/brickDisplay-icon.png and b/libs/core/jres/icons/brickDisplay-icon.png differ diff --git a/libs/core/jres/icons/colorSensor-icon.png b/libs/core/jres/icons/colorSensor-icon.png index 82c7cf03..ec2316c6 100644 Binary files a/libs/core/jres/icons/colorSensor-icon.png and b/libs/core/jres/icons/colorSensor-icon.png differ diff --git a/libs/core/jres/icons/gyroSensor-icon.png b/libs/core/jres/icons/gyroSensor-icon.png index 0f5cc8a9..c77946d2 100644 Binary files a/libs/core/jres/icons/gyroSensor-icon.png and b/libs/core/jres/icons/gyroSensor-icon.png differ diff --git a/libs/core/jres/icons/motorLarge-icon.png b/libs/core/jres/icons/motorLarge-icon.png index 4ec112b8..32bf7796 100644 Binary files a/libs/core/jres/icons/motorLarge-icon.png and b/libs/core/jres/icons/motorLarge-icon.png differ diff --git a/libs/core/jres/icons/motorMedium-icon.png b/libs/core/jres/icons/motorMedium-icon.png index 5793cfd1..50591820 100644 Binary files a/libs/core/jres/icons/motorMedium-icon.png and b/libs/core/jres/icons/motorMedium-icon.png differ diff --git a/libs/core/jres/icons/port1-icon.png b/libs/core/jres/icons/port1-icon.png new file mode 100644 index 00000000..1699b190 Binary files /dev/null and b/libs/core/jres/icons/port1-icon.png differ diff --git a/libs/core/jres/icons/port2-icon.png b/libs/core/jres/icons/port2-icon.png new file mode 100644 index 00000000..2f882383 Binary files /dev/null and b/libs/core/jres/icons/port2-icon.png differ diff --git a/libs/core/jres/icons/port3-icon.png b/libs/core/jres/icons/port3-icon.png new file mode 100644 index 00000000..7f5a77c0 Binary files /dev/null and b/libs/core/jres/icons/port3-icon.png differ diff --git a/libs/core/jres/icons/port4-icon.png b/libs/core/jres/icons/port4-icon.png new file mode 100644 index 00000000..b3af98bd Binary files /dev/null and b/libs/core/jres/icons/port4-icon.png differ diff --git a/libs/core/jres/icons/portA-icon.png b/libs/core/jres/icons/portA-icon.png new file mode 100644 index 00000000..c9550307 Binary files /dev/null and b/libs/core/jres/icons/portA-icon.png differ diff --git a/libs/core/jres/icons/portB-icon.png b/libs/core/jres/icons/portB-icon.png new file mode 100644 index 00000000..d5112f5d Binary files /dev/null and b/libs/core/jres/icons/portB-icon.png differ diff --git a/libs/core/jres/icons/portC-icon.png b/libs/core/jres/icons/portC-icon.png new file mode 100644 index 00000000..628b2410 Binary files /dev/null and b/libs/core/jres/icons/portC-icon.png differ diff --git a/libs/core/jres/icons/portD-icon.png b/libs/core/jres/icons/portD-icon.png new file mode 100644 index 00000000..3122fd14 Binary files /dev/null and b/libs/core/jres/icons/portD-icon.png differ diff --git a/libs/core/jres/icons/touchSensor-icon.png b/libs/core/jres/icons/touchSensor-icon.png index 8a34d505..f6d22e41 100644 Binary files a/libs/core/jres/icons/touchSensor-icon.png and b/libs/core/jres/icons/touchSensor-icon.png differ diff --git a/libs/core/jres/icons/ultrasonicSensor-icon.png b/libs/core/jres/icons/ultrasonicSensor-icon.png index 82d6c1e0..0429a7d7 100644 Binary files a/libs/core/jres/icons/ultrasonicSensor-icon.png and b/libs/core/jres/icons/ultrasonicSensor-icon.png differ diff --git a/libs/core/output.ts b/libs/core/output.ts index 209e14d4..18fdf21e 100644 --- a/libs/core/output.ts +++ b/libs/core/output.ts @@ -87,21 +87,21 @@ namespace motors { } /** - * Sets the motor power level from ``-100`` to ``100``. + * Sets the motor speed level from ``-100`` to ``100``. * @param motor the output connection that the motor is connected to - * @param power the power from ``100`` full forward to ``-100`` full backward, eg: 50 + * @param speed the power from ``100`` full forward to ``-100`` full backward, eg: 50 */ - //% blockId=motorSetPower block="power `icons.motorLarge` %motor|to %power|%" + //% blockId=motorSetSpeed block="set speed `icons.motorLarge` %motor|to %speed|%" //% weight=99 group="Motors" blockGap=8 //% power.min=-100 power.max=100 - power(power: number) { - power = Math.clamp(-100, 100, power >> 0); + setSpeed(speed: number) { + speed = Math.clamp(-100, 100, speed >> 0); // per LEGO: call it power, use speed const b = mkCmd(this.port, DAL.opOutputSpeed, 1) - b.setNumber(NumberFormat.Int8LE, 2, power) + b.setNumber(NumberFormat.Int8LE, 2, speed) writePWM(b) - if (power) { + if (speed) { const b = mkCmd(this.port, DAL.opOutputStart, 0) writePWM(b); } else { @@ -141,7 +141,7 @@ namespace motors { const b = mkCmd(this.port, DAL.opOutputStop, 1) b.setNumber(NumberFormat.UInt8LE, 2, this.brake ? 1 : 0) writePWM(b); - } + } /** * Sets the automatic brake on or off when the motor is off diff --git a/libs/core/screen.ts b/libs/core/screen.ts index 4b95db85..d0582d92 100644 --- a/libs/core/screen.ts +++ b/libs/core/screen.ts @@ -154,7 +154,7 @@ namespace brick { //% blockId=scren_image_picker block="%image" shim=TD_ID //% image.fieldEditor="imagedropdown" //% image.fieldOptions.columns=6 - //% block.fieldOptions.hasSearchBar=true + //% image.fieldOptions.hasSearchBar=true //% group="Screen" weight=0 blockHidden=1 export function _imagePicker(image: Image): Image { return image; diff --git a/libs/ev3/pxt.json b/libs/ev3/pxt.json index a5c384c2..61752d25 100644 --- a/libs/ev3/pxt.json +++ b/libs/ev3/pxt.json @@ -12,7 +12,6 @@ "color-sensor": "file:../color-sensor", "touch-sensor": "file:../touch-sensor", "ultrasonic-sensor": "file:../ultrasonic-sensor", - "infrared-sensor": "file:../infrared-sensor", "gyro-sensor": "file:../gyro-sensor" }, "public": true diff --git a/libs/gyro-sensor/gyro.ts b/libs/gyro-sensor/gyro.ts index 59ed387f..98fd5159 100644 --- a/libs/gyro-sensor/gyro.ts +++ b/libs/gyro-sensor/gyro.ts @@ -27,6 +27,8 @@ namespace sensors { //% block="`icons.gyroSensor` %sensor|angle" //% blockId=gyroGetAngle //% parts="gyroscope" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=65 blockGap=8 //% group="Gyro Sensor" @@ -43,6 +45,8 @@ namespace sensors { //% block="`icons.gyroSensor` %sensor|rotation rate" //% blockId=gyroGetRate //% parts="gyroscope" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=65 blockGap=8 //% group="Gyro Sensor" @@ -51,16 +55,16 @@ namespace sensors { return this.getNumber(NumberFormat.Int16LE, 0) } } - - //% fixedInstance whenUsed block="1" + + //% fixedInstance whenUsed block="1" jres=icons.port1 export const gyro1: GyroSensor = new GyroSensor(1) - //% fixedInstance whenUsed block="2" weight=95 + //% fixedInstance whenUsed block="2" weight=95 jres=icons.port2 export const gyro2: GyroSensor = new GyroSensor(2) - - //% fixedInstance whenUsed block="3" + + //% fixedInstance whenUsed block="3" jres=icons.port3 export const gyro3: GyroSensor = new GyroSensor(3) - //% fixedInstance whenUsed block="4" + //% fixedInstance whenUsed block="4" jres=icons.port4 export const gyro4: GyroSensor = new GyroSensor(4) } diff --git a/libs/infrared-sensor/_locales/infrared-sensor-strings.json b/libs/infrared-sensor/_locales/infrared-sensor-strings.json index ac335a2d..e194d8dc 100644 --- a/libs/infrared-sensor/_locales/infrared-sensor-strings.json +++ b/libs/infrared-sensor/_locales/infrared-sensor-strings.json @@ -2,8 +2,8 @@ "InfraredSensorEvent.ObjectDetected|block": "object detected", "InfraredSensorEvent.ObjectNear|block": "object near", "sensors.InfraredSensor.onEvent|block": "on `icons.infraredSensor` %sensor|%event", - "sensors.InfraredSensor.proximity|block": "`icons.infraredSensor` %infrared|proximity", - "sensors.InfraredSensor.remoteCommand|block": "`icons.infraredSensor` %infrared|remote command", + "sensors.InfraredSensor.proximity|block": "`icons.infraredSensor` %sensor|proximity", + "sensors.InfraredSensor.remoteCommand|block": "`icons.infraredSensor` %sensor|remote command", "sensors.InfraredSensor.waitUntil|block": "wait until `icons.infraredSensor` %sensor| %event", "sensors.RemoteInfraredBeaconButton.isPressed|block": "`icons.infraredSensor` %button|is pressed", "sensors.RemoteInfraredBeaconButton.onEvent|block": "on `icons.infraredSensor` %button|%event", diff --git a/libs/infrared-sensor/ir.ts b/libs/infrared-sensor/ir.ts index c2788be4..a125e9fc 100644 --- a/libs/infrared-sensor/ir.ts +++ b/libs/infrared-sensor/ir.ts @@ -192,6 +192,8 @@ namespace sensors { //% block="on `icons.infraredSensor` %sensor|%event" //% blockId=infraredOn //% parts="infraredsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=100 blockGap=8 //% group="Infrared Sensor" @@ -206,6 +208,8 @@ namespace sensors { //% block="wait until `icons.infraredSensor` %sensor| %event" //% blockId=infraredwait //% parts="infraredsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=99 blockGap=8 //% group="Infrared Sensor" @@ -215,12 +219,14 @@ namespace sensors { /** * Get the promixity measured by the infrared sensor, from ``0`` (close) to ``100`` (far) - * @param ir the infrared sensor + * @param sensor the infrared sensor */ //% help=input/infrared/proximity - //% block="`icons.infraredSensor` %infrared|proximity" + //% block="`icons.infraredSensor` %sensor|proximity" //% blockId=infraredGetProximity //% parts="infrared" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=65 blockGap=8 //% group="Infrared Sensor" @@ -231,12 +237,14 @@ namespace sensors { /** * Get the remote commandreceived the infrared sensor. - * @param ir the infrared sensor + * @param sensor the infrared sensor */ //% help=input/infrared/remote-command - //% block="`icons.infraredSensor` %infrared|remote command" + //% block="`icons.infraredSensor` %sensor|remote command" //% blockId=infraredGetRemoteCommand //% parts="infrared" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=65 blockGap=8 //% group="Infrared Sensor" @@ -252,16 +260,16 @@ namespace sensors { } } - //% fixedInstance whenUsed block="1" + //% fixedInstance whenUsed block="1" jres=icons.port1 export const infraredSensor1: InfraredSensor = new InfraredSensor(1) - //% fixedInstance whenUsed block="2" + //% fixedInstance whenUsed block="2" jres=icons.port2 export const infraredSensor2: InfraredSensor = new InfraredSensor(2) - //% fixedInstance whenUsed block="3" + //% fixedInstance whenUsed block="3" jres=icons.port3 export const infraredSensor3: InfraredSensor = new InfraredSensor(3) - //% fixedInstance whenUsed block="4" + //% fixedInstance whenUsed block="4" jres=icons.port4 export const infraredSensor4: InfraredSensor = new InfraredSensor(4) diff --git a/libs/music/_locales/music-jsdoc-strings.json b/libs/music/_locales/music-jsdoc-strings.json index 3a616a81..2d67cdcf 100644 --- a/libs/music/_locales/music-jsdoc-strings.json +++ b/libs/music/_locales/music-jsdoc-strings.json @@ -11,10 +11,10 @@ "music.fromWAV": "Makes a sound bound to a buffer in WAV format.", "music.noteFrequency": "Get the frequency of a note.", "music.noteFrequency|param|name": "the note name, eg: Note.C", - "music.playSound": "Start playing a sound and don't wait for it to finish.", - "music.playSoundUntilDone": "Plays a sound", - "music.playSoundUntilDone|param|sound": "the sound to play", - "music.playSound|param|sound": "the sound to play", + "music.playSoundEffect": "Start playing a sound and don't wait for it to finish.", + "music.playSoundEffectUntilDone": "Plays a sound", + "music.playSoundEffectUntilDone|param|sound": "the sound to play", + "music.playSoundEffect|param|sound": "the sound to play", "music.playTone": "Play a tone through the speaker for some amount of time.", "music.playTone|param|frequency": "pitch of the tone to play in Hertz (Hz)", "music.playTone|param|ms": "tone duration in milliseconds (ms)", diff --git a/libs/music/_locales/music-strings.json b/libs/music/_locales/music-strings.json index 52485175..a74eae44 100644 --- a/libs/music/_locales/music-strings.json +++ b/libs/music/_locales/music-strings.json @@ -24,8 +24,8 @@ "music.beat|block": "%fraction|beat", "music.changeTempoBy|block": "change tempo by %value|(bpm)", "music.noteFrequency|block": "%note", - "music.playSoundUntilDone|block": "play sound %sound|until done", - "music.playSound|block": "play sound %sound", + "music.playSoundEffectUntilDone|block": "play sound effect %sound|until done", + "music.playSoundEffect|block": "play sound effect %sound", "music.playTone|block": "play tone|at %note=device_note|for %duration=device_beat", "music.rest|block": "rest|for %duration=device_beat", "music.ringTone|block": "ring tone|at %note=device_note", diff --git a/libs/music/sounds.ts b/libs/music/sounds.ts index fe5e6152..44c7cef0 100644 --- a/libs/music/sounds.ts +++ b/libs/music/sounds.ts @@ -256,13 +256,16 @@ namespace sounds { } namespace music { + let numSoundsPlaying = 0; + let soundsLimit = 3; + /** * Plays a sound * @param sound the sound to play */ - //% blockId=music_play_sound_until_done block="play sound %sound|until done" + //% blockId=music_play_sound_effect_until_done block="play sound effect %sound|until done" //% weight=98 - export function playSoundUntilDone(sound: Sound) { + export function playSoundEffectUntilDone(sound: Sound) { if (!sound) return; sound.play(); } @@ -281,9 +284,11 @@ namespace music { * Start playing a sound and don't wait for it to finish. * @param sound the sound to play */ - //% blockId=music_play_sound block="play sound %sound" + //% blockId=music_play_sound_effect block="play sound effect %sound" //% weight=99 - export function playSound(sound: Sound) { - control.runInBackground(() => sound.play()); + export function playSoundEffect(sound: Sound) { + if (!sound || numSoundsPlaying >= soundsLimit) return; + numSoundsPlaying++; + control.runInBackground(() => {sound.play(); numSoundsPlaying--;}); } } diff --git a/libs/touch-sensor/touch.ts b/libs/touch-sensor/touch.ts index 645d69ba..8484b83e 100644 --- a/libs/touch-sensor/touch.ts +++ b/libs/touch-sensor/touch.ts @@ -44,6 +44,8 @@ namespace sensors { //% help=input/touch-sensor/on-event //% blockId=touchEvent block="on `icons.touchSensor` %sensor|%event" //% parts="touch" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=99 blockGap=8 //% group="Touch Sensor" @@ -59,6 +61,8 @@ namespace sensors { //% help=input/touch-sensor/wait-until //% blockId=touchWaitUntil block="wait until `icons.touchSensor` %sensor|%event" //% parts="touch" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=98 blockGap=8 //% group="Touch Sensor" @@ -74,6 +78,8 @@ namespace sensors { //% block="`icons.touchSensor` %sensor|is pressed" //% blockId=touchIsPressed //% parts="touch" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=81 blockGap=8 //% group="Touch Sensor" @@ -89,6 +95,8 @@ namespace sensors { //% block="`icons.touchSensor` %sensor|was pressed" //% blockId=touchWasPressed //% parts="touch" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=81 blockGap=8 //% group="Touch Sensor" @@ -97,12 +105,12 @@ namespace sensors { } } - //% whenUsed block="1" weight=95 fixedInstance + //% whenUsed block="1" weight=95 fixedInstance jres=icons.port1 export const touchSensor1: TouchSensor = new TouchSensor(1) - //% whenUsed block="2" weight=95 fixedInstance + //% whenUsed block="2" weight=95 fixedInstance jres=icons.port2 export const touchSensor2: TouchSensor = new TouchSensor(2) - //% whenUsed block="3" weight=95 fixedInstance + //% whenUsed block="3" weight=95 fixedInstance jres=icons.port3 export const touchSensor3: TouchSensor = new TouchSensor(3) - //% whenUsed block="4" weight=95 fixedInstance + //% whenUsed block="4" weight=95 fixedInstance jres=icons.port4 export const touchSensor4: TouchSensor = new TouchSensor(4) } diff --git a/libs/ultrasonic-sensor/ultrasonic.ts b/libs/ultrasonic-sensor/ultrasonic.ts index ef6628af..f61f856f 100644 --- a/libs/ultrasonic-sensor/ultrasonic.ts +++ b/libs/ultrasonic-sensor/ultrasonic.ts @@ -45,6 +45,8 @@ namespace sensors { //% blockId=ultrasonicOn //% block="on `icons.ultrasonicSensor` %sensor|%event" //% parts="ultrasonicsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=100 blockGap=8 //% group="Ultrasonic Sensor" @@ -59,6 +61,8 @@ namespace sensors { //% block="wait until `icons.ultrasonicSensor` %sensor| %event" //% blockId=ultrasonicWait //% parts="ultrasonicsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=99 blockGap=8 //% group="Ultrasonic Sensor" @@ -74,6 +78,8 @@ namespace sensors { //% block="`icons.ultrasonicSensor` %sensor|distance" //% blockId=sonarGetDistance //% parts="ultrasonicsensor" + //% sensor.fieldEditor="imagedropdown" + //% sensor.fieldOptions.columns=4 //% blockNamespace=sensors //% weight=65 blockGap=8 //% group="Ultrasonic Sensor" @@ -84,15 +90,15 @@ namespace sensors { } } - //% fixedInstance whenUsed block="1" + //% fixedInstance whenUsed block="1" jres=icons.port1 export const ultrasonic1: UltraSonicSensor = new UltraSonicSensor(1) - //% fixedInstance whenUsed block="4" + //% fixedInstance whenUsed block="4" jres=icons.port4 export const ultrasonic4: UltraSonicSensor = new UltraSonicSensor(4) - //% fixedInstance whenUsed block="2" + //% fixedInstance whenUsed block="2" jres=icons.port2 export const ultrasonic2: UltraSonicSensor = new UltraSonicSensor(2) - //% fixedInstance whenUsed block="3" + //% fixedInstance whenUsed block="3" jres=icons.port3 export const ultrasonic3: UltraSonicSensor = new UltraSonicSensor(3) } diff --git a/package.json b/package.json index b1bf0b04..2d21827e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "pxt-ev3", - "version": "0.0.35", + "version": "0.0.37", "description": "LEGO Mindstorms EV3 for Microsoft MakeCode", "private": true, "keywords": [ @@ -40,7 +40,7 @@ }, "dependencies": { "pxt-common-packages": "0.14.5", - "pxt-core": "2.3.31" + "pxt-core": "2.3.37" }, "scripts": { "test": "node node_modules/pxt-core/built/pxt.js travis" diff --git a/pxtarget.json b/pxtarget.json index 30dddfd8..31111b63 100644 --- a/pxtarget.json +++ b/pxtarget.json @@ -89,6 +89,8 @@ "termsOfUseUrl": "https://go.microsoft.com/fwlink/?LinkID=206977", "githubUrl": "https://github.com/Microsoft/pxt-ev3", "boardName": "LEGO Mindstorms EV3 Brick", + "selectLanguage": true, + "highContrast": true, "docMenu": [ { "name": "About",