251 lines
6.3 KiB
Markdown
251 lines
6.3 KiB
Markdown
# Coding in MakeCode
|
|
|
|
This guide is intended for users who are used to the LabView LEGO Minstorms editor.
|
|
|
|
## Snap the blocks
|
|
|
|
Just like LabView, blocks can be dragged from the cabinet and snapped together
|
|
to create a sequence of program instructions.
|
|
|
|
The program below **starts**, turns on motor A, waits a second and stop motor A.
|
|
|
|
data:image/s3,"s3://crabby-images/cf930/cf9306d4c2f07eaa2e74a489517b6c948eb7641e" alt="sequence of block"
|
|
|
|
The blocks are similar: they snap on the ``||on start||`` block then latch to each other vertically.
|
|
|
|
```blocks
|
|
motors.largeA.setSpeed(50)
|
|
loops.pause(1000)
|
|
motors.largeA.stop()
|
|
```
|
|
|
|
All block programs can be converted to JavaScript and edited from there as well.
|
|
|
|
```typescript
|
|
motors.largeA.setSpeed(50)
|
|
loops.pause(1000)
|
|
motors.largeA.stop()
|
|
```
|
|
|
|
## Download to the EV3
|
|
|
|
The MakeCode editor provides a simulator to try out the code in your browser. It restarts automatically after you make a code change. Once you are ready to transfer it to the @boardname@, click the ``||Download||`` button and follow the instructions.
|
|
|
|
## Single motors
|
|
|
|
The program below controls a large motor on port A in a variety of ways: setting the speed,
|
|
setting the speed for a given time, angle or number of rotations.
|
|
|
|
data:image/s3,"s3://crabby-images/42b70/42b70f9e7f6b79648553c58a215be9fe378083ac" alt="Single motor blocks"
|
|
|
|
```blocks
|
|
motors.largeA.setSpeed(50);
|
|
motors.largeA.setSpeed(50, 1000, MoveUnit.MilliSeconds);
|
|
motors.largeA.setSpeed(50, 360, MoveUnit.Degrees);
|
|
motors.largeA.setSpeed(50, 1, MoveUnit.Rotations);
|
|
motors.largeA.stop();
|
|
```
|
|
|
|
## Steering
|
|
|
|
The **steering** blocks allow to synchronize two motors at a precise rate. They can also specify the duration, angle or number of rotations.
|
|
|
|
data:image/s3,"s3://crabby-images/2637a/2637a649fbbdab188da7ec0d3cff10b2979f1d52" alt="Steering blocks"
|
|
|
|
```blocks
|
|
motors.largeBC.steer(0, 50);
|
|
motors.largeBC.steer(0, 50, 1000, MoveUnit.MilliSeconds);
|
|
motors.largeBC.steer(0, 50, 360, MoveUnit.Degrees);
|
|
motors.largeBC.steer(0, 50, 1, MoveUnit.Rotations);
|
|
motors.largeBC.stop();
|
|
```
|
|
|
|
## Tank
|
|
|
|
The **tank** blocks control the speed of two motors, typically from a differential drive robot. They can also specify the duration, angle or number of rotations.
|
|
|
|
data:image/s3,"s3://crabby-images/0d0c5/0d0c5f588e05eadc715b525c57b0c59d6e03d4cb" alt="Tank block"
|
|
|
|
```blocks
|
|
motors.largeBC.tank(50, 50);
|
|
motors.largeBC.tank(50, 50, 1000, MoveUnit.MilliSeconds);
|
|
motors.largeBC.tank(50, 50, 360, MoveUnit.Degrees);
|
|
motors.largeBC.tank(50, 50, 1, MoveUnit.Rotations);
|
|
motors.largeBC.stop();
|
|
```
|
|
|
|
## Coasting and braking
|
|
|
|
By default, all motors coast when the move command is done. You can change this behavior with the `set brake`` block.
|
|
|
|
data:image/s3,"s3://crabby-images/48770/487701c893b4fce3ab9f324d0831c66eb4831825" alt="Brake block"
|
|
|
|
```blocks
|
|
motors.largeD.setBrake(true);
|
|
motors.largeD.setSpeed(50, 1, MoveUnit.Rotations)
|
|
```
|
|
|
|
## Inverting and regulating motors
|
|
|
|
Sometime you need to invert the direction of a motor. Use the ``set invert`` block.
|
|
|
|
data:image/s3,"s3://crabby-images/52309/523090e547511e402ee4bffadb2a00a3b20364ea" alt="Brake block"
|
|
|
|
```blocks
|
|
motors.largeA.setInverted(true);
|
|
```
|
|
|
|
By default, the speed of motors is regulated. This means that if your robot goes up a hill,
|
|
the regulator will adjust the power to match the desired speed. You can disable this feature
|
|
using ``set regulated``.
|
|
|
|
data:image/s3,"s3://crabby-images/98e18/98e18441adee5b6fd97b26d917b86962c2336681" alt="Brake block"
|
|
|
|
```blocks
|
|
motors.largeA.setRegulated(false);
|
|
```
|
|
|
|
## Brick
|
|
|
|
The brick category contains a number of blocks to display graphics on the brick screen.
|
|
|
|
data:image/s3,"s3://crabby-images/331be/331bec0cb0b1f2cff93e6136398c0247a3239dc3" alt="brick image"
|
|
|
|
```blocks
|
|
brick.clearScreen()
|
|
brick.showImage(images.expressionsWink)
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/db656/db6564ec6692618ef792a9250669e18707bbb037" alt="brick status light"
|
|
|
|
```blocks
|
|
brick.setStatusLight(StatusLight.Off);
|
|
brick.setStatusLight(StatusLight.Red);
|
|
brick.setStatusLight(StatusLight.OrangePulse);
|
|
```
|
|
|
|
## Waiting (pausing)
|
|
|
|
It is quite common to wait for a sensor state, such as a touch button pressed.
|
|
The ``pause until`` blocks provide a variety of ways to acheive this.
|
|
|
|
data:image/s3,"s3://crabby-images/acc58/acc5857be0fda0a098aad1ea5991997474405592" alt="pause for time"
|
|
|
|
```blocks
|
|
motors.largeD.setSpeed(50)
|
|
loops.pause(1000)
|
|
motors.largeD.stop();
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/d0ca0/d0ca069abad654d6354b8d5695640073bded76e5" alt="pause for touch"
|
|
|
|
```blocks
|
|
motors.largeD.setSpeed(50)
|
|
sensors.touch1.pauseUntil(ButtonEvent.Pressed)
|
|
motors.largeD.stop();
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/050b0/050b004de7e87007a030993da86b42f536db5b32" alt="pause for distance"
|
|
|
|
```blocks
|
|
motors.largeD.setSpeed(50)
|
|
sensors.ultrasonic4.pauseUntil(UltrasonicSensorEvent.ObjectNear)
|
|
motors.largeD.stop();
|
|
```
|
|
|
|
You can also use the ``pause until`` block to wait on any boolean expression.
|
|
The runtime will evaluate this expression until it becomes true.
|
|
|
|
```blocks
|
|
motors.largeD.setSpeed(50)
|
|
pauseUntil(() => sensors.touch1.isPressed())
|
|
motors.largeD.stop()
|
|
```
|
|
|
|
## Loops
|
|
|
|
data:image/s3,"s3://crabby-images/ae902/ae902cbb36c2b938b776e1fc7d2db0eeecfff844" alt="Single loop"
|
|
|
|
```blocks
|
|
loops.forever(() => {
|
|
motors.largeD.setSpeed(50, 1, MoveUnit.Rotations);
|
|
motors.largeD.setSpeed(-50, 1, MoveUnit.Rotations);
|
|
})
|
|
```
|
|
|
|
data:image/s3,"s3://crabby-images/158f6/158f6cacb6b02bf271718df743b09ed9d04e8426" alt="While loop"
|
|
|
|
```blocks
|
|
for(let i = 0; i < 10; i++) {
|
|
motors.largeD.setSpeed(50, 1, MoveUnit.Rotations);
|
|
motors.largeD.setSpeed(-50, 1, MoveUnit.Rotations);
|
|
}
|
|
let k = 0;
|
|
while(k < 10) {
|
|
motors.largeD.setSpeed(50, 1, MoveUnit.Rotations);
|
|
motors.largeD.setSpeed(-50, 1, MoveUnit.Rotations);
|
|
k++;
|
|
}
|
|
```
|
|
|
|
## Variables
|
|
|
|
data:image/s3,"s3://crabby-images/e2cdc/e2cdc02494c9ecd59f8fa83661e2829eb4367428" alt="Variable block"
|
|
|
|
```blocks
|
|
let light = 0;
|
|
loops.forever(function () {
|
|
light = sensors.color3.light(LightIntensityMode.Reflected);
|
|
motors.largeD.setSpeed(light)
|
|
})
|
|
```
|
|
|
|
## Concurrent loops
|
|
|
|
You can spin up multiple ``forever`` loops that will run at the same time.
|
|
Only one code is running at the time, but each loop iteration will interleave.
|
|
|
|
data:image/s3,"s3://crabby-images/836f5/836f50877dc0926050059d9b1163707d2b93801e" alt="Brake block"
|
|
|
|
```blocks
|
|
loops.forever(() => {
|
|
motors.largeD.setSpeed(50, 1, MoveUnit.Rotations);
|
|
motors.largeD.setSpeed(-50, 1, MoveUnit.Rotations);
|
|
})
|
|
loops.forever(() => {
|
|
brick.showImage(images.eyesMiddleRight)
|
|
loops.pause(1000)
|
|
brick.showImage(images.eyesMiddleLeft)
|
|
loops.pause(1000)
|
|
})
|
|
```
|
|
|
|
## Conditional
|
|
|
|
The ``if`` block allow to run different code based on a boolean condition.
|
|
This is similar to the switch block.
|
|
|
|
data:image/s3,"s3://crabby-images/56907/56907b97b31a3f5198ebe605a972d76599bb9e54" alt="Brake block"
|
|
|
|
```blocks
|
|
loops.forever(function() {
|
|
if(sensors.touch1.isPressed()) {
|
|
motors.largeD.setSpeed(50)
|
|
} else {
|
|
motors.largeD.stop()
|
|
}
|
|
})
|
|
```
|
|
|
|
## Random
|
|
|
|
The ``random range`` blocks returns number between two bounds.
|
|
|
|
data:image/s3,"s3://crabby-images/70d62/70d62d076b315522d6ead1f2380ec51afd6b0823" alt="Brake block"
|
|
|
|
```blocks
|
|
loops.forever(function () {
|
|
motors.largeBC.steer(Math.randomRange(-5, 5), 50)
|
|
loops.pause(100)
|
|
})
|
|
``` |