Beta updates (#116)
* fixes for beta - hide blocks without function - digital Pin selection bring P0 in first position - add compass block to end confusion about "basic.showArrow(ArrowNames.North)" - add approved repos - add and sort preffered repos - add prefferedPackages - disable webUSB - disable parts - remove mobileSafariDownloadProtocol - update socialOptions * remove `preferredPackages` from `pxtarget` * Beta updates - removed robobit extension - updated docs menu - added about.md - added arrow icons - removed show arrow block Co-authored-by: Juri <gitkraken@juriwolf.de>
96
docs/about.md
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
![](/static/mb/device/calliope_website.jpg)
|
||||||
|
|
||||||
|
# About
|
||||||
|
|
||||||
|
## @description A Blocks / Javascript code editor for the Calliope mini, a pocket-size computer with 5x5 display, sensors and Bluetooth.
|
||||||
|
|
||||||
|
The [Calliope mini](https://calliope.cc) is a [pocket-size computer]([/device](https://calliope.cc/en/calliope-mini/tech-facts)) with a 5x5 display of 25 LEDs, Bluetooth and sensors that can be programmed by anyone.
|
||||||
|
|
||||||
|
The Calliope mini provides an easy and fun introduction to programming and making ??? switch on, program it to do something fun ??? wear it, customize it.
|
||||||
|
Just like Arduino, the Calliope mini can additionally be connected to and interact with sensors, displays, and other devices.
|
||||||
|
|
||||||
|
* [Read the docs](/docs)
|
||||||
|
|
||||||
|
## [Hardware: The Device](/device)
|
||||||
|
|
||||||
|
The Calliope mini is packaged with sensors, radio and other goodies. Learn about the [hardware components]([/device](https://calliope.cc/en/calliope-mini/tech-facts)) of the Calliope mini to make the most of it!
|
||||||
|
|
||||||
|
## ~ hint
|
||||||
|
|
||||||
|
**Looking to buy a Calliope mini?** See the [list of resellers](https://calliope.cc/en/shops).
|
||||||
|
|
||||||
|
## ~
|
||||||
|
|
||||||
|
## Programming: [Blocks](/blocks) or [JavaScript](/javascript)
|
||||||
|
|
||||||
|
You can program the Calliope mini using [Blocks](/blocks) or [JavaScript](/javascript) in your web browser via the [Calliope mini APIs](/reference):
|
||||||
|
|
||||||
|
```block
|
||||||
|
input.onButtonPressed(Button.A, () => {
|
||||||
|
basic.showString("Hi!");
|
||||||
|
})
|
||||||
|
```
|
||||||
|
```typescript
|
||||||
|
input.onButtonPressed(Button.A, () => {
|
||||||
|
basic.showString("Hi!");
|
||||||
|
})
|
||||||
|
```
|
||||||
|
|
||||||
|
The editor work in [most modern browsers](/browsers), work [offline](/offline) once loaded and do not require any installation.
|
||||||
|
|
||||||
|
## [Compile and Flash: Your Program!](/device/usb)
|
||||||
|
|
||||||
|
When you have your code ready, you connect your Calliope mini to a computer via a USB cable, so it appears as a mounted drive (named MINI). If you are using the Calliope mini REV2 you also see another drive (FLASH) that handels up to 25 additional programs.
|
||||||
|
|
||||||
|
Compilation to ARM thumb machine code from [Blocks](/blocks) or [JavaScript](/javascript) happens in the browser. You save the ARM binary
|
||||||
|
program to a file, which you then copy to the micro:bit drive, which flashes the micro:bit device with the new program.
|
||||||
|
|
||||||
|
## Simulator: Test Your Code
|
||||||
|
|
||||||
|
You can run your code using the micro:bit simulator, all within the confines of a web browser.
|
||||||
|
The simulator has support for the LED screen, buttons, as well as compass, accelerometer, and digital I/O pins.
|
||||||
|
|
||||||
|
```sim
|
||||||
|
basic.forever(() => {
|
||||||
|
basic.showString("Hi!");
|
||||||
|
})
|
||||||
|
input.onButtonPressed(Button.A, () => {
|
||||||
|
led.stopAnimation();
|
||||||
|
basic.showLeds(`
|
||||||
|
. . . . .
|
||||||
|
. # . # .
|
||||||
|
. . . . .
|
||||||
|
# . . . #
|
||||||
|
. # # # .`);
|
||||||
|
});
|
||||||
|
input.onButtonPressed(Button.B, () => {
|
||||||
|
led.stopAnimation();
|
||||||
|
basic.showLeds(`
|
||||||
|
. # . # .
|
||||||
|
# . # . #
|
||||||
|
# . . . #
|
||||||
|
. # . # .
|
||||||
|
. . # . .`);
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
## Learn!
|
||||||
|
|
||||||
|
We have tons of [projects](/projects), [examples](/examples) and [courses](/courses) to get your started!
|
||||||
|
|
||||||
|
|
||||||
|
## [Command Line Tools](/cli)
|
||||||
|
|
||||||
|
Looking to use @homeurl@ in your favorite editor? Install the [command line tools](/cli) and get rolling!
|
||||||
|
|
||||||
|
## [Extensions](/extensions)
|
||||||
|
|
||||||
|
Create, edit and distribute your own blocks and JavaScript using [extensions](/extensions). Extensions are hosted on GitHub and may be written using C++, JavaScript and/or ARM thumb.
|
||||||
|
|
||||||
|
## [Open Source](/open-source)
|
||||||
|
|
||||||
|
The code for the Calliope mini is [open source](/open-source) on GitHub. Contributors are welcome!
|
||||||
|
|
||||||
|
```package
|
||||||
|
radio
|
||||||
|
```
|
BIN
docs/static/mb/device/calliope_website.jpg
vendored
Normal file
After Width: | Height: | Size: 52 KiB |
@ -257,6 +257,8 @@
|
|||||||
"basic.showArrow": "Draws an arrow on the LED screen",
|
"basic.showArrow": "Draws an arrow on the LED screen",
|
||||||
"basic.showArrow|param|direction": "the direction of the arrow",
|
"basic.showArrow|param|direction": "the direction of the arrow",
|
||||||
"basic.showArrow|param|interval": "the amount of time (milliseconds) to show the icon. Default is 600.",
|
"basic.showArrow|param|interval": "the amount of time (milliseconds) to show the icon. Default is 600.",
|
||||||
|
"basic.showCompass": "Draws needle on the screen which always points to north",
|
||||||
|
"basic.showCompass|param|interval": "the amount of time (milliseconds) to show the needle. Default is 600.",
|
||||||
"basic.showIcon": "Draws the selected icon on the LED screen",
|
"basic.showIcon": "Draws the selected icon on the LED screen",
|
||||||
"basic.showIcon|param|icon": "the predefined icon id",
|
"basic.showIcon|param|icon": "the predefined icon id",
|
||||||
"basic.showIcon|param|interval": "the amount of time (milliseconds) to show the icon. Default is 600.",
|
"basic.showIcon|param|interval": "the amount of time (milliseconds) to show the icon. Default is 600.",
|
||||||
@ -396,8 +398,6 @@
|
|||||||
"images": "Creation, manipulation and display of LED images.",
|
"images": "Creation, manipulation and display of LED images.",
|
||||||
"images.createBigImage": "Creates an image with 2 frames.",
|
"images.createBigImage": "Creates an image with 2 frames.",
|
||||||
"images.createImage": "Creates an image that fits on the LED screen.",
|
"images.createImage": "Creates an image that fits on the LED screen.",
|
||||||
"images.showCompass": "Draws needle on the screen which always points to north",
|
|
||||||
"images.showCompass|param|interval": "the amount of time (milliseconds) to show the needle. Default is 600.",
|
|
||||||
"input": "Events and data from sensors",
|
"input": "Events and data from sensors",
|
||||||
"input.acceleration": "Get the acceleration value in milli-gravitys (when the board is laying flat with the screen up, x=0, y=0 and z=-1024)",
|
"input.acceleration": "Get the acceleration value in milli-gravitys (when the board is laying flat with the screen up, x=0, y=0 and z=-1024)",
|
||||||
"input.acceleration|param|dimension": "x, y, or z dimension, eg: Dimension.X",
|
"input.acceleration|param|dimension": "x, y, or z dimension, eg: Dimension.X",
|
||||||
|
@ -103,6 +103,14 @@
|
|||||||
"Gesture.TiltRight": "Raised when the screen is pointing right",
|
"Gesture.TiltRight": "Raised when the screen is pointing right",
|
||||||
"Gesture.TiltRight|block": "tilt right",
|
"Gesture.TiltRight|block": "tilt right",
|
||||||
"IconNames.Angry|block": "angry",
|
"IconNames.Angry|block": "angry",
|
||||||
|
"IconNames.ArrowEast|block": "arrow East",
|
||||||
|
"IconNames.ArrowNorthEast|block": "arrow north east",
|
||||||
|
"IconNames.ArrowNorthWest|block": "arrow north west",
|
||||||
|
"IconNames.ArrowNorth|block": "arrow north",
|
||||||
|
"IconNames.ArrowSouthEast|block": "arrow south east",
|
||||||
|
"IconNames.ArrowSouthWest|block": "arrow south west",
|
||||||
|
"IconNames.ArrowSouth|block": "arrow south",
|
||||||
|
"IconNames.ArrowWest|block": "arrow west",
|
||||||
"IconNames.Asleep|block": "asleep",
|
"IconNames.Asleep|block": "asleep",
|
||||||
"IconNames.Butterfly|block": "butterfly",
|
"IconNames.Butterfly|block": "butterfly",
|
||||||
"IconNames.Chessboard|block": "chess board",
|
"IconNames.Chessboard|block": "chess board",
|
||||||
@ -258,6 +266,7 @@
|
|||||||
"basic.rgbw|block": "red %red|green %green|blue %blue|white %white",
|
"basic.rgbw|block": "red %red|green %green|blue %blue|white %white",
|
||||||
"basic.setLedColor|block": "set led to %color=colorNumberPicker",
|
"basic.setLedColor|block": "set led to %color=colorNumberPicker",
|
||||||
"basic.showArrow|block": "show arrow %i=device_arrow",
|
"basic.showArrow|block": "show arrow %i=device_arrow",
|
||||||
|
"basic.showCompass|block": "show compass needle for $interval|ms",
|
||||||
"basic.showIcon|block": "show icon %i",
|
"basic.showIcon|block": "show icon %i",
|
||||||
"basic.showLeds|block": "show leds",
|
"basic.showLeds|block": "show leds",
|
||||||
"basic.showNumber|block": "show|number %number",
|
"basic.showNumber|block": "show|number %number",
|
||||||
@ -310,7 +319,6 @@
|
|||||||
"images.createBigImage|block": "create big image",
|
"images.createBigImage|block": "create big image",
|
||||||
"images.createImage|block": "create image",
|
"images.createImage|block": "create image",
|
||||||
"images.iconImage|block": "icon image %i",
|
"images.iconImage|block": "icon image %i",
|
||||||
"images.showCompass|block": "show compass needle for $interval|ms",
|
|
||||||
"images|block": "images",
|
"images|block": "images",
|
||||||
"input.acceleration|block": "acceleration (mg)|%NAME",
|
"input.acceleration|block": "acceleration (mg)|%NAME",
|
||||||
"input.buttonIsPressed|block": "button|%NAME|is pressed",
|
"input.buttonIsPressed|block": "button|%NAME|is pressed",
|
||||||
|
@ -229,7 +229,7 @@ let compassImagesDownside = [
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
namespace images {
|
namespace basic {
|
||||||
/**
|
/**
|
||||||
* Draws needle on the screen which always points to north
|
* Draws needle on the screen which always points to north
|
||||||
* @param interval the amount of time (milliseconds) to show the needle. Default is 600.
|
* @param interval the amount of time (milliseconds) to show the needle. Default is 600.
|
||||||
|
@ -122,5 +122,29 @@
|
|||||||
},
|
},
|
||||||
"scissors": {
|
"scissors": {
|
||||||
"icon": ""
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrownorth": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrownortheast": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arroweast": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrowsoutheast": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrowsouth": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrowsouthwest": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrowwest": {
|
||||||
|
"icon": ""
|
||||||
|
},
|
||||||
|
"arrownorthwest": {
|
||||||
|
"icon": ""
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -145,7 +145,31 @@ enum IconNames {
|
|||||||
SmallSquare,
|
SmallSquare,
|
||||||
//% block="scissors"
|
//% block="scissors"
|
||||||
//% jres=icons.scissors
|
//% jres=icons.scissors
|
||||||
Scissors
|
Scissors,
|
||||||
|
//% block="arrow north"
|
||||||
|
//% jres=icons.arrownorth
|
||||||
|
ArrowNorth,
|
||||||
|
//% block="arrow north east"
|
||||||
|
//% jres=icons.arrownortheast
|
||||||
|
ArrowNorthEast,
|
||||||
|
//% block="arrow East"
|
||||||
|
//% jres=icons.arroweast
|
||||||
|
ArrowEast,
|
||||||
|
//% block="arrow south east"
|
||||||
|
//% jres=icons.arrowsoutheast
|
||||||
|
ArrowSouthEast,
|
||||||
|
//% block="arrow south"
|
||||||
|
//% jres=icons.arrowsouth
|
||||||
|
ArrowSouth,
|
||||||
|
//% block="arrow south west"
|
||||||
|
//% jres=icons.arrowsouthwest
|
||||||
|
ArrowSouthWest,
|
||||||
|
//% block="arrow west"
|
||||||
|
//% jres=icons.arrowwest
|
||||||
|
ArrowWest,
|
||||||
|
//% block="arrow north west"
|
||||||
|
//% jres=icons.arrownorthwest
|
||||||
|
ArrowNorthWest
|
||||||
}
|
}
|
||||||
|
|
||||||
enum ArrowNames {
|
enum ArrowNames {
|
||||||
@ -164,7 +188,7 @@ enum ArrowNames {
|
|||||||
//% blockIdentity=images.arrowNumber block="West"
|
//% blockIdentity=images.arrowNumber block="West"
|
||||||
West,
|
West,
|
||||||
//% blockIdentity=images.arrowNumber block="North West"
|
//% blockIdentity=images.arrowNumber block="North West"
|
||||||
NorthWest,
|
NorthWest
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace basic {
|
namespace basic {
|
||||||
@ -199,6 +223,7 @@ namespace basic {
|
|||||||
//% parts="ledmatrix"
|
//% parts="ledmatrix"
|
||||||
//% advanced=true
|
//% advanced=true
|
||||||
//% help=basic/show-arrow
|
//% help=basic/show-arrow
|
||||||
|
//% deprecated=true
|
||||||
export function showArrow(direction: number, interval = 600) {
|
export function showArrow(direction: number, interval = 600) {
|
||||||
let res = images.arrowImage(direction)
|
let res = images.arrowImage(direction)
|
||||||
res.showImage(0, interval)
|
res.showImage(0, interval)
|
||||||
@ -528,6 +553,55 @@ namespace images {
|
|||||||
# # . # #
|
# # . # #
|
||||||
. # # # .
|
. # # # .
|
||||||
. . # . .`);
|
. . # . .`);
|
||||||
|
// arrows
|
||||||
|
case IconNames.ArrowNorth: return images.createImage(`
|
||||||
|
. . # . .
|
||||||
|
. # # # .
|
||||||
|
# . # . #
|
||||||
|
. . # . .
|
||||||
|
. . # . .`);
|
||||||
|
case IconNames.ArrowNorthEast: return images.createImage(`
|
||||||
|
. . # # #
|
||||||
|
. . . # #
|
||||||
|
. . # . #
|
||||||
|
. # . . .
|
||||||
|
# . . . .`);
|
||||||
|
case IconNames.ArrowEast: return images.createImage(`
|
||||||
|
. . # . .
|
||||||
|
. . . # .
|
||||||
|
# # # # #
|
||||||
|
. . . # .
|
||||||
|
. . # . .`);
|
||||||
|
case IconNames.ArrowSouthEast: return images.createImage(`
|
||||||
|
# . . . .
|
||||||
|
. # . . .
|
||||||
|
. . # . #
|
||||||
|
. . . # #
|
||||||
|
. . # # #`);
|
||||||
|
case IconNames.ArrowSouth: return images.createImage(`
|
||||||
|
. . # . .
|
||||||
|
. . # . .
|
||||||
|
# . # . #
|
||||||
|
. # # # .
|
||||||
|
. . # . .`);
|
||||||
|
case IconNames.ArrowSouthWest: return images.createImage(`
|
||||||
|
. . . . #
|
||||||
|
. . . # .
|
||||||
|
# . # . .
|
||||||
|
# # . . .
|
||||||
|
# # # . .`);
|
||||||
|
case IconNames.ArrowWest: return images.createImage(`
|
||||||
|
. . # . .
|
||||||
|
. # . . .
|
||||||
|
# # # # #
|
||||||
|
. # . . .
|
||||||
|
. . # . .`);
|
||||||
|
case IconNames.ArrowNorthWest: return images.createImage(`
|
||||||
|
# # # . .
|
||||||
|
# # . . .
|
||||||
|
# . # . .
|
||||||
|
. . . # .
|
||||||
|
. . . . #`);
|
||||||
default: return images.createImage(`
|
default: return images.createImage(`
|
||||||
. . . . .
|
. . . . .
|
||||||
. . . . .
|
. . . . .
|
||||||
|
Before Width: | Height: | Size: 699 B |
Before Width: | Height: | Size: 1014 B |
Before Width: | Height: | Size: 919 B |
Before Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 1.4 KiB |
Before Width: | Height: | Size: 1.2 KiB |
Before Width: | Height: | Size: 808 B |
Before Width: | Height: | Size: 1.0 KiB |
Before Width: | Height: | Size: 1.1 KiB |
BIN
libs/core/jres/icons/arroweast-icon.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
BIN
libs/core/jres/icons/arrownorth-icon.png
Normal file
After Width: | Height: | Size: 2.7 KiB |
BIN
libs/core/jres/icons/arrownortheast-icon.png
Normal file
After Width: | Height: | Size: 2.4 KiB |
BIN
libs/core/jres/icons/arrownorthwest-icon.png
Normal file
After Width: | Height: | Size: 2.3 KiB |
BIN
libs/core/jres/icons/arrowsouth-icon..png
Normal file
After Width: | Height: | Size: 2.7 KiB |
BIN
libs/core/jres/icons/arrowsoutheast-icon.png
Normal file
After Width: | Height: | Size: 2.4 KiB |
BIN
libs/core/jres/icons/arrowsouthwest-icon.png
Normal file
After Width: | Height: | Size: 2.3 KiB |
BIN
libs/core/jres/icons/arrowwest-icon.png
Normal file
After Width: | Height: | Size: 2.6 KiB |
@ -331,19 +331,23 @@
|
|||||||
"docMenu": [
|
"docMenu": [
|
||||||
{
|
{
|
||||||
"name": "Support",
|
"name": "Support",
|
||||||
"path": "https://calliope.cc/faq"
|
"path": "https://calliope.cc/en/impressum"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "Reference",
|
"name": "Reference",
|
||||||
"path": "/reference"
|
"path": "/about"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "Hardware",
|
"name": "Hardware",
|
||||||
"path": "/device"
|
"path": "https://calliope.cc/en/calliope-mini/tech-facts/"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "Buy",
|
"name": "Buy",
|
||||||
"path": "https://shop.calliope.cc/"
|
"path": "https://shop.calliope.cc/"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Forum",
|
||||||
|
"path": "https://forum.calliope.cc/"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"hasReferenceDocs": false,
|
"hasReferenceDocs": false,
|
||||||
@ -355,7 +359,7 @@
|
|||||||
"socialOptions": {
|
"socialOptions": {
|
||||||
"orgTwitterHandle": "calliopemini",
|
"orgTwitterHandle": "calliopemini",
|
||||||
"hashtags": "calliopemini",
|
"hashtags": "calliopemini",
|
||||||
"discourse": "https://forum.calliope.cc",
|
"discourse": "https://forum.calliope.cc/",
|
||||||
"discourseCategory": "Probleme-Software"
|
"discourseCategory": "Probleme-Software"
|
||||||
},
|
},
|
||||||
"blocklyOptions": {
|
"blocklyOptions": {
|
||||||
|
@ -211,7 +211,6 @@
|
|||||||
"tinysuperlab/motionkit",
|
"tinysuperlab/motionkit",
|
||||||
"tinysuperlab/touchkit",
|
"tinysuperlab/touchkit",
|
||||||
"calliope-edu/pxt-grove",
|
"calliope-edu/pxt-grove",
|
||||||
"Microsoft/pxt-neopixel",
|
|
||||||
"Microsoft/pxt-microturtle",
|
"Microsoft/pxt-microturtle",
|
||||||
"MKleinSB/pxt-OLED-SSD1306",
|
"MKleinSB/pxt-OLED-SSD1306",
|
||||||
"MKleinSB/pxt-iot-lora-node",
|
"MKleinSB/pxt-iot-lora-node",
|
||||||
@ -221,7 +220,7 @@
|
|||||||
"MKleinSB/pxt-dht11",
|
"MKleinSB/pxt-dht11",
|
||||||
"MKleinSB/pxt-esp-thingspeak",
|
"MKleinSB/pxt-esp-thingspeak",
|
||||||
"MKleinSB/pxt-neopixel-calliope",
|
"MKleinSB/pxt-neopixel-calliope",
|
||||||
"kittenbot/pxt-robotbit"
|
"Microsoft/pxt-neopixel"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"galleries": {
|
"galleries": {
|
||||||
|