lesson updates

This commit is contained in:
Michael Elliot Braun 2016-03-30 11:15:31 -07:00
commit df8aaaca5a
70 changed files with 221 additions and 196 deletions

View File

@ -52,7 +52,7 @@ The first job of the scheduler is to allow multiple *subprograms* to be queued u
``` ```
export function countButtonPresses() { export function countButtonPresses() {
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
}) })
basic.forever(() => { basic.forever(() => {
@ -65,7 +65,7 @@ export function countButtonPresses() {
The program above contains three statements that execute in order from top to bottom. The first statement The program above contains three statements that execute in order from top to bottom. The first statement
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
}) })
``` ```
@ -132,14 +132,14 @@ As a result, you can easily add a new capability to the micro:bit by just adding
``` ```
export function countButtonPressesWithReset() { export function countButtonPressesWithReset() {
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
}) })
basic.forever(() => { basic.forever(() => {
basic.showNumber(count, 150) basic.showNumber(count, 150)
}) })
count = 0 count = 0
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
count = 0 count = 0
}) })
} }

View File

@ -24,7 +24,7 @@ We create a **variable**, `count` to keep track of the current count. The number
```blocks ```blocks
let count_ = 0 let count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count, 150) basic.showNumber(count, 150)
}) })
@ -40,7 +40,7 @@ We are only pressing on button pressed once. So the number to display on the mic
```blocks ```blocks
count_ = 0 count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })

View File

@ -28,7 +28,7 @@ let count = 0
```blocks ```blocks
let count_ = 0 let count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })
@ -42,7 +42,7 @@ input.onButtonPressed("A", () => {
```blocks ```blocks
count_ = 0 count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })

View File

@ -12,27 +12,28 @@ Answers may vary. Generally, on button pressed run code when an input button is
Write the line of code that creates a condition when the BBC micro:bit button A is pressed. Write the line of code that creates a condition when the BBC micro:bit button A is pressed.
```blocks ```blocks
input.onButtonPressed(Button.A, () => { input.onButtonPressed(Button.A, () => {
}) })
``` ```
## 3. Consider the following directions ## 3. Write the line of code that creates a **local variable** and a **random number**.
Write the line of code that creates a **local variable** and a **random number**.
```blocks ```blocks
let randomNumber = Math.random(10) let randomNumber = Math.random(10)
``` ```
## 4. Consider the following code ## 4.
If the rectangle below represents the BBC micro:bit, shade the areas that will be displayed. Explain why that particular area is shaded.
```blocks ```blocks
randomNumber = Math.random(10) randomNumber = Math.random(10)
``` ```
If the rectangle below represents the BBC micro:bit, shade the areas that will be displayed. Explain why that particular area is shaded.
![](/static/mb/lessons/guess-the-number-0.png) ![](/static/mb/lessons/guess-the-number-0.png)

View File

@ -37,7 +37,7 @@ let num = 0
basic.forever(() => { basic.forever(() => {
basic.showNumber(num, 150) basic.showNumber(num, 150)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
num = num + 1 num = num + 1
}) })
``` ```

View File

@ -101,13 +101,13 @@ for (let i3 = 0; i3 < 5; i3++) {
Local scope allows you to use the same variable name in different parts of a program without concern about interference (as with variables with global scope). Here's the Touch Develop program that implements the "X" program without interference: Local scope allows you to use the same variable name in different parts of a program without concern about interference (as with variables with global scope). Here's the Touch Develop program that implements the "X" program without interference:
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
for (let i4 = 0; i4 < 5; i4++) { for (let i4 = 0; i4 < 5; i4++) {
led.plot(i4, i4) led.plot(i4, i4)
basic.pause(1000) basic.pause(1000)
} }
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
for (let i5 = 0; i5 < 5; i5++) { for (let i5 = 0; i5 < 5; i5++) {
led.plot(4 - i5, i5) led.plot(4 - i5, i5)
basic.pause(1000) basic.pause(1000)

View File

@ -19,7 +19,7 @@ control.inBackground(() => {
basic.pause(100) basic.pause(100)
} }
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
num++; num++;
}) })
``` ```
@ -31,7 +31,7 @@ let num = 0
basic.forever(() => { basic.forever(() => {
basic.showNumber(num, 150) basic.showNumber(num, 150)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
num++; num++;
}) })
``` ```
@ -44,7 +44,7 @@ If you have multiple processes that each show something on the LED screen, you m
basic.forever(() => { basic.forever(() => {
basic.showNumber(6789, 150) basic.showNumber(6789, 150)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showNumber(2, 150) basic.showNumber(2, 150)
}) })
``` ```

View File

