325ccce3a0
* missing packages * fixing snippet issues * snippet fix * more doc fixes
81 lines
2.1 KiB
Markdown
81 lines
2.1 KiB
Markdown
# Voting Machine
|
|
|
|
### ~ avatar
|
|
|
|
Build a voting machine using many @boardname@s!
|
|
|
|
### ~
|
|
|
|
https://youtu.be/77HOqf8BaNg
|
|
|
|
|
|
In this project, a **voter** program is uploaded on the player's @boardname@. The player uses the buttons to vote ``yes`` or ``no``
|
|
and the vote is sent to the **dashboard** @boardname@ via radio.
|
|
The dashboard allocates one LED per player and turns it on or off based on the vote.
|
|
|
|
## The voter program
|
|
|
|
Assuming button ``A`` is no and ``B`` is yes, the voter program works as follows:
|
|
|
|
* when button ``A`` is pressed, a number ``0`` is sent via radio and the ``X`` symbol is shown on the screen.
|
|
|
|
```block
|
|
input.onButtonPressed(Button.A, () => {
|
|
radio.sendNumber(0)
|
|
basic.showIcon(IconNames.No)
|
|
})
|
|
```
|
|
|
|
* when button ``B`` is pressed, a number ``255`` is sent via radio and the ``Y`` symbol is shown on the screen.
|
|
|
|
```block
|
|
input.onButtonPressed(Button.B, () => {
|
|
radio.sendNumber(255)
|
|
basic.showIcon(IconNames.Yes)
|
|
})
|
|
```
|
|
|
|
* In order to track the votes, we tell the radio to also transmit the device serial number.
|
|
|
|
```block
|
|
radio.setTransmitSerialNumber(true)
|
|
```
|
|
|
|
* we arbritrarily choose ``4`` as the group used for the communications
|
|
|
|
```block
|
|
radio.setGroup(4)
|
|
```
|
|
|
|
Combined together, the voter program looks as follows:
|
|
|
|
```blocks
|
|
input.onButtonPressed(Button.A, () => {
|
|
radio.sendNumber(0)
|
|
basic.showIcon(IconNames.No)
|
|
})
|
|
input.onButtonPressed(Button.B, () => {
|
|
radio.sendNumber(255)
|
|
basic.showIcon(IconNames.Yes)
|
|
})
|
|
radio.setGroup(4)
|
|
radio.setTransmitSerialNumber(true)
|
|
basic.showIcon(IconNames.Ghost)
|
|
```
|
|
|
|
## The dashboard
|
|
|
|
The dashboard code can be found at [/examples/radio-dashboard](/examples/radio-dashboard).
|
|
|
|
Download the code from that example into the @boardname@ that will be used to display the result.
|
|
|
|
When the dashboard receives a message from a @boardname@, it find a pixel for that board (and remembers it)
|
|
and uses the number received as the brightness of the LED.
|
|
|
|
When a message hasn't been received by a board for some time, it's pixel will start to blink. After more time, it will simply turn off.
|
|
|
|
|
|
```package
|
|
radio
|
|
```
|