diff --git a/docs/about.md b/docs/about.md new file mode 100644 index 00000000..52461817 --- /dev/null +++ b/docs/about.md @@ -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 +``` \ No newline at end of file diff --git a/docs/static/mb/device/calliope_website.jpg b/docs/static/mb/device/calliope_website.jpg new file mode 100644 index 00000000..413359ad Binary files /dev/null and b/docs/static/mb/device/calliope_website.jpg differ diff --git a/libs/core/_locales/core-jsdoc-strings.json b/libs/core/_locales/core-jsdoc-strings.json index d51a8d1b..2ef44769 100644 --- a/libs/core/_locales/core-jsdoc-strings.json +++ b/libs/core/_locales/core-jsdoc-strings.json @@ -257,6 +257,8 @@ "basic.showArrow": "Draws an arrow on the LED screen", "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.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|param|icon": "the predefined icon id", "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.createBigImage": "Creates an image with 2 frames.", "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.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", diff --git a/libs/core/_locales/core-strings.json b/libs/core/_locales/core-strings.json index a1c31820..fb0ea9f8 100644 --- a/libs/core/_locales/core-strings.json +++ b/libs/core/_locales/core-strings.json @@ -103,6 +103,14 @@ "Gesture.TiltRight": "Raised when the screen is pointing right", "Gesture.TiltRight|block": "tilt right", "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.Butterfly|block": "butterfly", "IconNames.Chessboard|block": "chess board", @@ -258,6 +266,7 @@ "basic.rgbw|block": "red %red|green %green|blue %blue|white %white", "basic.setLedColor|block": "set led to %color=colorNumberPicker", "basic.showArrow|block": "show arrow %i=device_arrow", + "basic.showCompass|block": "show compass needle for $interval|ms", "basic.showIcon|block": "show icon %i", "basic.showLeds|block": "show leds", "basic.showNumber|block": "show|number %number", @@ -310,7 +319,6 @@ "images.createBigImage|block": "create big image", "images.createImage|block": "create image", "images.iconImage|block": "icon image %i", - "images.showCompass|block": "show compass needle for $interval|ms", "images|block": "images", "input.acceleration|block": "acceleration (mg)|%NAME", "input.buttonIsPressed|block": "button|%NAME|is pressed", diff --git a/libs/core/compass.ts b/libs/core/compass.ts index 255fc8d1..ee01e1aa 100644 --- a/libs/core/compass.ts +++ b/libs/core/compass.ts @@ -229,7 +229,7 @@ let compassImagesDownside = [ -namespace images { +namespace basic { /** * Draws needle on the screen which always points to north * @param interval the amount of time (milliseconds) to show the needle. Default is 600. diff --git a/libs/core/icons.jres b/libs/core/icons.jres index 3e4e037d..5dde2472 100644 --- a/libs/core/icons.jres +++ b/libs/core/icons.jres @@ -122,5 +122,29 @@ }, "scissors": { "icon": "" + }, + "arrownorth": { + "icon": "" + }, + "arrownortheast": { + "icon": "" + }, + "arroweast": { + "icon": "" + }, + "arrowsoutheast": { + "icon": "" + }, + "arrowsouth": { + "icon": "" + }, + "arrowsouthwest": { + "icon": "" + }, + "arrowwest": { + "icon": "" + }, + "arrownorthwest": { + "icon": "" } } \ No newline at end of file diff --git a/libs/core/icons.ts b/libs/core/icons.ts index 00d82d33..686b900e 100644 --- a/libs/core/icons.ts +++ b/libs/core/icons.ts @@ -145,7 +145,31 @@ enum IconNames { SmallSquare, //% block="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 { @@ -164,7 +188,7 @@ enum ArrowNames { //% blockIdentity=images.arrowNumber block="West" West, //% blockIdentity=images.arrowNumber block="North West" - NorthWest, + NorthWest } namespace basic { @@ -199,6 +223,7 @@ namespace basic { //% parts="ledmatrix" //% advanced=true //% help=basic/show-arrow + //% deprecated=true export function showArrow(direction: number, interval = 600) { let res = images.arrowImage(direction) 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(` . . . . . . . . . . diff --git a/libs/core/jres/gestures/backsideup-icon.png b/libs/core/jres/gestures/backsideup-icon.png deleted file mode 100644 index 225d5cb3..00000000 Binary files a/libs/core/jres/gestures/backsideup-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/freefall-icon.png b/libs/core/jres/gestures/freefall-icon.png deleted file mode 100644 index 5b2bb2ed..00000000 Binary files a/libs/core/jres/gestures/freefall-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/frontsideup-icon.png b/libs/core/jres/gestures/frontsideup-icon.png deleted file mode 100644 index 074e7d3d..00000000 Binary files a/libs/core/jres/gestures/frontsideup-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/impact3g-icon.png b/libs/core/jres/gestures/impact3g-icon.png deleted file mode 100644 index 759d23ed..00000000 Binary files a/libs/core/jres/gestures/impact3g-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/impact6g-icon.png b/libs/core/jres/gestures/impact6g-icon.png deleted file mode 100644 index ca128d96..00000000 Binary files a/libs/core/jres/gestures/impact6g-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/impact8g-icon.png b/libs/core/jres/gestures/impact8g-icon.png deleted file mode 100644 index 7c70a7cd..00000000 Binary files a/libs/core/jres/gestures/impact8g-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/shake-icon.png b/libs/core/jres/gestures/shake-icon.png deleted file mode 100644 index 59e1dc43..00000000 Binary files a/libs/core/jres/gestures/shake-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/tiltforward-icon.png b/libs/core/jres/gestures/tiltforward-icon.png deleted file mode 100644 index 41d49270..00000000 Binary files a/libs/core/jres/gestures/tiltforward-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/tiltleft-icon.png b/libs/core/jres/gestures/tiltleft-icon.png deleted file mode 100644 index d119a15f..00000000 Binary files a/libs/core/jres/gestures/tiltleft-icon.png and /dev/null differ diff --git a/libs/core/jres/gestures/tiltright-icon.png b/libs/core/jres/gestures/tiltright-icon.png deleted file mode 100644 index 9f8308f8..00000000 Binary files a/libs/core/jres/gestures/tiltright-icon.png and /dev/null differ diff --git a/libs/core/jres/icons/arroweast-icon.png b/libs/core/jres/icons/arroweast-icon.png new file mode 100644 index 00000000..12df48e1 Binary files /dev/null and b/libs/core/jres/icons/arroweast-icon.png differ diff --git a/libs/core/jres/icons/arrownorth-icon.png b/libs/core/jres/icons/arrownorth-icon.png new file mode 100644 index 00000000..746fb33c Binary files /dev/null and b/libs/core/jres/icons/arrownorth-icon.png differ diff --git a/libs/core/jres/icons/arrownortheast-icon.png b/libs/core/jres/icons/arrownortheast-icon.png new file mode 100644 index 00000000..461d9773 Binary files /dev/null and b/libs/core/jres/icons/arrownortheast-icon.png differ diff --git a/libs/core/jres/icons/arrownorthwest-icon.png b/libs/core/jres/icons/arrownorthwest-icon.png new file mode 100644 index 00000000..91328afb Binary files /dev/null and b/libs/core/jres/icons/arrownorthwest-icon.png differ diff --git a/libs/core/jres/icons/arrowsouth-icon..png b/libs/core/jres/icons/arrowsouth-icon..png new file mode 100644 index 00000000..8d096464 Binary files /dev/null and b/libs/core/jres/icons/arrowsouth-icon..png differ diff --git a/libs/core/jres/icons/arrowsoutheast-icon.png b/libs/core/jres/icons/arrowsoutheast-icon.png new file mode 100644 index 00000000..8f86108c Binary files /dev/null and b/libs/core/jres/icons/arrowsoutheast-icon.png differ diff --git a/libs/core/jres/icons/arrowsouthwest-icon.png b/libs/core/jres/icons/arrowsouthwest-icon.png new file mode 100644 index 00000000..28c822bc Binary files /dev/null and b/libs/core/jres/icons/arrowsouthwest-icon.png differ diff --git a/libs/core/jres/icons/arrowwest-icon.png b/libs/core/jres/icons/arrowwest-icon.png new file mode 100644 index 00000000..6c26b00e Binary files /dev/null and b/libs/core/jres/icons/arrowwest-icon.png differ diff --git a/pxtarget.json b/pxtarget.json index 4bc23bd8..e9f5c693 100644 --- a/pxtarget.json +++ b/pxtarget.json @@ -331,19 +331,23 @@ "docMenu": [ { "name": "Support", - "path": "https://calliope.cc/faq" + "path": "https://calliope.cc/en/impressum" }, { "name": "Reference", - "path": "/reference" + "path": "/about" }, { "name": "Hardware", - "path": "/device" + "path": "https://calliope.cc/en/calliope-mini/tech-facts/" }, { "name": "Buy", "path": "https://shop.calliope.cc/" + }, + { + "name": "Forum", + "path": "https://forum.calliope.cc/" } ], "hasReferenceDocs": false, @@ -355,7 +359,7 @@ "socialOptions": { "orgTwitterHandle": "calliopemini", "hashtags": "calliopemini", - "discourse": "https://forum.calliope.cc", + "discourse": "https://forum.calliope.cc/", "discourseCategory": "Probleme-Software" }, "blocklyOptions": { diff --git a/targetconfig.json b/targetconfig.json index e6381c5f..b1e00213 100644 --- a/targetconfig.json +++ b/targetconfig.json @@ -211,7 +211,6 @@ "tinysuperlab/motionkit", "tinysuperlab/touchkit", "calliope-edu/pxt-grove", - "Microsoft/pxt-neopixel", "Microsoft/pxt-microturtle", "MKleinSB/pxt-OLED-SSD1306", "MKleinSB/pxt-iot-lora-node", @@ -221,7 +220,7 @@ "MKleinSB/pxt-dht11", "MKleinSB/pxt-esp-thingspeak", "MKleinSB/pxt-neopixel-calliope", - "kittenbot/pxt-robotbit" + "Microsoft/pxt-neopixel" ] }, "galleries": {