@ -15,7 +15,7 @@ The code below shows a simple game where the user gets to press the button ``A``
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -27,7 +27,7 @@ let img = images.createImage(`
. . . . . . . . . .
`) `)
img.showImage(0) img.showImage(0)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
img.clear() img.clear()
img.showImage(0) img.showImage(0)
}) })

View File

@ -13,7 +13,7 @@ The game library supports simple single-player time-based games. The player has
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -15,7 +15,7 @@ The code below shows a simple game where the user gets to press the button ``A``
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -13,7 +13,7 @@ The game library supports simple single-player time-based games. The general goa
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -98,10 +98,10 @@ This program will record the current acceleration measured on `x` when you press
``` ```
let accelerations = (<number[]>[]) let accelerations = (<number[]>[])
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
accelerations.push(input.acceleration("x")) accelerations.push(input.acceleration("x"))
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
for (let i1 = 0; i1 < accelerations.length; i1++) { for (let i1 = 0; i1 < accelerations.length; i1++) {
basic.showString(accelerations[i1].toString(), 150) basic.showString(accelerations[i1].toString(), 150)
} }

View File

@ -9,7 +9,7 @@ An event handler is code that is associated with a particular event, such as "bu
Functions named "on <event>" create an association between an event and the event handler code. For example, the following code registers the event handler (the code between the `do` and `end` keywords) with the event of a press of button A: Functions named "on <event>" create an association between an event and the event handler code. For example, the following code registers the event handler (the code between the `do` and `end` keywords) with the event of a press of button A:
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("hello", 150) basic.showString("hello", 150)
}) })
``` ```
@ -21,7 +21,7 @@ After this code executes, then whenever button A is pressed in the future, the s
Once you have registered an event handler for an event, like above, that event handler is active for the rest of the program execution. If you want to stop the string "hello" from printing each time button A is pressed then you need to arrange for the following code to execute: Once you have registered an event handler for an event, like above, that event handler is active for the rest of the program execution. If you want to stop the string "hello" from printing each time button A is pressed then you need to arrange for the following code to execute:
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) })
``` ```
@ -32,10 +32,10 @@ The above code associated an event handler that does nothing with the event of a
The above example also illustrates that there is only one event handler for each event. What is the result of the following code? The above example also illustrates that there is only one event handler for each event. What is the result of the following code?
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("hello", 150) basic.showString("hello", 150)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("goodbye", 150) basic.showString("goodbye", 150)
}) })
``` ```
@ -43,7 +43,7 @@ input.onButtonPressed("A", () => {
The answer is that whenever button A is pressed, the string "goodbye" will be printed. If you want both the strings "hello" and "goodbye" to be printed, you need to write the code like this: The answer is that whenever button A is pressed, the string "goodbye" will be printed. If you want both the strings "hello" and "goodbye" to be printed, you need to write the code like this:
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("hello", 150) basic.showString("hello", 150)
basic.showString("goodbye", 150) basic.showString("goodbye", 150)
}) })

View File

@ -9,7 +9,7 @@ The game library supports simple single-player time-based games. The player has
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -15,7 +15,7 @@ The code below shows a simple game where the user gets to press the button ``A``
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -15,7 +15,7 @@ The code below shows a simple game where the user gets to press the button ``A``
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -15,7 +15,7 @@ The code below shows a simple game where the user gets to press the button ``A``
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -13,7 +13,7 @@ The game library supports simple single-player time-based games. The general goa
The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds. The code below shows a simple game where the user gets to press the button ``A`` as much times as possible in 10 seconds.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
}) })
game.startCountdown(10000) game.startCountdown(10000)

View File

@ -32,7 +32,7 @@ claimBall = true
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
if (claimBall) { if (claimBall) {
pins.digitalWritePin("P0", 1) pins.digitalWritePin("P0", 1)
} }

View File

@ -9,7 +9,7 @@ Welcome! This [guided tutorial](https://live.microbit.co.uk/td/lessons/speed-but
``` ```
counter = 0 counter = 0
fastPress = false fastPress = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
}) })
``` ```
@ -21,7 +21,7 @@ We need to know when the user has hit button `A` 15 times. The user wins when he
``` ```
counter = 0 counter = 0
fastPress = false fastPress = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 15 && input.runningTime() < 3500) { if (counter == 15 && input.runningTime() < 3500) {
} }
@ -33,7 +33,7 @@ Next, if the user has won, let's set our boolean to true. This indicates that he
``` ```
counter = 0 counter = 0
fastPress = false fastPress = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 15 && input.runningTime() < 3500) { if (counter == 15 && input.runningTime() < 3500) {
fastPress = true // *** fastPress = true // ***
@ -48,7 +48,7 @@ We want to set `fastPress` to false if the user was too slow. To do so, we need
``` ```
counter = 0 counter = 0
fastPress = false fastPress = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 15 && input.runningTime() < 3500) { if (counter == 15 && input.runningTime() < 3500) {
fastPress = true fastPress = true
@ -66,7 +66,7 @@ Now let's display if the user won or lost. To do so, we need to check the status
``` ```
counter = 0 counter = 0
fastPress = false fastPress = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 15 && input.runningTime() < 3500) { if (counter == 15 && input.runningTime() < 3500) {
fastPress = true fastPress = true

View File

@ -12,7 +12,7 @@ At the end of the tutorial, click `keep editing`. Your code should look like thi
``` ```
newAction() // *** newAction() // ***
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
if (action == 0) { if (action == 0) {
game.addScore(1) // *** game.addScore(1) // ***
newAction() // *** newAction() // ***
@ -30,7 +30,7 @@ input.onGesture(Gesture.Shake, () => {
newAction() // *** newAction() // ***
} }
}) // *** }) // ***
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showNumber(game.score(), 150) // *** basic.showNumber(game.score(), 150) // ***
basic.pause(2000) // *** basic.pause(2000) // ***
newAction() // *** newAction() // ***
@ -68,12 +68,12 @@ Now let's implement `PRESS PIN 0` in the main. Create a condition of `input->on
``` ```
// **. . .** // **. . .**
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showNumber(game.score(), 150) // *** basic.showNumber(game.score(), 150) // ***
basic.pause(2000) // *** basic.pause(2000) // ***
newAction() // *** newAction() // ***
}) // *** }) // ***
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
if (action == 3) { if (action == 3) {
game.addScore(1) // *** game.addScore(1) // ***
newAction() // *** newAction() // ***

View File

@ -33,7 +33,7 @@ if (action == 0) {
<br /> <br />
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
if (action == 0) { if (action == 0) {
game.addScore(1) game.addScore(1)
} }

View File

@ -9,7 +9,7 @@ Welcome! This [guided tutorial](/microbit/lessons/break/tutorial) will assist yo
``` ```
count = 0 count = 0
shouldBreak = false shouldBreak = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
shouldBreak = true shouldBreak = true
}) })
while (true) { while (true) {
@ -49,7 +49,7 @@ while (true) {
basic.showNumber(count, 150) basic.showNumber(count, 150)
basic.pause(1000) basic.pause(1000)
} }
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) // *** }) // ***
``` ```
@ -57,7 +57,7 @@ Next, set `shouldBreak` back to false to indicate we want to run the `while` loo
``` ```
// **. . .** // **. . .**
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
shouldBreak = false // *** shouldBreak = false // ***
}) })
``` ```
@ -66,7 +66,7 @@ And now copy the code from the previous while loop into the condition of `input-
``` ```
// **. . .** // **. . .**
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
shouldBreak = false shouldBreak = false
while (true) { while (true) {
if (shouldBreak) { if (shouldBreak) {

View File

@ -9,14 +9,14 @@ Howdy! This [guided tutorial](/microbit/rxqgzy) will help you complete this acti
In this guide, you will learn how to use buttons and show text on the screen. Let's start by adding to respond **when the left button is pressed**. In this guide, you will learn how to use buttons and show text on the screen. Let's start by adding to respond **when the left button is pressed**.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) })
``` ```
All the code inside `input->on button pressed` runs when the button is pressed. Let's add the code to show some text. All the code inside `input->on button pressed` runs when the button is pressed. Let's add the code to show some text.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("hello", 150) basic.showString("hello", 150)
}) })
``` ```
@ -26,10 +26,10 @@ input.onButtonPressed("A", () => {
Let's add an event handler for Button `B`. Let's add an event handler for Button `B`.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("hello", 150) basic.showString("hello", 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) })
``` ```
@ -38,10 +38,10 @@ input.onButtonPressed("B", () => {
Display `bye` when the `B` button is pressed. Display `bye` when the `B` button is pressed.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("hello", 150) basic.showString("hello", 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showString("bye", 150) basic.showString("bye", 150)
}) })
``` ```

View File

@ -18,7 +18,7 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() basic.clearScreen()
}) })
``` ```
@ -37,10 +37,10 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() basic.clearScreen()
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) })
``` ```
@ -56,10 +56,10 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() basic.clearScreen()
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showAnimation(` basic.showAnimation(`
# # # # # # # # # # . . . . . . . . . . # # # # # # # # # # . . . . . . . . . .
# # # # # # # # # # . . . . . . . . . . # # # # # # # # # # . . . . . . . . . .

View File

@ -8,7 +8,7 @@ Welcome! This [guided tutorial](/microbit/lessons/comparison/tutorial) will assi
``` ```
counter = 0 counter = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 10) { if (counter == 10) {
counter = 1 counter = 1
@ -23,7 +23,7 @@ Now let's do something special when the micro:bit reaches the number `5`. Instea
``` ```
counter = 0 counter = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 10) { if (counter == 10) {
counter = 1 counter = 1
@ -40,7 +40,7 @@ Let's continue our plan of displaying `HALF WAY!` when `counter = 5`. To do so,
``` ```
counter = 0 counter = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 10) { if (counter == 10) {
counter = 1 counter = 1
@ -60,7 +60,7 @@ You may notice a problem right now. When `counter = 5`, the micro:bit will show
``` ```
counter = 0 counter = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
if (counter == 10) { if (counter == 10) {
counter = 1 counter = 1

View File

@ -22,7 +22,7 @@ The code under ``on button pressed("A")`` will run each time the user presses A.
``` ```
let count_ = 0 let count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
}) })
``` ```
@ -31,7 +31,7 @@ Since the count has changed, it's time to refresh the screen display. Let's add
``` ```
let count_1 = 0 let count_1 = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
basic.showNumber(count, 150) basic.showNumber(count, 150)
}) })

View File

@ -8,7 +8,7 @@ Complete the following [guided tutorial](/microbit/lessons/counter/activity) At
``` ```
let count = 0 let count = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
basic.showNumber(count, 150) basic.showNumber(count, 150)
}) })
@ -22,11 +22,11 @@ Let's add the code to `count` when `B` is pressed. Add an event handler with `in
``` ```
let count1 = 0 let count1 = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count1 = count1 + 1 count1 = count1 + 1
basic.showNumber(count1, 150) basic.showNumber(count1, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
count1 = count1 - 1 // *** count1 = count1 - 1 // ***
basic.showNumber(count1, 150) // *** basic.showNumber(count1, 150) // ***
}) // *** }) // ***

