From dab281a9cbad96f4c86aae095ee4320ecc7bd322 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 12:41:47 -0800 Subject: [PATCH 1/8] including a few icons in block names --- libs/core/_locales/core-strings.json | 40 +++++++++--------- libs/core/icons.jres | 21 +++++++++ libs/core/ir.ts | 10 ++--- libs/core/jres/icons/infraredSensor-icon.png | Bin 0 -> 5043 bytes libs/core/jres/icons/motorLarge-icon.png | Bin 0 -> 5381 bytes libs/core/jres/icons/motorMedium-icon.png | Bin 0 -> 5170 bytes libs/core/jres/icons/touchSensor-icon.png | Bin 0 -> 4904 bytes .../core/jres/icons/ultrasonicSensor-icon.png | Bin 0 -> 5271 bytes libs/core/output.ts | 16 +++---- libs/core/pxt.json | 1 + libs/core/touch.ts | 8 ++-- libs/core/ultrasonic.ts | 12 +++--- 12 files changed, 65 insertions(+), 43 deletions(-) create mode 100644 libs/core/icons.jres create mode 100644 libs/core/jres/icons/infraredSensor-icon.png create mode 100644 libs/core/jres/icons/motorLarge-icon.png create mode 100644 libs/core/jres/icons/motorMedium-icon.png create mode 100644 libs/core/jres/icons/touchSensor-icon.png create mode 100644 libs/core/jres/icons/ultrasonicSensor-icon.png diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index 5292ec55..c4435c68 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -55,14 +55,14 @@ "motors.Motor.speed|block": "%motor|speed", "motors.Motor.stop|block": "stop %motor", "motors.Motor.tachoCount|block": "%motor|tacho count", - "motors.largeMotorA|block": "large motor A", - "motors.largeMotorB|block": "large motor B", - "motors.largeMotorC|block": "large motor C", - "motors.largeMotorD|block": "large motor D", - "motors.mediumMotorA|block": "medium motor A", - "motors.mediumMotorB|block": "medium motor B", - "motors.mediumMotorC|block": "medium motor C", - "motors.mediumMotorD|block": "medium motor D", + "motors.largeMotorA|block": "`icons.motorLarge` A", + "motors.largeMotorB|block": "`icons.motorLarge` B", + "motors.largeMotorC|block": "`icons.motorLarge` C", + "motors.largeMotorD|block": "`icons.motorLarge` D", + "motors.mediumMotorA|block": "`icons.motorMedium` A", + "motors.mediumMotorB|block": "`icons.motorMedium` B", + "motors.mediumMotorC|block": "`icons.motorMedium` C", + "motors.mediumMotorD|block": "`icons.motorMedium` D", "motors.stopAllMotors|block": "stop all motors", "motors|block": "motors", "output|block": "output", @@ -93,23 +93,23 @@ "sensors.gyro2|block": "gyro sensor 2", "sensors.gyro3|block": "gyro sensor 3", "sensors.gyro4|block": "gyro sensor 4", - "sensors.infraredSensor1|block": "infrared sensor 1", - "sensors.infraredSensor2|block": "infrared sensor 2", - "sensors.infraredSensor3|block": "infrared sensor 3", - "sensors.infraredSensor4|block": "infrared sensor 4", + "sensors.infraredSensor1|block": "`icons.infraredSensor` 1", + "sensors.infraredSensor2|block": "`icons.infraredSensor` 2", + "sensors.infraredSensor3|block": "`icons.infraredSensor` 3", + "sensors.infraredSensor4|block": "`icons.infraredSensor` 4", "sensors.remoteButtonBottomLeft|block": "remote button bottom-left", "sensors.remoteButtonBottomRight|block": "remote button bottom-right", "sensors.remoteButtonCenter|block": "remote button center", "sensors.remoteButtonTopLeft|block": "remote button top-left", "sensors.remoteButtonTopRight|block": "remote button top-right", - "sensors.touchSensor1|block": "touch sensor 1", - "sensors.touchSensor2|block": "touch sensor 2", - "sensors.touchSensor3|block": "touch sensor 3", - "sensors.touchSensor4|block": "touch sensor 4", - "sensors.ultrasonic1|block": "ultrasonic sensor 1", - "sensors.ultrasonic2|block": "ultrasonic sensor 2", - "sensors.ultrasonic3|block": "ultrasonic sensor 3", - "sensors.ultrasonic4|block": "ultrasonic sensor 4", + "sensors.touchSensor1|block": "`icons.touchSensor` 1", + "sensors.touchSensor2|block": "`icons.touchSensor` 2", + "sensors.touchSensor3|block": "`icons.touchSensor` 3", + "sensors.touchSensor4|block": "`icons.touchSensor` 4", + "sensors.ultrasonic1|block": "`icons.ultrasonicSensor` 1", + "sensors.ultrasonic2|block": "`icons.ultrasonicSensor` 2", + "sensors.ultrasonic3|block": "`icons.ultrasonicSensor` 3", + "sensors.ultrasonic4|block": "`icons.ultrasonicSensor` 4", "sensors|block": "sensors", "serial|block": "serial", "{id:category}Brick": "Brick", diff --git a/libs/core/icons.jres b/libs/core/icons.jres new file mode 100644 index 00000000..38cf5836 --- /dev/null +++ b/libs/core/icons.jres @@ -0,0 +1,21 @@ +{ + "*": { + "namespace": "icons", + "dataEncoding": "base64" + }, + "ultrasonicSensor": { + "icon": "" + }, + "infraredSensor": { + "icon": "" + }, + "motorMedium": { + "icon": "" + }, + "motorLarge": { + "icon": "" + }, + "touchSensor": { + "icon": "" + } +} \ No newline at end of file diff --git a/libs/core/ir.ts b/libs/core/ir.ts index 1e73dd32..db20425a 100644 --- a/libs/core/ir.ts +++ b/libs/core/ir.ts @@ -214,7 +214,7 @@ namespace sensors { //% parts="infraredsensor" //% blockNamespace=sensors //% weight=99 blockGap=8 - //% group="Ultrasonic Sensor" + //% group="Infrared Sensor" wait(event: InfraredSensorEvent) { // TODO } @@ -258,16 +258,16 @@ namespace sensors { } } - //% fixedInstance whenUsed block="infrared sensor 1" + //% fixedInstance whenUsed block="`icons.infraredSensor` 1" export const infraredSensor1: InfraredSensor = new InfraredSensor(1) - //% fixedInstance whenUsed block="infrared sensor 2" + //% fixedInstance whenUsed block="`icons.infraredSensor` 2" export const infraredSensor2: InfraredSensor = new InfraredSensor(2) - //% fixedInstance whenUsed block="infrared sensor 3" + //% fixedInstance whenUsed block="`icons.infraredSensor` 3" export const infraredSensor3: InfraredSensor = new InfraredSensor(3) - //% fixedInstance whenUsed block="infrared sensor 4" + //% fixedInstance whenUsed block="`icons.infraredSensor` 4" export const infraredSensor4: InfraredSensor = new InfraredSensor(4) diff --git a/libs/core/jres/icons/infraredSensor-icon.png b/libs/core/jres/icons/infraredSensor-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..7f232861e47cfaae2e7b13197ac4e4dcfdcf2378 GIT binary patch literal 5043 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 literal 0 HcmV?d00001 diff --git a/libs/core/jres/icons/touchSensor-icon.png b/libs/core/jres/icons/touchSensor-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..8a34d50540e60f308d511a1807c116e1f833c0e7 GIT binary patch literal 4904 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 literal 0 HcmV?d00001 diff --git a/libs/core/output.ts b/libs/core/output.ts index f3c68e5a..dc912b75 100644 --- a/libs/core/output.ts +++ b/libs/core/output.ts @@ -216,28 +216,28 @@ namespace motors { } } - //% whenUsed fixedInstance block="large motor A" + //% whenUsed fixedInstance block="`icons.motorLarge` A" export const largeMotorA = new Motor(Output.A, true); - //% whenUsed fixedInstance block="large motor B" + //% whenUsed fixedInstance block="`icons.motorLarge` B" export const largeMotorB = new Motor(Output.B, true); - //% whenUsed fixedInstance block="large motor C" + //% whenUsed fixedInstance block="`icons.motorLarge` C" export const largeMotorC = new Motor(Output.C, true); - //% whenUsed fixedInstance block="large motor D" + //% whenUsed fixedInstance block="`icons.motorLarge` D" export const largeMotorD = new Motor(Output.D, true); - //% whenUsed fixedInstance block="medium motor A" + //% whenUsed fixedInstance block="`icons.motorMedium` A" export const mediumMotorA = new Motor(Output.A, false); - //% whenUsed fixedInstance block="medium motor B" + //% whenUsed fixedInstance block="`icons.motorMedium` B" export const mediumMotorB = new Motor(Output.B, false); - //% whenUsed fixedInstance block="medium motor C" + //% whenUsed fixedInstance block="`icons.motorMedium` C" export const mediumMotorC = new Motor(Output.C, false); - //% whenUsed fixedInstance block="medium motor D" + //% whenUsed fixedInstance block="`icons.motorMedium` D" export const mediumMotorD = new Motor(Output.D, false); function reset(out: Output) { diff --git a/libs/core/pxt.json b/libs/core/pxt.json index 24832ada..b21ee1ff 100644 --- a/libs/core/pxt.json +++ b/libs/core/pxt.json @@ -28,6 +28,7 @@ "dal.d.ts", "images.ts", "images.jres", + "icons.jres", "ns.ts" ], "testFiles": [ diff --git a/libs/core/touch.ts b/libs/core/touch.ts index c603fae4..cc9760c4 100644 --- a/libs/core/touch.ts +++ b/libs/core/touch.ts @@ -67,12 +67,12 @@ namespace sensors { } } - //% whenUsed block="touch sensor 1" weight=95 fixedInstance + //% whenUsed block="`icons.touchSensor` 1" weight=95 fixedInstance export const touchSensor1: TouchSensor = new TouchSensor(1) - //% whenUsed block="touch sensor 2" weight=95 fixedInstance + //% whenUsed block="`icons.touchSensor` 2" weight=95 fixedInstance export const touchSensor2: TouchSensor = new TouchSensor(2) - //% whenUsed block="touch sensor 3" weight=95 fixedInstance + //% whenUsed block="`icons.touchSensor` 3" weight=95 fixedInstance export const touchSensor3: TouchSensor = new TouchSensor(3) - //% whenUsed block="touch sensor 4" weight=95 fixedInstance + //% whenUsed block="`icons.touchSensor` 4" weight=95 fixedInstance export const touchSensor4: TouchSensor = new TouchSensor(4) } diff --git a/libs/core/ultrasonic.ts b/libs/core/ultrasonic.ts index fe32a12f..d131e70d 100644 --- a/libs/core/ultrasonic.ts +++ b/libs/core/ultrasonic.ts @@ -85,16 +85,16 @@ namespace sensors { return this.getNumber(NumberFormat.UInt16LE, 0) & 0x0fff; } } - - //% fixedInstance whenUsed block="ultrasonic sensor 4" - export const ultrasonic4: UltraSonicSensor = new UltraSonicSensor(4) - //% fixedInstance whenUsed block="ultrasonic sensor 1" + //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 1" export const ultrasonic1: UltraSonicSensor = new UltraSonicSensor(1) + + //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 4" + export const ultrasonic4: UltraSonicSensor = new UltraSonicSensor(4) - //% fixedInstance whenUsed block="ultrasonic sensor 2" + //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 2" export const ultrasonic2: UltraSonicSensor = new UltraSonicSensor(2) - //% fixedInstance whenUsed block="ultrasonic sensor 3" + //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 3" export const ultrasonic3: UltraSonicSensor = new UltraSonicSensor(3) } From 9437873427f70af21652dc32725239c0a0c82428 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 12:58:37 -0800 Subject: [PATCH 2/8] more images --- libs/core/_locales/core-strings.json | 86 +++++++++++----------- libs/core/color.ts | 20 ++--- libs/core/gyro.ts | 16 ++-- libs/core/icons.jres | 6 ++ libs/core/ir.ts | 16 ++-- libs/core/jres/icons/colorSensor-icon.png | Bin 0 -> 5317 bytes libs/core/jres/icons/gyroSensor-icon.png | Bin 0 -> 4950 bytes libs/core/output.ts | 16 ++-- libs/core/touch.ts | 42 +++++------ libs/core/ultrasonic.ts | 20 ++--- 10 files changed, 114 insertions(+), 108 deletions(-) create mode 100644 libs/core/jres/icons/colorSensor-icon.png create mode 100644 libs/core/jres/icons/gyroSensor-icon.png diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index c4435c68..70acfb9e 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -55,61 +55,61 @@ "motors.Motor.speed|block": "%motor|speed", "motors.Motor.stop|block": "stop %motor", "motors.Motor.tachoCount|block": "%motor|tacho count", - "motors.largeMotorA|block": "`icons.motorLarge` A", - "motors.largeMotorB|block": "`icons.motorLarge` B", - "motors.largeMotorC|block": "`icons.motorLarge` C", - "motors.largeMotorD|block": "`icons.motorLarge` D", - "motors.mediumMotorA|block": "`icons.motorMedium` A", - "motors.mediumMotorB|block": "`icons.motorMedium` B", - "motors.mediumMotorC|block": "`icons.motorMedium` C", - "motors.mediumMotorD|block": "`icons.motorMedium` D", + "motors.largeMotorA|block": "large A", + "motors.largeMotorB|block": "large B", + "motors.largeMotorC|block": "large C", + "motors.largeMotorD|block": "large D", + "motors.mediumMotorA|block": "medium A", + "motors.mediumMotorB|block": "medium B", + "motors.mediumMotorC|block": "medium C", + "motors.mediumMotorD|block": "medium D", "motors.stopAllMotors|block": "stop all motors", "motors|block": "motors", "output|block": "output", "screen|block": "screen", - "sensors.ColorSensor.ambientLight|block": "%color| ambient light", - "sensors.ColorSensor.color|block": "%color| color", - "sensors.ColorSensor.onColorDetected|block": "on %sensor|detected %color", - "sensors.ColorSensor.reflectedLight|block": "%color| reflected light", - "sensors.GyroSensor.angle|block": "%sensor|angle", - "sensors.GyroSensor.rate|block": "%sensor|rotation rate", - "sensors.InfraredSensor.on|block": "on %sensor|%event", - "sensors.InfraredSensor.proximity|block": "%infrared|proximity", - "sensors.InfraredSensor.remoteCommand|block": "%infrared|remote command", - "sensors.InfraredSensor.wait|block": "wait %sensor|for %event", + "sensors.ColorSensor.ambientLight|block": "`icons.colorSensor` %color| ambient light", + "sensors.ColorSensor.color|block": "`icons.colorSensor` %color| color", + "sensors.ColorSensor.onColorDetected|block": "on `icons.colorSensor` %sensor|detected %color", + "sensors.ColorSensor.reflectedLight|block": "`icons.colorSensor` %color| reflected light", + "sensors.GyroSensor.angle|block": "`icons.gyroSensor` %sensor|angle", + "sensors.GyroSensor.rate|block": "`icons.gyroSensor` %sensor|rotation rate", + "sensors.InfraredSensor.on|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.wait|block": "wait `icons.infraredSensor` %sensor|for %event", "sensors.RemoteInfraredBeaconButton.isPressed|block": "%button|is pressed", "sensors.RemoteInfraredBeaconButton.onEvent|block": "on %button|%event", "sensors.RemoteInfraredBeaconButton.wasPressed|block": "%button|was pressed", - "sensors.TouchSensor.isTouched|block": "%sensor|is touched", - "sensors.TouchSensor.onEvent|block": "on %sensor|%event", - "sensors.UltraSonicSensor.distance|block": "%sensor|distance", - "sensors.UltraSonicSensor.on|block": "on %sensor|%event", - "sensors.UltraSonicSensor.wait|block": "wait %sensor|for %event", - "sensors.color1|block": "color sensor 1", - "sensors.color2|block": "color sensor 2", - "sensors.color3|block": "color sensor 3", - "sensors.color4|block": "color sensor 4", - "sensors.gyro1|block": "gyro sensor 1", - "sensors.gyro2|block": "gyro sensor 2", - "sensors.gyro3|block": "gyro sensor 3", - "sensors.gyro4|block": "gyro sensor 4", - "sensors.infraredSensor1|block": "`icons.infraredSensor` 1", - "sensors.infraredSensor2|block": "`icons.infraredSensor` 2", - "sensors.infraredSensor3|block": "`icons.infraredSensor` 3", - "sensors.infraredSensor4|block": "`icons.infraredSensor` 4", + "sensors.TouchSensor.isTouched|block": "`icons.touchSensor` %sensor|is touched", + "sensors.TouchSensor.onEvent|block": "on `icons.touchSensor` %sensor|%event", + "sensors.UltraSonicSensor.distance|block": "`icons.ultrasonicSensor` %sensor|distance", + "sensors.UltraSonicSensor.on|block": "on `icons.ultrasonicSensor` %sensor|%event", + "sensors.UltraSonicSensor.wait|block": "wait `icons.ultrasonicSensor` %sensor|for %event", + "sensors.color1|block": "1", + "sensors.color2|block": "2", + "sensors.color3|block": "3", + "sensors.color4|block": "4", + "sensors.gyro1|block": "1", + "sensors.gyro2|block": "2", + "sensors.gyro3|block": "3", + "sensors.gyro4|block": "4", + "sensors.infraredSensor1|block": "1", + "sensors.infraredSensor2|block": "2", + "sensors.infraredSensor3|block": "3", + "sensors.infraredSensor4|block": "4", "sensors.remoteButtonBottomLeft|block": "remote button bottom-left", "sensors.remoteButtonBottomRight|block": "remote button bottom-right", "sensors.remoteButtonCenter|block": "remote button center", "sensors.remoteButtonTopLeft|block": "remote button top-left", "sensors.remoteButtonTopRight|block": "remote button top-right", - "sensors.touchSensor1|block": "`icons.touchSensor` 1", - "sensors.touchSensor2|block": "`icons.touchSensor` 2", - "sensors.touchSensor3|block": "`icons.touchSensor` 3", - "sensors.touchSensor4|block": "`icons.touchSensor` 4", - "sensors.ultrasonic1|block": "`icons.ultrasonicSensor` 1", - "sensors.ultrasonic2|block": "`icons.ultrasonicSensor` 2", - "sensors.ultrasonic3|block": "`icons.ultrasonicSensor` 3", - "sensors.ultrasonic4|block": "`icons.ultrasonicSensor` 4", + "sensors.touchSensor1|block": "1", + "sensors.touchSensor2|block": "2", + "sensors.touchSensor3|block": "3", + "sensors.touchSensor4|block": "4", + "sensors.ultrasonic1|block": "1", + "sensors.ultrasonic2|block": "2", + "sensors.ultrasonic3|block": "3", + "sensors.ultrasonic4|block": "4", "sensors|block": "sensors", "serial|block": "serial", "{id:category}Brick": "Brick", diff --git a/libs/core/color.ts b/libs/core/color.ts index b334d4a6..77308481 100644 --- a/libs/core/color.ts +++ b/libs/core/color.ts @@ -59,7 +59,7 @@ namespace sensors { * @param handler the code to run when detected */ //% help=input/color/on-color-detected - //% block="on %sensor|detected %color" + //% block="on `icons.colorSensor` %sensor|detected %color" //% blockId=colorOnColorDetected //% parts="colorsensor" //% blockNamespace=sensors @@ -77,7 +77,7 @@ namespace sensors { * @param color the color sensor to query the request */ //% help=input/color/ambient-light - //% block="%color| ambient light" + //% block="`icons.colorSensor` %color| ambient light" //% blockId=colorGetAmbient //% parts="colorsensor" //% blockNamespace=sensors @@ -93,7 +93,7 @@ namespace sensors { * @param color the color sensor to query the request */ //% help=input/color/refelected-light - //% block="%color| reflected light" + //% block="`icons.colorSensor` %color| reflected light" //% blockId=colorGetReflected //% parts="colorsensor" //% blockNamespace=sensors @@ -109,7 +109,7 @@ namespace sensors { * @param color the color sensor to query the request */ //% help=input/color/color - //% block="%color| color" + //% block="`icons.colorSensor` %color| color" //% blockId=colorGetColor //% parts="colorsensor" //% blockNamespace=sensors @@ -121,15 +121,15 @@ namespace sensors { } } - //% whenUsed block="color sensor 3" weight=95 fixedInstance + //% whenUsed block="1" weight=95 fixedInstance + export const color1: ColorSensor = new ColorSensor(1) + + //% whenUsed block="3" weight=90 fixedInstance export const color3: ColorSensor = new ColorSensor(3) - //% whenUsed block="color sensor 1" weight=95 fixedInstance - export const color1: ColorSensor = new ColorSensor(1) - - //% whenUsed block="color sensor 2" weight=95 fixedInstance + //% whenUsed block="2" weight=90 fixedInstance export const color2: ColorSensor = new ColorSensor(2) - //% whenUsed block="color sensor 4" weight=95 fixedInstance + //% whenUsed block="4" weight=90 fixedInstance export const color4: ColorSensor = new ColorSensor(4) } diff --git a/libs/core/gyro.ts b/libs/core/gyro.ts index 74de5b20..2a394cc6 100644 --- a/libs/core/gyro.ts +++ b/libs/core/gyro.ts @@ -24,7 +24,7 @@ namespace sensors { * @param sensor the gyroscope to query the request */ //% help=input/gyro/angle - //% block="%sensor|angle" + //% block="`icons.gyroSensor` %sensor|angle" //% blockId=gyroGetAngle //% parts="gyroscope" //% blockNamespace=sensors @@ -40,7 +40,7 @@ namespace sensors { * @param sensor the gyroscope to query the request */ //% help=input/gyro/rate - //% block="%sensor|rotation rate" + //% block="`icons.gyroSensor` %sensor|rotation rate" //% blockId=gyroGetRate //% parts="gyroscope" //% blockNamespace=sensors @@ -51,16 +51,16 @@ namespace sensors { return this.getNumber(NumberFormat.Int16LE, 0) } } - - //% fixedInstance whenUsed block="gyro sensor 2" - export const gyro2: GyroSensor = new GyroSensor(2) - //% fixedInstance whenUsed block="gyro sensor 1" + //% fixedInstance whenUsed block="1" export const gyro1: GyroSensor = new GyroSensor(1) - //% fixedInstance whenUsed block="gyro sensor 3" + //% fixedInstance whenUsed block="2" weight=95 + export const gyro2: GyroSensor = new GyroSensor(2) + + //% fixedInstance whenUsed block="3" export const gyro3: GyroSensor = new GyroSensor(3) - //% fixedInstance whenUsed block="gyro sensor 4" + //% fixedInstance whenUsed block="4" export const gyro4: GyroSensor = new GyroSensor(4) } diff --git a/libs/core/icons.jres b/libs/core/icons.jres index 38cf5836..2198314e 100644 --- a/libs/core/icons.jres +++ b/libs/core/icons.jres @@ -17,5 +17,11 @@ }, "touchSensor": { "icon": "" + }, + "gyroSensor": { + "icon": "" + }, + "colorSensor": { + "icon": "" } } \ No newline at end of file diff --git a/libs/core/ir.ts b/libs/core/ir.ts index db20425a..ec247342 100644 --- a/libs/core/ir.ts +++ b/libs/core/ir.ts @@ -193,7 +193,7 @@ namespace sensors { * @param handler the code to run when detected */ //% help=input/infrared/on - //% block="on %sensor|%event" + //% block="on `icons.infraredSensor` %sensor|%event" //% blockId=infraredOn //% parts="infraredsensor" //% blockNamespace=sensors @@ -209,7 +209,7 @@ namespace sensors { * Waits for the event to occur */ //% help=input/ultrasonic/wait - //% block="wait %sensor|for %event" + //% block="wait `icons.infraredSensor` %sensor|for %event" //% blockId=infraredwait //% parts="infraredsensor" //% blockNamespace=sensors @@ -224,7 +224,7 @@ namespace sensors { * @param ir the infrared sensor */ //% help=input/infrared/proximity - //% block="%infrared|proximity" + //% block="`icons.infraredSensor` %infrared|proximity" //% blockId=infraredGetProximity //% parts="infrared" //% blockNamespace=sensors @@ -240,7 +240,7 @@ namespace sensors { * @param ir the infrared sensor */ //% help=input/infrared/remote-command - //% block="%infrared|remote command" + //% block="`icons.infraredSensor` %infrared|remote command" //% blockId=infraredGetRemoteCommand //% parts="infrared" //% blockNamespace=sensors @@ -258,16 +258,16 @@ namespace sensors { } } - //% fixedInstance whenUsed block="`icons.infraredSensor` 1" + //% fixedInstance whenUsed block="1" export const infraredSensor1: InfraredSensor = new InfraredSensor(1) - //% fixedInstance whenUsed block="`icons.infraredSensor` 2" + //% fixedInstance whenUsed block="2" export const infraredSensor2: InfraredSensor = new InfraredSensor(2) - //% fixedInstance whenUsed block="`icons.infraredSensor` 3" + //% fixedInstance whenUsed block="3" export const infraredSensor3: InfraredSensor = new InfraredSensor(3) - //% fixedInstance whenUsed block="`icons.infraredSensor` 4" + //% fixedInstance whenUsed block="4" export const infraredSensor4: InfraredSensor = new InfraredSensor(4) diff --git a/libs/core/jres/icons/colorSensor-icon.png b/libs/core/jres/icons/colorSensor-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..82c7cf0323926c929633d64e23ab1c22b4901a5e GIT binary patch literal 5317 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 Uz6_CVxc~qF07*qoM6N<$g8ffHCIA2c literal 0 HcmV?d00001 diff --git a/libs/core/output.ts b/libs/core/output.ts index dc912b75..4a87e043 100644 --- a/libs/core/output.ts +++ b/libs/core/output.ts @@ -216,28 +216,28 @@ namespace motors { } } - //% whenUsed fixedInstance block="`icons.motorLarge` A" + //% whenUsed fixedInstance block="large A" export const largeMotorA = new Motor(Output.A, true); - //% whenUsed fixedInstance block="`icons.motorLarge` B" + //% whenUsed fixedInstance block="large B" export const largeMotorB = new Motor(Output.B, true); - //% whenUsed fixedInstance block="`icons.motorLarge` C" + //% whenUsed fixedInstance block="large C" export const largeMotorC = new Motor(Output.C, true); - //% whenUsed fixedInstance block="`icons.motorLarge` D" + //% whenUsed fixedInstance block="large D" export const largeMotorD = new Motor(Output.D, true); - //% whenUsed fixedInstance block="`icons.motorMedium` A" + //% whenUsed fixedInstance block="medium A" export const mediumMotorA = new Motor(Output.A, false); - //% whenUsed fixedInstance block="`icons.motorMedium` B" + //% whenUsed fixedInstance block="medium B" export const mediumMotorB = new Motor(Output.B, false); - //% whenUsed fixedInstance block="`icons.motorMedium` C" + //% whenUsed fixedInstance block="medium C" export const mediumMotorC = new Motor(Output.C, false); - //% whenUsed fixedInstance block="`icons.motorMedium` D" + //% whenUsed fixedInstance block="medium D" export const mediumMotorD = new Motor(Output.D, false); function reset(out: Output) { diff --git a/libs/core/touch.ts b/libs/core/touch.ts index cc9760c4..119bc80d 100644 --- a/libs/core/touch.ts +++ b/libs/core/touch.ts @@ -35,12 +35,28 @@ namespace sensors { return DAL.DEVICE_TYPE_TOUCH } + /** + * Do something when a touch sensor is touched... + * @param sensor the touch sensor that needs to be clicked or used + * @param event the kind of button gesture that needs to be detected + * @param body code to run when the event is raised + */ + //% help=input/touch/on-event + //% blockId=touchEvent block="on `icons.touchSensor` %sensor|%event" + //% parts="touch" + //% blockNamespace=sensors + //% weight=99 blockGap=8 + //% group="Touch Sensor" + onEvent(ev: TouchSensorEvent, body: () => void) { + this.button.onEvent(ev, body) + } + /** * Check if touch sensor is touched. * @param sensor the port to query the request */ //% help=input/touch/is-touched - //% block="%sensor|is touched" + //% block="`icons.touchSensor` %sensor|is touched" //% blockId=touchIsTouched //% parts="touch" //% blockNamespace=sensors @@ -49,30 +65,14 @@ namespace sensors { isTouched() { return this.button.isPressed(); } - - /** - * Do something when a touch sensor is touched... - * @param sensor the touch sensor that needs to be clicked or used - * @param event the kind of button gesture that needs to be detected - * @param body code to run when the event is raised - */ - //% help=input/touch/on-event - //% blockId=touchEvent block="on %sensor|%event" - //% parts="touch" - //% blockNamespace=sensors - //% weight=99 blockGap=8 - //% group="Touch Sensor" - onEvent(ev: TouchSensorEvent, body: () => void) { - this.button.onEvent(ev, body) - } } - //% whenUsed block="`icons.touchSensor` 1" weight=95 fixedInstance + //% whenUsed block="1" weight=95 fixedInstance export const touchSensor1: TouchSensor = new TouchSensor(1) - //% whenUsed block="`icons.touchSensor` 2" weight=95 fixedInstance + //% whenUsed block="2" weight=95 fixedInstance export const touchSensor2: TouchSensor = new TouchSensor(2) - //% whenUsed block="`icons.touchSensor` 3" weight=95 fixedInstance + //% whenUsed block="3" weight=95 fixedInstance export const touchSensor3: TouchSensor = new TouchSensor(3) - //% whenUsed block="`icons.touchSensor` 4" weight=95 fixedInstance + //% whenUsed block="4" weight=95 fixedInstance export const touchSensor4: TouchSensor = new TouchSensor(4) } diff --git a/libs/core/ultrasonic.ts b/libs/core/ultrasonic.ts index d131e70d..069bb664 100644 --- a/libs/core/ultrasonic.ts +++ b/libs/core/ultrasonic.ts @@ -41,9 +41,9 @@ namespace sensors { * @param handler the code to run when detected */ //% help=input/ultrasonic/on - //% block="on %sensor|%event" //% blockId=ultrasonicOn - //% parts="infraredsensor" + //% block="on `icons.ultrasonicSensor` %sensor|%event" + //% parts="ultrasonicsensor" //% blockNamespace=sensors //% weight=100 blockGap=8 //% group="Ultrasonic Sensor" @@ -58,9 +58,9 @@ namespace sensors { * Waits for the event to occur */ //% help=input/ultrasonic/wait - //% block="wait %sensor|for %event" + //% block="wait `icons.ultrasonicSensor` %sensor|for %event" //% blockId=ultrasonicWait - //% parts="infraredsensor" + //% parts="ultrasonicsensor" //% blockNamespace=sensors //% weight=99 blockGap=8 //% group="Ultrasonic Sensor" @@ -73,9 +73,9 @@ namespace sensors { * @param sensor the ultrasonic sensor port */ //% help=input/ultrasonic/distance - //% block="%sensor|distance" + //% block="`icons.ultrasonicSensor` %sensor|distance" //% blockId=sonarGetDistance - //% parts="ultrasonic" + //% parts="ultrasonicsensor" //% blockNamespace=sensors //% weight=65 blockGap=8 //% group="Ultrasonic Sensor" @@ -86,15 +86,15 @@ namespace sensors { } } - //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 1" + //% fixedInstance whenUsed block="1" export const ultrasonic1: UltraSonicSensor = new UltraSonicSensor(1) - //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 4" + //% fixedInstance whenUsed block="4" export const ultrasonic4: UltraSonicSensor = new UltraSonicSensor(4) - //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 2" + //% fixedInstance whenUsed block="2" export const ultrasonic2: UltraSonicSensor = new UltraSonicSensor(2) - //% fixedInstance whenUsed block="`icons.ultrasonicSensor` 3" + //% fixedInstance whenUsed block="3" export const ultrasonic3: UltraSonicSensor = new UltraSonicSensor(3) } From 41c2899feb8824a2835aca518d339eb9573b09a7 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 13:03:15 -0800 Subject: [PATCH 3/8] more icons --- libs/core/_locales/core-strings.json | 16 ++++++++-------- libs/core/icons.jres | 3 +++ libs/core/ir.ts | 16 ++++++++-------- libs/core/jres/icons/remoteButton-icon.png | Bin 0 -> 5373 bytes 4 files changed, 19 insertions(+), 16 deletions(-) create mode 100644 libs/core/jres/icons/remoteButton-icon.png diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index 70acfb9e..32f947b0 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -77,9 +77,9 @@ "sensors.InfraredSensor.proximity|block": "`icons.infraredSensor` %infrared|proximity", "sensors.InfraredSensor.remoteCommand|block": "`icons.infraredSensor` %infrared|remote command", "sensors.InfraredSensor.wait|block": "wait `icons.infraredSensor` %sensor|for %event", - "sensors.RemoteInfraredBeaconButton.isPressed|block": "%button|is pressed", - "sensors.RemoteInfraredBeaconButton.onEvent|block": "on %button|%event", - "sensors.RemoteInfraredBeaconButton.wasPressed|block": "%button|was pressed", + "sensors.RemoteInfraredBeaconButton.isPressed|block": "`icons.remoteButton` %button|is pressed", + "sensors.RemoteInfraredBeaconButton.onEvent|block": "on `icons.remoteButton` %button|%event", + "sensors.RemoteInfraredBeaconButton.wasPressed|block": "`icons.remoteButton` %button|was pressed", "sensors.TouchSensor.isTouched|block": "`icons.touchSensor` %sensor|is touched", "sensors.TouchSensor.onEvent|block": "on `icons.touchSensor` %sensor|%event", "sensors.UltraSonicSensor.distance|block": "`icons.ultrasonicSensor` %sensor|distance", @@ -97,11 +97,11 @@ "sensors.infraredSensor2|block": "2", "sensors.infraredSensor3|block": "3", "sensors.infraredSensor4|block": "4", - "sensors.remoteButtonBottomLeft|block": "remote button bottom-left", - "sensors.remoteButtonBottomRight|block": "remote button bottom-right", - "sensors.remoteButtonCenter|block": "remote button center", - "sensors.remoteButtonTopLeft|block": "remote button top-left", - "sensors.remoteButtonTopRight|block": "remote button top-right", + "sensors.remoteButtonBottomLeft|block": "bottom-left", + "sensors.remoteButtonBottomRight|block": "bottom-right", + "sensors.remoteButtonCenter|block": "center", + "sensors.remoteButtonTopLeft|block": "top-left", + "sensors.remoteButtonTopRight|block": "top-right", "sensors.touchSensor1|block": "1", "sensors.touchSensor2|block": "2", "sensors.touchSensor3|block": "3", diff --git a/libs/core/icons.jres b/libs/core/icons.jres index 2198314e..67dc3953 100644 --- a/libs/core/icons.jres +++ b/libs/core/icons.jres @@ -23,5 +23,8 @@ }, "colorSensor": { "icon": "" + }, + "remoteButton": { + "icon": "" } } \ No newline at end of file diff --git a/libs/core/ir.ts b/libs/core/ir.ts index ec247342..20e0e178 100644 --- a/libs/core/ir.ts +++ b/libs/core/ir.ts @@ -93,7 +93,7 @@ namespace sensors { * @param button the remote button to query the request */ //% help=input/remote-infrared-beacon/is-pressed - //% block="%button|is pressed" + //% block="`icons.remoteButton` %button|is pressed" //% blockId=remoteButtonIsPressed //% parts="remote" //% blockNamespace=sensors @@ -108,7 +108,7 @@ namespace sensors { * @param button the remote button to query the request */ //% help=input/remote-infrared-beacon/was-pressed - //% block="%button|was pressed" + //% block="`icons.remoteButton` %button|was pressed" //% blockId=remotebuttonWasPressed //% parts="remote" //% blockNamespace=sensors @@ -125,7 +125,7 @@ namespace sensors { * @param body code to run when the event is raised */ //% help=input/remote-infrared-beacon/on-event - //% blockId=remotebuttonEvent block="on %button|%event" + //% blockId=remotebuttonEvent block="on `icons.remoteButton` %button|%event" //% parts="remote" //% blockNamespace=sensors //% weight=99 blockGap=8 @@ -274,30 +274,30 @@ namespace sensors { /** * Remote beacon (center) button. */ - //% whenUsed block="remote button center" weight=95 fixedInstance + //% whenUsed block="center" weight=95 fixedInstance export const remoteButtonCenter = irButton(IrRemoteButton.CenterBeacon) /** * Remote top-left button. */ - //% whenUsed block="remote button top-left" weight=95 fixedInstance + //% whenUsed block="top-left" weight=95 fixedInstance export const remoteButtonTopLeft = irButton(IrRemoteButton.TopLeft) /** * Remote top-right button. */ - //% whenUsed block="remote button top-right" weight=95 fixedInstance + //% whenUsed block="top-right" weight=95 fixedInstance export const remoteButtonTopRight = irButton(IrRemoteButton.TopRight) /** * Remote bottom-left button. */ - //% whenUsed block="remote button bottom-left" weight=95 fixedInstance + //% whenUsed block="bottom-left" weight=95 fixedInstance export const remoteButtonBottomLeft = irButton(IrRemoteButton.BottomLeft) /** * Remote bottom-right button. */ - //% whenUsed block="remote button bottom-right" weight=95 fixedInstance + //% whenUsed block="bottom-right" weight=95 fixedInstance export const remoteButtonBottomRight = irButton(IrRemoteButton.BottomRight) } diff --git a/libs/core/jres/icons/remoteButton-icon.png b/libs/core/jres/icons/remoteButton-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..cb389b30937c69ea3bb7bcf1eafb7e13083eaaa9 GIT binary patch literal 5373 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 bYy3R`BI!`h5n-sZ00000NkvXXu0mjf!0ZC( literal 0 HcmV?d00001 From d100026d5ce695997d45e005d1986a8127ec56ba Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 13:05:50 -0800 Subject: [PATCH 4/8] more icons --- libs/core/_locales/core-strings.json | 18 +++++++++--------- libs/core/output.ts | 18 +++++++++--------- 2 files changed, 18 insertions(+), 18 deletions(-) diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index 32f947b0..7af2c0a5 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -47,14 +47,14 @@ "brick|block": "brick", "control.raiseEvent|block": "raise event|from %src|with value %value", "control|block": "control", - "motors.Motor.count|block": "%motor|count", - "motors.Motor.move|block": "move %motor|by %angle|degrees at %power|%", - "motors.Motor.power|block": "power %motor|to %power|%", - "motors.Motor.setBrake|block": "set %motor|brake %brake", - "motors.Motor.setReversed|block": "set %motor|reversed %reversed", - "motors.Motor.speed|block": "%motor|speed", - "motors.Motor.stop|block": "stop %motor", - "motors.Motor.tachoCount|block": "%motor|tacho count", + "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.speed|block": "`icons.motorLarge` %motor|speed", + "motors.Motor.stop|block": "stop `icons.motorLarge` %motor", + "motors.Motor.tachoCount|block": "`icons.motorLarge` %motor|tacho count", "motors.largeMotorA|block": "large A", "motors.largeMotorB|block": "large B", "motors.largeMotorC|block": "large C", @@ -63,7 +63,7 @@ "motors.mediumMotorB|block": "medium B", "motors.mediumMotorC|block": "medium C", "motors.mediumMotorD|block": "medium D", - "motors.stopAllMotors|block": "stop all motors", + "motors.stopAllMotors|block": "stop all `icons.motorLarge`", "motors|block": "motors", "output|block": "output", "screen|block": "screen", diff --git a/libs/core/output.ts b/libs/core/output.ts index 4a87e043..aec5ed2c 100644 --- a/libs/core/output.ts +++ b/libs/core/output.ts @@ -66,7 +66,7 @@ namespace motors { /** * Stops all motors */ - //% blockId=motorStopAll block="stop all motors" + //% blockId=motorStopAll block="stop all `icons.motorLarge`" //% weight=10 group="Motors" blockGap=8 export function stopAllMotors() { const b = mkCmd(Output.ALL, DAL.opOutputStop, 0) @@ -91,7 +91,7 @@ namespace motors { * @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 */ - //% blockId=motorSetPower block="power %motor|to %power|%" + //% blockId=motorSetPower block="power `icons.motorLarge` %motor|to %power|%" //% weight=99 group="Motors" blockGap=8 //% power.min=-100 power.max=100 power(power: number) { @@ -114,7 +114,7 @@ namespace motors { * @param angle the degrees to rotate, eg: 360 * @param power the power from ``100`` full forward to ``-100`` full backward, eg: 50 */ - //% blockId=motorMove block="move %motor|by %angle|degrees at %power|%" + //% blockId=motorMove block="move `icons.motorLarge` %motor|by %angle|degrees at %power|%" //% weight=98 group="Motors" blockGap=8 //% power.min=-100 power.max=100 move(angle: number, power: number) { @@ -134,7 +134,7 @@ namespace motors { /** * Stops the motor */ - //% blockId=motorStop block="stop %motor" + //% blockId=motorStop block="stop `icons.motorLarge` %motor" //% weight=97 group="Motors" stop() { const b = mkCmd(this.port, DAL.opOutputStop, 1) @@ -146,7 +146,7 @@ namespace motors { * Sets the automatic brake on or off when the motor is off * @param brake a value indicating if the motor should break when off */ - //% blockId=outputMotorSetBrakeMode block="set %motor|brake %brake" + //% blockId=outputMotorSetBrakeMode block="set `icons.motorLarge` %motor|brake %brake" //% brake.fieldEditor=toggleonoff //% weight=60 group="Motors" blockGap=8 setBrake(brake: boolean) { @@ -156,7 +156,7 @@ namespace motors { /** * Reverses the motor polarity */ - //% blockId=motorSetReversed block="set %motor|reversed %reversed" + //% blockId=motorSetReversed block="set `icons.motorLarge` %motor|reversed %reversed" //% reversed.fieldEditor=toggleonoff //% weight=59 group="Motors" setReversed(reversed: boolean) { @@ -169,7 +169,7 @@ namespace motors { * Gets motor actual speed. * @param motor the port which connects to the motor */ - //% blockId=motorSpeed block="%motor|speed" + //% blockId=motorSpeed block="`icons.motorLarge` %motor|speed" //% weight=72 group="Motors" blockGap=8 speed(): number { return getMotorData(this.port).actualSpeed; @@ -179,7 +179,7 @@ namespace motors { * Gets motor step count. * @param motor the port which connects to the motor */ - //% blockId=motorCount block="%motor|count" + //% blockId=motorCount block="`icons.motorLarge` %motor|count" //% weight=71 group="Motors" blockGap=8 count(): number { return getMotorData(this.port).count; @@ -189,7 +189,7 @@ namespace motors { * Gets motor tacho count. * @param motor the port which connects to the motor */ - //% blockId=motorTachoCount block="%motor|tacho count" + //% blockId=motorTachoCount block="`icons.motorLarge` %motor|tacho count" //% weight=70 group="Motors" tachoCount(): number { return getMotorData(this.port).tachoCount; From c936c16c330339bf4662853d709da20128bae527 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 22:03:43 -0800 Subject: [PATCH 5/8] more icons --- libs/core/_locales/core-strings.json | 28 +++++++++--------- libs/core/buttons.ts | 18 +++++------ libs/core/icons.jres | 5 +++- libs/core/ir.ts | 6 ++-- ...eButton-icon.png => brickButtons-icon.png} | Bin libs/core/jres/icons/brickDisplay-icon.png | Bin 0 -> 4239 bytes libs/core/screen.ts | 4 +-- 7 files changed, 32 insertions(+), 29 deletions(-) rename libs/core/jres/icons/{remoteButton-icon.png => brickButtons-icon.png} (100%) create mode 100644 libs/core/jres/icons/brickDisplay-icon.png diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index 7af2c0a5..61921f98 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -32,18 +32,18 @@ "TouchSensorEvent.Released|block": "released", "UltrasonicSensorEvent.ObjectDetected|block": "object detected", "UltrasonicSensorEvent.ObjectNear|block": "object near", - "brick.Button.isPressed|block": "%button|is pressed", - "brick.Button.onEvent|block": "on %button|%event", - "brick.Button.wasPressed|block": "%button|was pressed", - "brick.buttonDown|block": "button down", - "brick.buttonEnter|block": "button enter", - "brick.buttonLeft|block": "button left", - "brick.buttonRight|block": "button right", - "brick.buttonUp|block": "button up", + "brick.Button.isPressed|block": "`icons.brickButtons` %button|is pressed", + "brick.Button.onEvent|block": "on `icons.brickButtons` %button|%event", + "brick.Button.wasPressed|block": "`icons.brickButtons` %button|was pressed", + "brick.buttonDown|block": "down", + "brick.buttonEnter|block": "enter", + "brick.buttonLeft|block": "left", + "brick.buttonRight|block": "right", + "brick.buttonUp|block": "up", "brick.pattern|block": "%pattern", - "brick.print|block": "print %text| at x: %x| y: %y", - "brick.setPixel|block": "set pixel %on| at x: %x| y: %y", - "brick.setStatusLight|block": "set status light %pattern=led_pattern", + "brick.print|block": "`icons.brickDisplay` print %text| at x: %x| y: %y", + "brick.setPixel|block": "`icons.brickDisplay` set pixel %on| at x: %x| y: %y", + "brick.setStatusLight|block": "set `icons.brickButtons` to %pattern=led_pattern", "brick|block": "brick", "control.raiseEvent|block": "raise event|from %src|with value %value", "control|block": "control", @@ -77,9 +77,9 @@ "sensors.InfraredSensor.proximity|block": "`icons.infraredSensor` %infrared|proximity", "sensors.InfraredSensor.remoteCommand|block": "`icons.infraredSensor` %infrared|remote command", "sensors.InfraredSensor.wait|block": "wait `icons.infraredSensor` %sensor|for %event", - "sensors.RemoteInfraredBeaconButton.isPressed|block": "`icons.remoteButton` %button|is pressed", - "sensors.RemoteInfraredBeaconButton.onEvent|block": "on `icons.remoteButton` %button|%event", - "sensors.RemoteInfraredBeaconButton.wasPressed|block": "`icons.remoteButton` %button|was pressed", + "sensors.RemoteInfraredBeaconButton.isPressed|block": "`icons.infraredSensor` %button|is pressed", + "sensors.RemoteInfraredBeaconButton.onEvent|block": "on `icons.infraredSensor` %button|%event", + "sensors.RemoteInfraredBeaconButton.wasPressed|block": "`icons.infraredSensor` %button|was pressed", "sensors.TouchSensor.isTouched|block": "`icons.touchSensor` %sensor|is touched", "sensors.TouchSensor.onEvent|block": "on `icons.touchSensor` %sensor|%event", "sensors.UltraSonicSensor.distance|block": "`icons.ultrasonicSensor` %sensor|distance", diff --git a/libs/core/buttons.ts b/libs/core/buttons.ts index b92c3f39..4b6bd11f 100644 --- a/libs/core/buttons.ts +++ b/libs/core/buttons.ts @@ -84,7 +84,7 @@ namespace brick { * @param button the button to query the request */ //% help=input/button/is-pressed - //% block="%button|is pressed" + //% block="`icons.brickButtons` %button|is pressed" //% blockId=buttonIsPressed //% parts="brick" //% blockNamespace=brick @@ -99,7 +99,7 @@ namespace brick { * @param button the button to query the request */ //% help=input/button/was-pressed - //% block="%button|was pressed" + //% block="`icons.brickButtons` %button|was pressed" //% blockId=buttonWasPressed //% parts="brick" //% blockNamespace=brick @@ -118,7 +118,7 @@ namespace brick { * @param body code to run when the event is raised */ //% help=input/button/on-event - //% blockId=buttonEvent block="on %button|%event" + //% blockId=buttonEvent block="on `icons.brickButtons` %button|%event" //% parts="brick" //% blockNamespace=brick //% weight=99 blockGap=8 @@ -180,31 +180,31 @@ namespace brick { /** * Enter button on the EV3 Brick. */ - //% whenUsed block="button enter" weight=95 fixedInstance + //% whenUsed block="enter" weight=95 fixedInstance export const buttonEnter: Button = new DevButton(DAL.BUTTON_ID_ENTER) /** * Left button on the EV3 Brick. */ - //% whenUsed block="button left" weight=95 fixedInstance + //% whenUsed block="left" weight=95 fixedInstance export const buttonLeft: Button = new DevButton(DAL.BUTTON_ID_LEFT) /** * Right button on the EV3 Brick. */ - //% whenUsed block="button right" weight=94 fixedInstance + //% whenUsed block="right" weight=94 fixedInstance export const buttonRight: Button = new DevButton(DAL.BUTTON_ID_RIGHT) /** * Up button on the EV3 Brick. */ - //% whenUsed block="button up" weight=95 fixedInstance + //% whenUsed block="up" weight=95 fixedInstance export const buttonUp: Button = new DevButton(DAL.BUTTON_ID_UP) /** * Down button on the EV3 Brick. */ - //% whenUsed block="button down" weight=95 fixedInstance + //% whenUsed block="down" weight=95 fixedInstance export const buttonDown: Button = new DevButton(DAL.BUTTON_ID_DOWN) } @@ -233,7 +233,7 @@ namespace brick { * Set lights. * @param pattern the lights pattern to use. */ - //% blockId=setLights block="set status light %pattern=led_pattern" + //% blockId=setLights block="set `icons.brickButtons` to %pattern=led_pattern" //% weight=100 group="Light" export function setStatusLight(pattern: number): void { if (currPattern === pattern) diff --git a/libs/core/icons.jres b/libs/core/icons.jres index 67dc3953..be203f27 100644 --- a/libs/core/icons.jres +++ b/libs/core/icons.jres @@ -24,7 +24,10 @@ "colorSensor": { "icon": "" }, - "remoteButton": { + "brickButtons": { "icon": "" + }, + "brickDisplay": { + "icon": "" } } \ No newline at end of file diff --git a/libs/core/ir.ts b/libs/core/ir.ts index 20e0e178..0129aa0f 100644 --- a/libs/core/ir.ts +++ b/libs/core/ir.ts @@ -93,7 +93,7 @@ namespace sensors { * @param button the remote button to query the request */ //% help=input/remote-infrared-beacon/is-pressed - //% block="`icons.remoteButton` %button|is pressed" + //% block="`icons.infraredSensor` %button|is pressed" //% blockId=remoteButtonIsPressed //% parts="remote" //% blockNamespace=sensors @@ -108,7 +108,7 @@ namespace sensors { * @param button the remote button to query the request */ //% help=input/remote-infrared-beacon/was-pressed - //% block="`icons.remoteButton` %button|was pressed" + //% block="`icons.infraredSensor` %button|was pressed" //% blockId=remotebuttonWasPressed //% parts="remote" //% blockNamespace=sensors @@ -125,7 +125,7 @@ namespace sensors { * @param body code to run when the event is raised */ //% help=input/remote-infrared-beacon/on-event - //% blockId=remotebuttonEvent block="on `icons.remoteButton` %button|%event" + //% blockId=remotebuttonEvent block="on `icons.infraredSensor` %button|%event" //% parts="remote" //% blockNamespace=sensors //% weight=99 blockGap=8 diff --git a/libs/core/jres/icons/remoteButton-icon.png b/libs/core/jres/icons/brickButtons-icon.png similarity index 100% rename from libs/core/jres/icons/remoteButton-icon.png rename to libs/core/jres/icons/brickButtons-icon.png diff --git a/libs/core/jres/icons/brickDisplay-icon.png b/libs/core/jres/icons/brickDisplay-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..9e7bded6234530d26f82f1c549b55c02d173bf44 GIT binary patch literal 4239 zcmV;A5OD8_P)KLZ*U+IBfRsybQWXdwQbLP>6pAqfylh#{fb6;Z(vMMVS~$e@S=j*ftg6;Uhf59&ghTmgWD0l;*T zI709Y^p6lP1rIRMx#05C~cW=H_Aw*bJ-5DT&Z2n+x)QHX^p z00esgV8|mQcmRZ%02D^@S3L16t`O%c004NIvOKvYIYoh62rY33S640`D9%Y2D-rV&neh&#Q1i z007~1e$oCcFS8neI|hJl{-P!B1ZZ9hpmq0)X0i`JwE&>$+E?>%_LC6RbVIkUx0b+_+BaR3cnT7Zv!AJxW zizFb)h!jyGOOZ85F;a?DAXP{m@;!0_IfqH8(HlgRxt7s3}k3K`kFu>>-2Q$QMFfPW!La{h336o>X zu_CMttHv6zR;&ZNiS=X8v3CR#fknUxHUxJ0uoBa_M6WNWeqIg~6QE69c9o#eyhGvpiOA@W-aonk<7r1(?fC{oI5N*U!4 zfg=2N-7=cNnjjOr{yriy6mMFgG#l znCF=fnQv8CDz++o6_Lscl}eQ+l^ZHARH>?_s@|##Rr6KLRFA1%Q+=*RRWnoLsR`7U zt5vFIcfW3@?wFpwUVxrVZ>QdQz32KIeJ}k~{cZZE^+ya? z2D1z#2HOnI7(B%_ac?{wFUQ;QQA1tBKtrWrm0_3Rgps+?Jfqb{jYbcQX~taRB;#$y zZN{S}1|}gUOHJxc?wV3fxuz+mJ4`!F$IZ;mqRrNsHJd##*D~ju=bP7?-?v~|cv>vB zsJ6IeNwVZxrdjT`yl#bBIa#GxRa#xMMy;K#CDyyGyQdMSxlWT#tDe?p!?5wT$+oGt z8L;Kp2HUQ-ZMJ=3XJQv;x5ci*?vuTfeY$;({XGW_huIFR9a(?@3)XSs8O^N5RyOM=TTmp(3=8^+zpz2r)C z^>JO{deZfso3oq3?Wo(Y?l$ge?uXo;%ru`Vo>?<<(8I_>;8Eq#KMS9gFl*neeosSB zfoHYnBQIkwkyowPu(zdms`p{<7e4kra-ZWq<2*OsGTvEV%s0Td$hXT+!*8Bnh2KMe zBmZRodjHV?r+_5^X9J0WL4jKW`}lf%A-|44I@@LTvf1rHjG(ze6+w@Jt%Bvjts!X0 z?2xS?_ve_-kiKB_KiJlZ$9G`c^=E@oNG)mWWaNo-3TIW8)$Hg0Ub-~8?KhvJ>$ z3*&nim@mj(aCxE5!t{lw7O5^0EIO7zOo&c6l<+|iDySBWCGrz@C5{St!X3hAA}`T4 z(TLbXTq+(;@<=L8dXnssyft|w#WSTW<++3>sgS%(4NTpeI-VAqb|7ssJvzNHgOZVu zaYCvgO_R1~>SyL=cFU|~g|hy|Zi}}s9+d~lYqOB71z9Z$wnC=pR9Yz4DhIM>Wmjgu z&56o6maCpC&F##y%G;1PobR9i?GnNg;gYtchD%p19a!eQtZF&3JaKv33gZ<8D~47E ztUS1iwkmDaPpj=$m#%)jCVEY4fnLGNg2A-`YwHVD3gv};>)hAvT~AmqS>Lr``i7kw zJ{5_It`yrBmlc25DBO7E8;5VoznR>Ww5hAaxn$2~(q`%A-YuS64wkBy=9dm`4cXeX z4c}I@?e+FW+b@^RDBHV(wnMq2zdX3SWv9u`%{xC-q*U}&`cyXV(%rRT*Z6MH?i+i& z_B8C(+grT%{XWUQ+f@NoP1R=AW&26{v-dx)iK^-Nmiuj8txj!m?Z*Ss1N{dh4z}01 z)YTo*JycSU)+_5r4#yw9{+;i4Ee$peRgIj+;v;ZGdF1K$3E%e~4LaI(jC-u%2h$&R z9cLXcYC@Xwnns&bn)_Q~Te?roKGD|d-g^8;+aC{{G(1^(O7m37Y1-+6)01cN&y1aw zoqc{T`P^XJqPBbIW6s}d4{z_f5Om?vMgNQEJG?v2T=KYd^0M3I6IZxbny)%vZR&LD zJpPl@Psh8QyPB@KTx+@RdcC!KX7}kEo;S|j^u2lU7XQ}Oo;f|;z4Ll+_r>@1-xl3| zawq-H%e&ckC+@AhPrP6BKT#_XdT7&;F71j}Joy zkC~6lh7E@6o;W@^IpRNZ{ptLtL(gQ-CY~4mqW;US7Zxvm_|@yz&e53Bp_lTPlfP|z zrTyx_>lv@x#=^!PzR7qqF<$gm`|ZJZ+;<)Cqu&ot2z=0000WV@Og>004R=004l4008;_004mL004C`008P>0026e000+nl3&F} z000HLNklz7p+#(aCtg`%^I?O% zY{B9m5K1pJnkwm6{J=Y*Hc%-PyeL?TS#R2s1Z!FlyIZR$*-4Xi=bZQL#eD3}y1VWc z?19-?=FBoGdtb5 zy5XuH??1yCl-Y@zJwQZIq#&h&k`hD;cYnK!n?K$1m}YnEkRFXjXHC-_DwRqmPyk%| zlv0(BE2DdO92i`6XLbM)gShG<1~WPA2mvC3rfFbi=%G-gtF!Yv2ytIG4CA##B9V>7 zqJeA^Ih1lu^Z;XFaS=xjA3?EL3}_&cOknonSIA}u0CrR3G3ByGME?7lriILSJR^xx z8Z$p7auL@Et19;Af&c)kXkm0@3`K%-T=DI?yjIq}g6AA}c~UAT{x*{MLAep9mbk`;$>^>qwv9jFY-K!0|NlM-idX&;EY(1DndN~K`NO;;}hy}g@Z zKYoPb_j7?Z;RA<|9T-479{1Ud$75~)&aY^n5potMB3!<78Tmi+e%;PpJMsGaqp%<3 zgKf$s%w78iw{y4sXQ@;Q2M-+tGdJCnngVga5Kd2>!uaR}EUTiE@XjIh%zhhKZH*m6 z051CPm2%uhCrUY9#V4#404k?u=l?)sc>0|Z2+9&p;AVvZaj%C`b71MzfW z+xD||pvD$xAq@aS5mo$&JC(S~k0>ILQV;;Bjwh}Qq_e9Fxm*s(WD-&;FexZvkWwHf z-!?LU)zww3t*xOal|m#O2E6scja&!;A)I?i*YQ`OfbNYO1HPm#kaF3^8*jad()v1x z2qC>O;z%TdE3+5y!;KsGWa<<)_Vz-S?WP7g+tm$XhP3VHGa>*)qtWNO@^B=ASS*Hk zJPuvgp_G$?WP96U%0^(M>&@ip65l lCZe_$5@r_RaQMN$0|0fz@nxVy%%T7Q002ovPDHLkV1gw$;I9Ax literal 0 HcmV?d00001 diff --git a/libs/core/screen.ts b/libs/core/screen.ts index 70ca003f..d3cfe580 100644 --- a/libs/core/screen.ts +++ b/libs/core/screen.ts @@ -84,7 +84,7 @@ namespace brick { * @param x the starting position's x coordinate, eg: 0 * @param y the starting position's x coordinate, eg: 0 */ - //% blockId=screen_setpixel block="set pixel %on| at x: %x| y: %y" + //% blockId=screen_setpixel block="`icons.brickDisplay` set pixel %on| at x: %x| y: %y" //% weight=98 group="Screen" //% x.min=0 x.max=178 y.min=0 y.max=128 on.fieldEditor=toggleonoff export function setPixel(on: boolean, x: number, y: number) { @@ -100,7 +100,7 @@ namespace brick { * @param x the starting position's x coordinate, eg: 0 * @param y the starting position's x coordinate, eg: 0 */ - //% blockId=screen_print block="print %text| at x: %x| y: %y" + //% blockId=screen_print block="`icons.brickDisplay` print %text| at x: %x| y: %y" //% weight=99 group="Screen" inlineInputMode="inline" blockGap=8 //% x.min=0 x.max=178 y.min=0 y.max=128 export function print(text: string, x: number, y: number, mode = Draw.Normal) { From 90afb60cc4a94e3975fc3dfbfa9f88f2437367d2 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 22:04:29 -0800 Subject: [PATCH 6/8] bump pxt-core to 2.3.26, bump pxt-common-packages to 0.14.2, --- package.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/package.json b/package.json index 61150691..8fc3ea53 100644 --- a/package.json +++ b/package.json @@ -39,8 +39,8 @@ "semantic-ui-less": "^2.2.4" }, "dependencies": { - "pxt-common-packages": "0.12.17", - "pxt-core": "2.3.19" + "pxt-common-packages": "0.14.2", + "pxt-core": "2.3.26" }, "scripts": { "test": "node node_modules/pxt-core/built/pxt.js travis" From b602b52f7d19e6b834044161ff4130a07d3d066b Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 22:25:26 -0800 Subject: [PATCH 7/8] bump pxt-core to 2.3.27, --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 8fc3ea53..6134614b 100644 --- a/package.json +++ b/package.json @@ -40,7 +40,7 @@ }, "dependencies": { "pxt-common-packages": "0.14.2", - "pxt-core": "2.3.26" + "pxt-core": "2.3.27" }, "scripts": { "test": "node node_modules/pxt-core/built/pxt.js travis" From 3a5885b28eb195047c1642566f022d90192e1c20 Mon Sep 17 00:00:00 2001 From: Peli de Halleux Date: Thu, 16 Nov 2017 22:25:36 -0800 Subject: [PATCH 8/8] 0.0.30 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 6134614b..1016cd7f 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "pxt-ev3", - "version": "0.0.29", + "version": "0.0.30", "description": "LEGO Mindstorms EV3 for Microsoft MakeCode", "private": true, "keywords": [