scratch like broadcast api (#1358)
* scratch like broadcast api * always register handler * adding docs * added icon * updated block name * adding DAL support "radio.raiseEvent" * typo * implemented using radiobus * adding docs * adding raise event block * updated shims * updated pxt
This commit is contained in:
@ -0,0 +1,6 @@
|
||||
{
|
||||
"radio": "Communicate data using radio packets",
|
||||
"radio.onReceivedMessage": "Registers code to run for a particular message",
|
||||
"radio.onReceivedMessage|param|msg": "@param handler ",
|
||||
"radio.sendMessage": "Broadcasts a message over radio"
|
||||
}
|
@ -0,0 +1,6 @@
|
||||
{
|
||||
"radio.onReceivedMessage|block": "on radio $msg received",
|
||||
"radio.sendMessage|block": "radio send $msg",
|
||||
"radio|block": "radio",
|
||||
"{id:category}Radio": "Radio"
|
||||
}
|
@ -0,0 +1,45 @@
|
||||
# on Received Message
|
||||
|
||||
Run part of a program when the @boardname@ receives a
|
||||
message over ``radio``.
|
||||
|
||||
```sig
|
||||
radio.onReceivedMessage(0, function() {})
|
||||
```
|
||||
|
||||
## Parameters
|
||||
|
||||
* **msg**: The message to listen for. See [send message](/reference/radio/send-message)
|
||||
|
||||
## Examples
|
||||
|
||||
## Example: Broadcasting heart or skull
|
||||
|
||||
Sends a ``heart`` message when ``A`` is pressed, ``skull`` when ``B`` is pressed. On the side, display heart or skull for the message.
|
||||
|
||||
```blocks
|
||||
enum RadioMessage {
|
||||
heart,
|
||||
skull
|
||||
}
|
||||
input.onButtonPressed(Button.A, function () {
|
||||
radio.sendMessage(RadioMessage.heart)
|
||||
})
|
||||
input.onButtonPressed(Button.B, function () {
|
||||
radio.sendMessage(RadioMessage.skull)
|
||||
})
|
||||
radio.onReceivedMessage(RadioMessage.heart, function () {
|
||||
basic.showIcon(IconNames.Heart)
|
||||
})
|
||||
radio.onReceivedMessage(RadioMessage.skull, function () {
|
||||
basic.showIcon(IconNames.Skull)
|
||||
})
|
||||
```
|
||||
|
||||
## See also
|
||||
|
||||
[send message](/reference/radio/send-message),
|
||||
|
||||
```package
|
||||
radio-broadcast
|
||||
```
|
43
libs/radio-broadcast/docs/reference/radio/send-message.md
Normal file
43
libs/radio-broadcast/docs/reference/radio/send-message.md
Normal file
@ -0,0 +1,43 @@
|
||||
# send Message
|
||||
|
||||
Broadcast a coded message to other @boardname@s connected via ``radio``.
|
||||
|
||||
```sig
|
||||
radio.sendMessage(0);
|
||||
```
|
||||
|
||||
## Parameters
|
||||
|
||||
* **msg**: a coded message.
|
||||
|
||||
|
||||
## Example: Broadcasting heart or skull
|
||||
|
||||
Sends a ``heart`` message when ``A`` is pressed, ``skull`` when ``B`` is pressed. On the side, display heart or skull for the message.
|
||||
|
||||
```blocks
|
||||
enum RadioMessage {
|
||||
heart,
|
||||
skull
|
||||
}
|
||||
input.onButtonPressed(Button.A, function () {
|
||||
radio.sendMessage(RadioMessage.heart)
|
||||
})
|
||||
input.onButtonPressed(Button.B, function () {
|
||||
radio.sendMessage(RadioMessage.skull)
|
||||
})
|
||||
radio.onReceivedMessage(RadioMessage.heart, function () {
|
||||
basic.showIcon(IconNames.Heart)
|
||||
})
|
||||
radio.onReceivedMessage(RadioMessage.skull, function () {
|
||||
basic.showIcon(IconNames.Skull)
|
||||
})
|
||||
```
|
||||
|
||||
## See also
|
||||
|
||||
[on received number](/reference/radio/on-received-number)
|
||||
|
||||
```package
|
||||
radio-broadcast
|
||||
```
|
11
libs/radio-broadcast/pxt.json
Normal file
11
libs/radio-broadcast/pxt.json
Normal file
@ -0,0 +1,11 @@
|
||||
{
|
||||
"name": "radio-broadcast",
|
||||
"files": [
|
||||
"pxt.json",
|
||||
"radio-broadcast.ts"
|
||||
],
|
||||
"dependencies": {
|
||||
"core": "file:../core",
|
||||
"radio": "file:../radio"
|
||||
}
|
||||
}
|
38
libs/radio-broadcast/radio-broadcast.ts
Normal file
38
libs/radio-broadcast/radio-broadcast.ts
Normal file
@ -0,0 +1,38 @@
|
||||
namespace radio {
|
||||
/**
|
||||
* Gets the message code
|
||||
*/
|
||||
//% blockHidden=1 shim=ENUM_GET
|
||||
//% blockId=radioMessageCode block="$msg" enumInitialMembers="message1"
|
||||
//% enumName=RadioMessage enumMemberName=msg enumPromptHint="e.g. Start, Stop, Jump..."
|
||||
export function __message(msg: number): number {
|
||||
return msg;
|
||||
}
|
||||
|
||||
/**
|
||||
* Broadcasts a message over radio
|
||||
* @param msg
|
||||
*/
|
||||
//% blockId=radioBroadcastMessage block="radio send $msg"
|
||||
//% msg.shadow=radioMessageCode draggableParameters
|
||||
//% weight=200
|
||||
//% blockGap=8
|
||||
//% help=radio/send-message
|
||||
export function sendMessage(msg: number): void {
|
||||
// 0 is MICROBIT_EVT_ANY, shifting by 1
|
||||
radio.raiseEvent(DAL.MES_BROADCAST_GENERAL_ID, msg + 1);
|
||||
}
|
||||
|
||||
/**
|
||||
* Registers code to run for a particular message
|
||||
* @param msg
|
||||
* @param handler
|
||||
*/
|
||||
//% blockId=radioOnMessageReceived block="on radio $msg received"
|
||||
//% msg.shadow=radioMessageCode draggableParameters
|
||||
//% weight=199
|
||||
//% help=radio/on-received-message
|
||||
export function onReceivedMessage(msg: number, handler: () => void) {
|
||||
control.onEvent(DAL.MES_BROADCAST_GENERAL_ID, msg + 1, handler);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user