View File

@ -15,14 +15,14 @@ To create a new script, go to the [Create Code](/microbit/create-code) page and
Add an event handler when button `A` is pressed. Add an event handler when button `A` is pressed.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) })
``` ```
Create a local variable of type number `x` and set it to a random number using `math->random`. `math->random(10)` generates a random number between `0` and `10` **excluded**. Create a local variable of type number `x` and set it to a random number using `math->random`. `math->random(10)` generates a random number between `0` and `10` **excluded**.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let x = Math.random(10) let x = Math.random(10)
}) })
``` ```
@ -30,7 +30,7 @@ input.onButtonPressed("A", () => {
Show the random number on the screen. Show the random number on the screen.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let x1 = Math.random(10) let x1 = Math.random(10)
basic.showNumber(x1, 150) basic.showNumber(x1, 150)
}) })

View File

@ -11,7 +11,7 @@ Complete the following guided tutorial:
At the end of the tutorial, click `keep editing`. Your code should look like this: At the end of the tutorial, click `keep editing`. Your code should look like this:
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let x = Math.random(10) let x = Math.random(10)
basic.showNumber(x, 150) basic.showNumber(x, 150)
}) })
@ -24,11 +24,11 @@ input.onButtonPressed("A", () => {
When button `B` is pressed, we want to clear the screen. This will make it so users can play your game over and over again! Add an event handler to handle this case. When button `B` is pressed, we want to clear the screen. This will make it so users can play your game over and over again! Add an event handler to handle this case.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let x1 = Math.random(10) let x1 = Math.random(10)
basic.showNumber(x1, 150) basic.showNumber(x1, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.clearScreen() // *** basic.clearScreen() // ***
}) })
``` ```

View File

