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 @@
+
+
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 @@
+
+
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 @@
+
+
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 @@
+
+
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 @@
+
+
+
+
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 @@
+
+
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 @@
+
+
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 @@
+
+
+
+
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 @@
+
+
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",