@ -13,7 +13,7 @@ At the end of the tutorial, click `keep editing`. Your code should look like thi
``` ```
count = 0 count = 0
shouldBreak = false shouldBreak = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
shouldBreak = true shouldBreak = true
}) })
while (true) { while (true) {
@ -60,7 +60,7 @@ while (true) {
basic.showNumber(count, 150) basic.showNumber(count, 150)
basic.pause(1000) basic.pause(1000)
} }
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) // *** }) // ***
``` ```
@ -68,7 +68,7 @@ Next, set `should break` back to false to indicate we want to run the `while` lo
``` ```
// **. . .** // **. . .**
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
shouldBreak = false // *** shouldBreak = false // ***
}) })
``` ```
@ -77,7 +77,7 @@ And now copy the code from the previous while loop into the condition of `input-
``` ```
// **. . .** // **. . .**
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
shouldBreak = false shouldBreak = false
while (true) { while (true) {
if (shouldBreak) { if (shouldBreak) {

View File

@ -22,7 +22,7 @@ shouldBreak = false
Write the line of code to stop incrementing `count` when the button is pressed. (Hint: This will set `should break` to true). Write the line of code to stop incrementing `count` when the button is pressed. (Hint: This will set `should break` to true).
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
shouldBreak = true shouldBreak = true
}) })
``` ```

View File

@ -128,7 +128,7 @@ for (let j = 0; j < 10; j++) {
<br/> <br/>
``` ```
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showString("WINS", 150) basic.showString("WINS", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
basic.pause(500) basic.pause(500)

View File

@ -15,14 +15,14 @@ To create a new script, go to the [Create Code](/microbit/create-code) page and
Begin by registering an event with `input->on pin pressed(PO)` to know when someone is holding pin ``P0`` and pin ``Gnd``. Begin by registering an event with `input->on pin pressed(PO)` to know when someone is holding pin ``P0`` and pin ``Gnd``.
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
}) })
``` ```
We are going to create a meter that displays a random number from 0 to 10. We use ``11`` as `math->random(n)` returns a number between ``0`` and ``n-1``. We are going to create a meter that displays a random number from 0 to 10. We use ``11`` as `math->random(n)` returns a number between ``0`` and ``n-1``.
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
let x = Math.random(11) let x = Math.random(11)
}) })
``` ```
@ -30,7 +30,7 @@ input.onPinPressed("P0", () => {
Finally, let's show that number on the micro:bit. Finally, let's show that number on the micro:bit.
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
let x_ = Math.random(11) let x_ = Math.random(11)
basic.showNumber(x_, 150) basic.showNumber(x_, 150)
}) })

View File

@ -11,7 +11,7 @@ Complete the following guided tutorial:
At the end of the tutorial, click `keep editing`. Your code should look like this: At the end of the tutorial, click `keep editing`. Your code should look like this:
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
let x = Math.random(11) let x = Math.random(11)
basic.showNumber(x, 150) basic.showNumber(x, 150)
}) })
@ -22,7 +22,7 @@ input.onPinPressed("P0", () => {
Add a pause of 3000 milliseconds (3 seconds) after showing the number so that the number won't immediately disappear in the next challenge. Add a pause of 3000 milliseconds (3 seconds) after showing the number so that the number won't immediately disappear in the next challenge.
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
let x1 = Math.random(11) let x1 = Math.random(11)
basic.showNumber(x1, 150) basic.showNumber(x1, 150)
basic.pause(3000) // *** basic.pause(3000) // ***
@ -34,7 +34,7 @@ input.onPinPressed("P0", () => {
If the rating **x** is between ``0`` and ``3`` (strictly less than ``4``), display the text "HORRIBLE!". If the rating **x** is between ``0`` and ``3`` (strictly less than ``4``), display the text "HORRIBLE!".
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
let x2 = Math.random(11) let x2 = Math.random(11)
basic.showNumber(x2, 150) basic.showNumber(x2, 150)
basic.pause(3000) basic.pause(3000)
@ -51,7 +51,7 @@ input.onPinPressed("P0", () => {
If the rating is between 4 and 7, display the text "MEDIOCRE!" **else** display the text "MATCHED!" If the rating is between 4 and 7, display the text "MEDIOCRE!" **else** display the text "MATCHED!"
``` ```
input.onPinPressed("P0", () => { input.onPinPressed(TouchPin.P0, () => {
let x3 = Math.random(11) let x3 = Math.random(11)
basic.showNumber(x3, 150) basic.showNumber(x3, 150)
basic.pause(3000) basic.pause(3000)

View File

@ -13,7 +13,7 @@ It's a method that runs code when the user holds the GND pin with a finger of on
## 2. Create a condition for on pin pressed ("P1"). ## 2. Create a condition for on pin pressed ("P1").
``` ```
input.onPinPressed("P1", () => { input.onPinPressed(TouchPin.P1, () => {
}) })
``` ```

View File

@ -32,7 +32,7 @@ Add a new event handler for `input->on button pressed(A)` and add the code to se
``` ```
led.setBrightness(255) led.setBrightness(255)
led.plotAll() led.plotAll()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.setBrightness(64) // *** led.setBrightness(64) // ***
}) // *** }) // ***
``` ```

View File

@ -13,7 +13,7 @@ At the end of the tutorial, click `keep editing`. Your code should look like thi
``` ```
led.setBrightness(255) led.setBrightness(255)
led.plotAll() led.plotAll()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.setBrightness(64) led.setBrightness(64)
}) })
``` ```
@ -27,10 +27,10 @@ What if we want to turn off all the LEDs? Let's do this by setting the brightnes
``` ```
led.setBrightness(255) led.setBrightness(255)
led.plotAll() led.plotAll()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.setBrightness(64) led.setBrightness(64)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
led.setBrightness(0) // *** led.setBrightness(0) // ***
}) // *** }) // ***
``` ```

View File

@ -126,7 +126,7 @@ for (let i4 = 0; i4 < 4; i4++) {
<br /> <br />
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
if (gameMode == 0 && playerNumber == 0) { if (gameMode == 0 && playerNumber == 0) {
micro_bitTransfer.transferByte(255) micro_bitTransfer.transferByte(255)
} }
@ -148,7 +148,7 @@ for (let k1 = 0; k1 < 3; k1++) {
<br /> <br />
``` ```
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
if (gameMode == 2) { if (gameMode == 2) {
gameMode = 1 gameMode = 1
basic.plotImage(` basic.plotImage(`

View File

@ -24,7 +24,7 @@ basic.forever(() => {
. . # . . . . # . .
`).showImage(offset) `).showImage(offset)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
offset = offset + 1 offset = offset + 1
}) })
``` ```
@ -47,10 +47,10 @@ basic.forever(() => {
. . # . . . . # . .
`).showImage(offset) `).showImage(offset)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
offset = offset + 1 offset = offset + 1
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
offset = offset - 1 // *** offset = offset - 1 // ***
}) // *** }) // ***
``` ```
@ -82,10 +82,10 @@ basic.forever(() => {
. . # . . . . # . .
`).showImage(offset) `).showImage(offset)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
offset = offset + 1 offset = offset + 1
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
offset = offset - 1 offset = offset - 1
}) })
``` ```

View File

@ -41,7 +41,7 @@ Write the two lines of code that cause the `variable` offset to increase by one
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
offset = offset + 1 offset = offset + 1
}) })
``` ```

View File

@ -26,10 +26,10 @@ ball.setDirection(-45)
The user will control the paddle by pressing ``A`` to go up and ``B`` to go down. Let's add ``on button pressed`` event handlers to do that. The user will control the paddle by pressing ``A`` to go up and ``B`` to go down. Let's add ``on button pressed`` event handlers to do that.
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
paddle.changeYBy(-1) paddle.changeYBy(-1)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
paddle.changeYBy(1) paddle.changeYBy(1)
}) })
``` ```

View File

@ -42,7 +42,7 @@ led.plot(ballX, ballY)
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
if (paddleNotUp()) { if (paddleNotUp()) {
led.unplot(0, paddleY) led.unplot(0, paddleY)
paddleY = paddleY - 1 paddleY = paddleY - 1
@ -56,7 +56,7 @@ input.onButtonPressed("A", () => {
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
if (paddleNotDown()) { if (paddleNotDown()) {
led.unplot(0, paddleY) led.unplot(0, paddleY)
paddleY = paddleY + 1 paddleY = paddleY + 1

View File

@ -8,7 +8,7 @@ Welcome! This [guided tutorial](/microbit/lessons/return/tutorial) will help you
``` ```
let original1 = 5 let original1 = 5
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let doubled = doubleIt_(5) let doubled = doubleIt_(5)
basic.showNumber(doubled, 150) // *** basic.showNumber(doubled, 150) // ***
}) })
@ -32,11 +32,11 @@ Add a condition to know when button `B` is pressed. We will use this condition i
``` ```
let original = 5 let original = 5
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let one = doubleIt_(original) let one = doubleIt_(original)
basic.showNumber(one, 150) basic.showNumber(one, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) })
``` ```

View File

@ -50,7 +50,7 @@ input.onGesture(Gesture.Shake, () => {
let offset1 = 5 * Math.random(3) let offset1 = 5 * Math.random(3)
img1.showImage(offset1) img1.showImage(offset1)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) // *** }) // ***
``` ```
@ -71,7 +71,7 @@ input.onGesture(Gesture.Shake, () => {
let offset2 = 5 * Math.random(3) let offset2 = 5 * Math.random(3)
img2.showImage(offset2) img2.showImage(offset2)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 // *** wins = wins + 1 // ***
}) })
``` ```
@ -93,7 +93,7 @@ input.onGesture(Gesture.Shake, () => {
let offset3 = 5 * Math.random(3) let offset3 = 5 * Math.random(3)
img3.showImage(offset3) img3.showImage(offset3)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) // *** basic.showString("WINS:", 150) // ***
basic.showNumber(wins, 150) // *** basic.showNumber(wins, 150) // ***
@ -129,12 +129,12 @@ input.onGesture(Gesture.Shake, () => {
let offset4 = 5 * Math.random(3) let offset4 = 5 * Math.random(3)
img4.showImage(offset4) img4.showImage(offset4)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) // *** }) // ***
``` ```
@ -155,12 +155,12 @@ input.onGesture(Gesture.Shake, () => {
let offset5 = 5 * Math.random(3) let offset5 = 5 * Math.random(3)
img5.showImage(offset5) img5.showImage(offset5)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
losses = losses + 1 // *** losses = losses + 1 // ***
}) })
``` ```
@ -182,12 +182,12 @@ input.onGesture(Gesture.Shake, () => {
let offset6 = 5 * Math.random(3) let offset6 = 5 * Math.random(3)
img6.showImage(offset6) img6.showImage(offset6)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
losses = losses + 1 losses = losses + 1
basic.showString("WINS", 150) // *** basic.showString("WINS", 150) // ***
basic.showNumber(wins, 150) // *** basic.showNumber(wins, 150) // ***
@ -213,14 +213,14 @@ input.onGesture(Gesture.Shake, () => {
let offset7 = 5 * Math.random(3) let offset7 = 5 * Math.random(3)
img7.showImage(offset7) img7.showImage(offset7)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
basic.showString("LOSSES:", 150) // *** basic.showString("LOSSES:", 150) // ***
basic.showNumber(losses, 150) // *** basic.showNumber(losses, 150) // ***
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
losses = losses + 1 losses = losses + 1
basic.showString("WINS", 150) basic.showString("WINS", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)

View File

@ -50,7 +50,7 @@ input.onGesture(Gesture.Shake, () => {
let offset1 = 5 * Math.random(3) let offset1 = 5 * Math.random(3)
img1.showImage(offset1) img1.showImage(offset1)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) // *** }) // ***
``` ```
@ -71,7 +71,7 @@ input.onGesture(Gesture.Shake, () => {
let offset2 = 5 * Math.random(3) let offset2 = 5 * Math.random(3)
img2.showImage(offset2) img2.showImage(offset2)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 // *** wins = wins + 1 // ***
}) })
``` ```
@ -93,7 +93,7 @@ input.onGesture(Gesture.Shake, () => {
let offset3 = 5 * Math.random(3) let offset3 = 5 * Math.random(3)
img3.showImage(offset3) img3.showImage(offset3)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) // *** basic.showString("WINS:", 150) // ***
basic.showNumber(wins, 150) // *** basic.showNumber(wins, 150) // ***
@ -129,12 +129,12 @@ input.onGesture(Gesture.Shake, () => {
let offset4 = 5 * Math.random(3) let offset4 = 5 * Math.random(3)
img4.showImage(offset4) img4.showImage(offset4)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) // *** }) // ***
``` ```
@ -155,12 +155,12 @@ input.onGesture(Gesture.Shake, () => {
let offset5 = 5 * Math.random(3) let offset5 = 5 * Math.random(3)
img5.showImage(offset5) img5.showImage(offset5)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
losses = losses + 1 // *** losses = losses + 1 // ***
}) })
``` ```
@ -182,12 +182,12 @@ input.onGesture(Gesture.Shake, () => {
let offset6 = 5 * Math.random(3) let offset6 = 5 * Math.random(3)
img6.showImage(offset6) img6.showImage(offset6)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
losses = losses + 1 losses = losses + 1
basic.showString("WINS", 150) // *** basic.showString("WINS", 150) // ***
basic.showNumber(wins, 150) // *** basic.showNumber(wins, 150) // ***
@ -213,14 +213,14 @@ input.onGesture(Gesture.Shake, () => {
let offset7 = 5 * Math.random(3) let offset7 = 5 * Math.random(3)
img7.showImage(offset7) img7.showImage(offset7)
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
wins = wins + 1 wins = wins + 1
basic.showString("WINS:", 150) basic.showString("WINS:", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)
basic.showString("LOSSES:", 150) // *** basic.showString("LOSSES:", 150) // ***
basic.showNumber(losses, 150) // *** basic.showNumber(losses, 150) // ***
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
losses = losses + 1 losses = losses + 1
basic.showString("WINS", 150) basic.showString("WINS", 150)
basic.showNumber(wins, 150) basic.showNumber(wins, 150)

View File

@ -34,7 +34,7 @@ input.onGesture(Gesture.Shake, () => {
`) `)
img1.plotFrame(Math.random(3)) img1.plotFrame(Math.random(3))
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) // *** game.addScore(1) // ***
}) // *** }) // ***
``` ```
@ -54,7 +54,7 @@ input.onGesture(Gesture.Shake, () => {
`) `)
img2.plotFrame(Math.random(3)) img2.plotFrame(Math.random(3))
}) })
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
game.addScore(1) game.addScore(1)
basic.showString("WINS: ", 150) // *** basic.showString("WINS: ", 150) // ***
basic.showNumber(game.score(), 150) // *** basic.showNumber(game.score(), 150) // ***

View File

@ -27,7 +27,7 @@ Now let's add to this by creating a condition for on button pressed `A` before t
``` ```
rotating = true rotating = true
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) // *** }) // ***
while (rotating) { while (rotating) {
basic.showAnimation(` basic.showAnimation(`
@ -48,7 +48,7 @@ Now that we have the on button pressed condition, let's make the animation stop
``` ```
rotating = true rotating = true
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
rotating = false // *** rotating = false // ***
}) // *** }) // ***
while (rotating) { while (rotating) {

View File

@ -30,7 +30,7 @@ Now let's add to this by creating a condition for on button pressed `A` before t
``` ```
rotating = true rotating = true
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) // *** }) // ***
while (rotating) { while (rotating) {
basic.showAnimation(` basic.showAnimation(`
@ -52,7 +52,7 @@ Now that we have the on button pressed condition, let's make the animation stop
``` ```
rotating = true rotating = true
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
rotating = false // *** rotating = false // ***
}) // *** }) // ***
while (rotating) { while (rotating) {

View File

@ -88,7 +88,7 @@ levelTime = 0
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let temp = math.abs(person.dirX) * (-1) let temp = math.abs(person.dirX) * (-1)
// {stcode} // {stcode}
// MACRO: stcode // MACRO: stcode
@ -104,7 +104,7 @@ input.onButtonPressed("A", () => {
<br/> <br/>
``` ```
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
let temp1 = math.abs(person.dirX) let temp1 = math.abs(person.dirX)
// {stcode} // {stcode}
// MACRO: stcode // MACRO: stcode

View File

@ -32,7 +32,7 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() // *** basic.clearScreen() // ***
}) // *** }) // ***
``` ```

View File

@ -14,7 +14,7 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() basic.clearScreen()
}) })
``` ```
@ -31,10 +31,10 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() basic.clearScreen()
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) })
``` ```
@ -52,10 +52,10 @@ basic.showAnimation(`
. . . . . # # # # # # # # # # # # # # # . . . . . # # # # # # # # # # # # # # #
. . . . . . . . . . . . . . . # # # # # . . . . . . . . . . . . . . . # # # # #
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.clearScreen() basic.clearScreen()
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showAnimation(` basic.showAnimation(`
# # # # # # # # # # . . . . . . . . . . # # # # # # # # # # . . . . . . . . . .
# # # # # # # # # # . . . . . . . . . . # # # # # # # # # # . . . . . . . . . .

View File

@ -1,6 +1,6 @@
# set brightness challenges # set brightness challenges
These challenges will allow you to change the brightness of the micro:bit. #docs These challenges will allow you to change the brightness of the micro:bit. docs
**Challenge 0** **Challenge 0**
@ -11,7 +11,7 @@ These challenges will allow you to change the brightness of the micro:bit. #docs
``` ```
led.setBrightness(255) led.setBrightness(255)
led.plotAll() led.plotAll()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.setBrightness(64) led.setBrightness(64)
}) })
``` ```
@ -25,10 +25,10 @@ What if we want to turn off all the LEDs? Let's do this by setting the brightnes
``` ```
led.setBrightness(255) led.setBrightness(255)
led.plotAll() led.plotAll()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.setBrightness(64) led.setBrightness(64)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) // *** }) // ***
``` ```
@ -39,10 +39,10 @@ Inside of the condition `input->on button pressed("B")`, add `led->set brightnes
``` ```
led.setBrightness(255) led.setBrightness(255)
led.plotAll() led.plotAll()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.setBrightness(64) led.setBrightness(64)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
led.setBrightness(0) // *** led.setBrightness(0) // ***
}) })
``` ```

View File

@ -30,7 +30,7 @@ basic.showAnimation(`
# . . . # . . . . . # . . . # . . . . .
. # # # . . . . . . . # # # . . . . . .
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) // *** }) // ***
``` ```
@ -48,7 +48,7 @@ basic.showAnimation(`
# . . . # . . . . . # . . . # . . . . .
. # # # . . . . . . . # # # . . . . . .
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showLeds(` basic.showLeds(`
. # . # . . # . # .
. # . # . . # . # .

View File

@ -13,7 +13,7 @@ At the end of the tutorial, click `keep editing`. Your code should look like thi
``` ```
let counter = 0 let counter = 0
let fastPress = false let fastPress = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter = counter + 1 counter = counter + 1
}) })
``` ```
@ -25,7 +25,7 @@ We need to know when the user has hit button `A` 15 times. The user wins when he
``` ```
let counter1 = 0 let counter1 = 0
let fastPress1 = false let fastPress1 = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter1 = counter1 + 1 counter1 = counter1 + 1
if (counter1 == 15 && input.runningTime() < 5000) { if (counter1 == 15 && input.runningTime() < 5000) {
} }
@ -37,7 +37,7 @@ Next, if the user has won, let's set our boolean to true. This indicates that he
``` ```
let counter2 = 0 let counter2 = 0
let fastPress2 = false let fastPress2 = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter2 = counter2 + 1 counter2 = counter2 + 1
if (counter2 == 15 && input.runningTime() < 5000) { if (counter2 == 15 && input.runningTime() < 5000) {
fastPress2 = true // *** fastPress2 = true // ***
@ -52,7 +52,7 @@ We want to set `fastPress` to false if the user was too slow. To do so, we need
``` ```
let counter3 = 0 let counter3 = 0
let fastPress3 = false let fastPress3 = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter3 = counter3 + 1 counter3 = counter3 + 1
if (counter3 == 15 && input.runningTime() < 5000) { if (counter3 == 15 && input.runningTime() < 5000) {
fastPress3 = true fastPress3 = true
@ -72,7 +72,7 @@ Now let's display if the user won or lost. To do so, we need to check the status
``` ```
let counter4 = 0 let counter4 = 0
let fastPress4 = false let fastPress4 = false
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
counter4 = counter4 + 1 counter4 = counter4 + 1
if (counter4 == 15 && input.runningTime() < 5000) { if (counter4 == 15 && input.runningTime() < 5000) {
fastPress4 = true fastPress4 = true

View File

@ -22,7 +22,7 @@ let count = 0
``` ```
let count_ = 0 let count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })
@ -38,7 +38,7 @@ After two button presses, **count** will be equal to 2.
``` ```
count_ = 0 count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })

View File

@ -24,7 +24,7 @@ let count = 0
``` ```
let count_ = 0 let count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })
@ -38,7 +38,7 @@ input.onButtonPressed("A", () => {
``` ```
count_ = 0 count_ = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count_ = count_ + 1 count_ = count_ + 1
basic.showNumber(count_, 100) basic.showNumber(count_, 100)
}) })

View File

@ -13,10 +13,10 @@ At the end of the tutorial, click `keep editing`. Your code should look like thi
``` ```
initializeGame() initializeGame()
playLevel() playLevel()
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
selectHat() selectHat()
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
chooseHat() chooseHat()
}) })
``` ```

View File

@ -46,7 +46,7 @@ Write the code that displays the next letter of the string in "cup select" when
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
index = index + 1 index = index + 1
if (index > 2) { if (index > 2) {
index = 0 index = 0

View File

@ -12,7 +12,7 @@ At the end of the tutorial, click `keep editing`. Your code should look like thi
``` ```
let inital = 5 let inital = 5
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let doubled1 = double(initial) let doubled1 = double(initial)
basic.showNumber(doubled1, 150) // *** basic.showNumber(doubled1, 150) // ***
}) })
@ -40,11 +40,11 @@ Add a condition for when button `B` is pressed. We will use this condition in th
``` ```
initial = 5 initial = 5
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let doubled = double(initial) let doubled = double(initial)
basic.showNumber(doubled, 150) basic.showNumber(doubled, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
}) // *** }) // ***
``` ```

View File

@ -21,7 +21,7 @@ let x = 5
<br/> <br/>
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) })
``` ```

View File

@ -28,7 +28,7 @@ basic.showLeds(`
. . # . . . . # . .
. . # . . . . # . .
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
}) })
``` ```
@ -42,7 +42,7 @@ basic.showLeds(`
. . # . . . . # . .
. . # . . . . # . .
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let random = Math.random(2) let random = Math.random(2)
}) })
``` ```
@ -57,7 +57,7 @@ basic.showLeds(`
. . # . . . . # . .
. . # . . . . # . .
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let random1 = Math.random(2) let random1 = Math.random(2)
if (random1 == 0) { if (random1 == 0) {
basic.showString("TRUTH", 150) basic.showString("TRUTH", 150)
@ -79,7 +79,7 @@ basic.showLeds(`
. . # . . . . # . .
. . # . . . . # . .
`, 400) `, 400)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let random2 = Math.random(2) let random2 = Math.random(2)
if (random2 == 0) { if (random2 == 0) {
basic.showString("TRUTH", 150) basic.showString("TRUTH", 150)

View File

@ -18,7 +18,7 @@ basic.plotImage(`
. . # . . . . # . .
. . # . . . . # . .
`) `)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let random = Math.random(2) let random = Math.random(2)
if (random == 0) { if (random == 0) {
basic.showString("TRUTH", 150) basic.showString("TRUTH", 150)
@ -47,7 +47,7 @@ basic.plotImage(`
. . # . . . . # . .
. . # . . . . # . .
`) `)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let random1 = Math.random(3) // *** let random1 = Math.random(3) // ***
if (random1 == 0) { if (random1 == 0) {
basic.showString("TRUTH", 150) basic.showString("TRUTH", 150)
@ -76,7 +76,7 @@ basic.plotImage(`
. . # . . . . # . .
. . # . . . . # . .
`) `)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
let random2 = Math.random(3) let random2 = Math.random(3)
if (random2 == 0) { if (random2 == 0) {
basic.showString("TRUTH", 150) // *** basic.showString("TRUTH", 150) // ***

View File

@ -10,14 +10,14 @@ This [guided tutorial](/microbit/lessons/typing-game/tutorial) will teach you ho
alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
index = 0 index = 0
name = "" name = ""
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.showString(alphabet.substr(index, 1), 0) led.showString(alphabet.substr(index, 1), 0)
index = index + 1 index = index + 1
}) })
if (index > 25) { if (index > 25) {
index = 0 index = 0
} }
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
name = name.concat(alphabet.substr(index - 1, 1)) name = name.concat(alphabet.substr(index - 1, 1))
}) })
input.onGesture(Gesture.Shake, () => { input.onGesture(Gesture.Shake, () => {
@ -33,14 +33,14 @@ After you have shown the string in the condition `on shake`, make the name varia
alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
index = 0 index = 0
name = "" name = ""
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.showString(alphabet.substr(index, 1), 0) led.showString(alphabet.substr(index, 1), 0)
index = index + 1 index = index + 1
}) })
if (index > 25) { if (index > 25) {
index = 0 index = 0
} }
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
name = name.concat(alphabet.substr(index - 1, 1)) name = name.concat(alphabet.substr(index - 1, 1))
}) })
input.onGesture(Gesture.Shake, () => { input.onGesture(Gesture.Shake, () => {
@ -57,14 +57,14 @@ After you have cleared the name variable to hold nothing, make `index := 0` so t
alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ" alphabet = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
index = 0 index = 0
name = "" name = ""
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
led.showString(alphabet.substr(index, 1), 0) led.showString(alphabet.substr(index, 1), 0)
index = index + 1 index = index + 1
}) })
if (index > 25) { if (index > 25) {
index = 0 index = 0
} }
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
name = name.concat(alphabet.substr(index - 1, 1)) name = name.concat(alphabet.substr(index - 1, 1))
}) })
input.onGesture(Gesture.Shake, () => { input.onGesture(Gesture.Shake, () => {

View File

@ -18,7 +18,7 @@ Now we need to reply after someone asks Micro a yes or no question. We want to
``` ```
basic.showString("ASK ME A QUESTION", 150) basic.showString("ASK ME A QUESTION", 150)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("YES", 150) // *** basic.showString("YES", 150) // ***
}) // *** }) // ***
``` ```
@ -33,10 +33,10 @@ What if Micro's answer to the question is no? Let's have `NO` be displayed when
``` ```
basic.showString("ASK ME A QUESTION", 150) basic.showString("ASK ME A QUESTION", 150)
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
basic.showString("YES", 150) basic.showString("YES", 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
basic.showString("NO", 150) // *** basic.showString("NO", 150) // ***
}) // *** }) // ***
``` ```

View File

@ -53,7 +53,7 @@ The first job of the scheduler is to allow multiple *subprograms* to be queued u
``` ```
export function countButtonPresses() { export function countButtonPresses() {
let count = 0 let count = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
}) })
basic.forever(() => { basic.forever(() => {
@ -71,7 +71,7 @@ let count1 = 0
initializesthe variable `count`. The second statement initializesthe variable `count`. The second statement
``` ```
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count1 = count1 + 1 count1 = count1 + 1
}) })
``` ```
@ -135,13 +135,13 @@ As a result, you can easily add a new capability to the micro:bit by just adding
``` ```
export function countButtonPressesWithReset() { export function countButtonPressesWithReset() {
let count = 0 let count = 0
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
count = count + 1 count = count + 1
}) })
basic.forever(() => { basic.forever(() => {
basic.showNumber(count, 150) basic.showNumber(count, 150)
}) })
input.onButtonPressed("B", () => { input.onButtonPressed(Button.B, () => {
count = 0 count = 0
}) })
} }

View File

@ -8,7 +8,7 @@ The code below shows a simple script that sends a line when the BBC micro:bit st
``` ```
serial.writeLine("started...") serial.writeLine("started...")
input.onButtonPressed("A", () => { input.onButtonPressed(Button.A, () => {
serial.writeLine("A pressed") serial.writeLine("A pressed")
}) })
``` ```

View File

@ -1,6 +1,6 @@
{ {
"name": "kindscript-microbit", "name": "kindscript-microbit",
"version": "0.0.14", "version": "0.0.15",
"description": "BBC micro:bit target for KindScript", "description": "BBC micro:bit target for KindScript",
"keywords": [ "keywords": [
"JavaScript", "JavaScript",
@ -30,6 +30,6 @@
"typescript": "^1.8.7" "typescript": "^1.8.7"
}, },
"dependencies": { "dependencies": {
"kindscript": "0.1.119" "kindscript": "0.1.121"
} }
} }

View File

@ -683,10 +683,16 @@ svg.sim.grayscale {
case 'radiopacket': this.flashAntenna(); break; case 'radiopacket': this.flashAntenna(); break;
} }
} }
let tiltDecayer = 0;
this.element.addEventListener("mousemove", (ev: MouseEvent) => { this.element.addEventListener("mousemove", (ev: MouseEvent) => {
let state = this.board; let state = this.board;
if (!state.accelerometer.isActive) return; if (!state.accelerometer.isActive) return;
if (tiltDecayer) {
clearInterval(tiltDecayer);
tiltDecayer = 0;
}
let ax = (ev.clientX - this.element.clientWidth / 2) / (this.element.clientWidth / 3); let ax = (ev.clientX - this.element.clientWidth / 2) / (this.element.clientWidth / 3);
let ay = (ev.clientY - this.element.clientHeight / 2) / (this.element.clientHeight / 3); let ay = (ev.clientY - this.element.clientHeight / 2) / (this.element.clientHeight / 3);
@ -695,6 +701,7 @@ svg.sim.grayscale {
let z2 = 1023*1023 - x * x - y * y; let z2 = 1023*1023 - x * x - y * y;
let z = Math.floor((z2 > 0 ? -1 : 1)* Math.sqrt(Math.abs(z2))); let z = Math.floor((z2 > 0 ? -1 : 1)* Math.sqrt(Math.abs(z2)));
console.log(`move: ${ax} ${y} ${z}`)
state.accelerometer.update(x,y,z); state.accelerometer.update(x,y,z);
this.updateTilt(); this.updateTilt();
}, false); }, false);
@ -702,8 +709,25 @@ svg.sim.grayscale {
let state = this.board; let state = this.board;
if (!state.accelerometer.isActive) return; if (!state.accelerometer.isActive) return;
state.accelerometer.update(0,0,-1023); if (!tiltDecayer) {
tiltDecayer = setInterval(() => {
let accx = state.accelerometer.getX(MicroBitCoordinateSystem.RAW);
accx = Math.floor(Math.abs(accx) * 0.85) * (accx > 0 ? 1 : -1);
let accy = state.accelerometer.getY(MicroBitCoordinateSystem.RAW);
accy = Math.floor(Math.abs(accy) * 0.85) * (accy > 0 ? 1 : -1);
let accz = -Math.sqrt(Math.max(0, 1023*1023 - accx*accx - accy*accy));
if (Math.abs(accx) <= 24 && Math.abs(accy) <= 24) {
clearInterval(tiltDecayer);
tiltDecayer = 0;
accx = 0;
accy = 0;
accz = -1023;
}
console.log(`leave: ${accx} ${accy} ${accz}`)
state.accelerometer.update(accx, accy, accz);
this.updateTilt(); this.updateTilt();
}, 50)
}
}, false); }, false);
this.pins.forEach((pin, index) => { this.pins.forEach((pin, index) => {