BBC micro:bit
The BBC micro:bit is a small microcontroller board designed for computer education in the UK - see the Wikipedia Article for more information.
There are multiple versions of the micro:bit available:
- micro:bit v2 - full-featured support with 2v08 and later (these are the ones with a speaker)
- micro:bit v1.5 - (cut-down Espruino, limited memory) to use the sensors you'll need 2v07 or later
- micro:bit v1 - (cut-down Espruino, limited memory) supported from Espruino 1v95
We are currently not using universal hex files, so you will need to load the
correct hex file (_microbit1
or _microbit2
) for your board.
micro:bit contains:
- USB communications and JST power connectors
- A 5x5 array of LEDs for use as a display
- Two user-configurable buttons, and one reset button
- An accelerometer and magnetometer (LSM303AGR, or MAG3110 + MMA8652 on older boards)
- Speaker & Microphone on v2
- A Nordic nRF52833 ARM Cortex-M4 microcontroller (512kB flash, 128kB RAM) on v2, or nRF51822 ARM Cortex-M0 microcontroller (256kB flash, 16kB RAM) on v1.
- A Freescale Kinetis chip to handle USB - this provides a virtual USB flash drive that allows firmware updates just by saving a file.
Contents
micro:bit v1
While we do provide Espruino for the micro:bit v1, it takes a lot of memory to provide Bluetooth functionality and as a result some functionality has had to be removed compared to the v2 and other Espruino devices:
- No ES6 Features (ArrayBuffer map/forEach, template literals, arrow functions, etc)
- No debug or code autocomplete
- No advanced library functions (In the reference, any function with the comment "Note: This is only available in some devices: not devices with low flash memory" will not be included)
- Low program memory (Espruino on micro:bit has only 350 vars available, whereas on other devices it has over 10 times that)
If you want the full experience, please consider buying an official Espruino Board.
Flashing Espruino
There is a build of Espruino designed specifically for the micro:bit. Releases are available from the Download page for micro:bit 1 or micro:bit 2 - however you may also download 'cutting edge' builds from here - these are updated every time something changes in Espruino's source code, so may occasionally not work.
To flash onto your micro:bit:
- Plug it into USB. A drive called
MICROBIT
should appear - Download the microbit
.hex
file for Espruino (ensuring that you have themicrobit1
ormicrobit2
file depending on your device), and save it directly into the root of that drive - The yellow LED on the micro:bit will blink quickly for a few seconds, and will then stop.
- The Espruino firmware is now installed!
Using the micro:bit
There are two ways to communicate with your micro:bit:
USB
This is the easiest, and recommended way of communicating with Espruino.
For Windows users, you will need to install drivers first - on other platforms, the board should 'just work'.
Follow the instructions in the Quick Start tutorial to install the Web IDE (ignore the Plugging in
section), and you should be able to communicate with the micro:bit just like any other board.
Note: as the micro:bit has a display but no general-purpose LEDs, the tutorials in the Quick Start that use LED1
/etc will not work without modification.
Bluetooth Low Energy (BT 4.0 / Bluetooth Smart)
You can also program the micro:bit wirelessly!
If you have a device that supports Web Bluetooth, you can go directly to the Online Web IDE in your web browser, and can connect with that.
- Click the connect icon at the top left
- Choose
Web Bluetooth
- if this doesn't exist, it's because your device doesn't have Web Bluetooth enabled. Click thestatus
link for more information. - Now you should be prompted for a device to connect to by the web browser
- Click it, and wait - connection can take around 10 seconds
- Finally the icon up the top left should change state to 'Connected', and you'll be able to program Espruino as normal - but via Bluetooth!
micro:bit Functionality
The micro:bit has a few variables and functions that are useful:
BTN1
and BTN2
These read the state of the two buttons, for example:
BTN1.read()
or digitalRead(BTN1)
return 1 or 0 depending on the state of the button
The following will write Pressed
each time the button is pressed:
setWatch(function() {
console.log("Pressed");
}, BTN1, {repeat:true, debounce:20, edge:"falling"});
Or this will write Pressed
or Released
:
setWatch(function(e) {
if (e.state) console.log("Released");
else console.log("Pressed");
}, BTN1, {repeat:true, debounce:20, edge:"both"});
Note: Currently the state of the buttons is inverted - 1
means not pressed, 0
means pressed.
show(bitmap)
Shows graphics on the built-in 5x5 LED screen. This takes a binary number or a string. For example:
show(0)
shows nothingshow(1)
lights the first LEDshow(0b1000)
lights the fourth LEDshow(0b1111111111111111111111111)
orshow(0x1FFFFFF)
lights all LEDs- The following will draw a smiley face:
show("1 1\n"+
" 1 \n"+
" 1 \n"+
"1 1\n"+
" 111 \n");
`
You can use the Graphics library to display text and images, for example the following with scroll 'Espruino' across the display:
g = Graphics.createArrayBuffer(5,5,1);
g.flip = function(){show(this.buffer);};
var x = 0;
setInterval(function() {
x++;
if (x>50)x=0;
g.clear();
g.drawString("Espruino",5-x);
g.flip();
}, 100);
Microbit
class
This contains functions for interfacing with the Micro:bit hardware. See a full reference here
Note: In 2v07
and earlier the Microbit
class doesn't exist and instead there are just acceleration()
and compass()
functions.
Microbit.accel()
This returns an object with x
, y
, and z
elements, each containing the force in that axis in g
.
Note: In 2v07
and earlier this doesn't exist and acceleration()
is available instead.
You can also use Microbit.accelOn()
which then creates an event whenever data is available, which can be read with Microbit.on('accel', function(d) { ... })
Microbit.mag()
This returns an object with x
, y
, and z
elements, indicating the current direction of the magnetic field
Note: In 2v07
and earlier this doesn't exist and compass()
is available instead.
Microbit.play(waveform, samplesPerSecond, callback)
Micro:bit version 2 only: plays a sound - see the reference for more information
Microbit.record(samplesPerSecond, callback, samples)
Micro:bit version 2 only: records a sound - see the reference](http://www.espruino.com/Reference#l_Microbit_record) for more information
Pinout
Hover the mouse over a pin function for more information. Clicking in a function will tell you how to use it in Espruino.
- Purple boxes show pins that are used for other functionality on the board. You should avoid using these unless you know that the marked device is not used.
- ! boxes contain extra information about the pin. Hover your mouse over them to see it.
- 3.3v boxes mark pins that are not 5v tolerant (they only take inputs from 0 - 3.3v, not 0 - 5v).
- 3.3 is a 3.3v output from the on-board Voltage regulator.
- GND is ground (0v).
- ADC is an Analog to Digital Converter (for reading analog voltages)
- SPI is the 3 wire Serial Peripheral Interface.
- USART is a 2 wire peripheral for Serial Data.
- I2C is the 2 wire Inter-Integrated Circuit bus.
Tutorials
Tutorials using the micro:bit Board:
Tutorials using Bluetooth LE:
data:image/s3,"s3://crabby-images/44475/44475c9be703c508028cc0a9712a29cad945fbce" alt="BTHome Library BTHome Library"
data:image/s3,"s3://crabby-images/c198c/c198cfcaa063e6fab2edc08f9bd213b32d1b7a86" alt="Bluetooth LE Printers Bluetooth LE Printers"
data:image/s3,"s3://crabby-images/fb5b6/fb5b6a95bda46da5119501994d28dd4fc4b15d24" alt="Bluetooth LE Emoji Advertising Bluetooth LE Emoji Advertising"
data:image/s3,"s3://crabby-images/b58de/b58de9e775fac2f8f09ffeced8eec578a8bab973" alt="Battery Monitor Battery Monitor"
data:image/s3,"s3://crabby-images/18a3b/18a3b8c236394b1450ed1df88ad61e7376d8fde5" alt="LEGO Power Functions Clone Remote Control (Mould King M-0006 / Kaiyu / Bandra / AKOGD / MayD / etc) LEGO Power Functions Clone Remote Control (Mould King M-0006 / Kaiyu / Bandra / AKOGD / MayD / etc)"
data:image/s3,"s3://crabby-images/3c5a7/3c5a7aa3d6d65306956a9d0e98516fdc4e85fd27" alt="Tilt Hydrometer Repeater Tilt Hydrometer Repeater"
data:image/s3,"s3://crabby-images/d369e/d369e136ca278b4d93b552b671f68039cb4e7c74" alt="Quick Start (Bluetooth LE) Quick Start (Bluetooth LE)"
data:image/s3,"s3://crabby-images/51d9b/51d9b2f7eab946a18f9b4e165d39ac9f1c8f7546" alt="BLE Advertising with Node.js/Python/C#/Android BLE Advertising with Node.js/Python/C#/Android"
data:image/s3,"s3://crabby-images/dab6d/dab6da417369724f46aa23dc76d72f99649023af" alt="Automatic Data Download Automatic Data Download"
data:image/s3,"s3://crabby-images/0014e/0014e802bfff173d476c63d4e93c4f1cf68811ca" alt="Puck.js to GCP BigQuery & Data Studio Puck.js to GCP BigQuery & Data Studio"
data:image/s3,"s3://crabby-images/6fa90/6fa9011dd10c7cb722de6ab19ef77e854db3e284" alt="Stream from Puck.js to AWS IOT Core & SNS Email Stream from Puck.js to AWS IOT Core & SNS Email"
data:image/s3,"s3://crabby-images/3a97a/3a97aae16f01b44020c0e732547adc266b9b2bfe" alt="Bluetooth LE UARTs (NUS) Bluetooth LE UARTs (NUS)"
data:image/s3,"s3://crabby-images/f8c68/f8c6899b39fc2f98287b6a6c8250ae470b0240d7" alt="Bluetooth LE HID Keyboards Bluetooth LE HID Keyboards"
data:image/s3,"s3://crabby-images/5ea24/5ea24a55093b794125cadb762a5507305895901f" alt="Bluetooth LE Security and Access Control Bluetooth LE Security and Access Control"
data:image/s3,"s3://crabby-images/c90b9/c90b9a3a1e47104bb74809e7508459d53f5c906e" alt="Bluetooth LE MIDI Bluetooth LE MIDI"
data:image/s3,"s3://crabby-images/7de30/7de3045f44b4c2b5bb4a16d0362a9bc92e0359b2" alt="Web Bluetooth on Linux Web Bluetooth on Linux"
data:image/s3,"s3://crabby-images/bb3f0/bb3f0c49f906ef449993d17c698505d37fb912ec" alt="Bluetooth Time Setter Bluetooth Time Setter"
data:image/s3,"s3://crabby-images/7ec17/7ec17880c6988e7660c4b2df3026ba7786345be2" alt="Using Web Bluetooth with Espruino Using Web Bluetooth with Espruino"
data:image/s3,"s3://crabby-images/42638/42638e91ee732bab9dc2958d4ba56f0b76da2e06" alt="Bluetooth LE and If This Then That Bluetooth LE and If This Then That"
data:image/s3,"s3://crabby-images/12616/12616f9de963095a9196d1420166649dc1287a4b" alt="UART.js Library UART.js Library"
data:image/s3,"s3://crabby-images/7c7fc/7c7fc2220f08273b2289fc2a94701b66afa75a03" alt="iBeacons iBeacons"
data:image/s3,"s3://crabby-images/da05a/da05ab3228614a14b83c5593e05e55b6c313dc74" alt="Eddystone Beacons Eddystone Beacons"
data:image/s3,"s3://crabby-images/b1a43/b1a4370062d14ae8a2f6f34430c524295cbafedf" alt="Bluetooth LE and Node-RED with MQTT Bluetooth LE and Node-RED with MQTT"
data:image/s3,"s3://crabby-images/0797f/0797fccb46efe71b82996e8bf1df6d00801747ad" alt="Bluetooth Music Controller Bluetooth Music Controller"
data:image/s3,"s3://crabby-images/15885/15885c9abac555fa6bbae318d5f7d168c03e3a62" alt="Controlling Bluetooth Lights with Puck.js Controlling Bluetooth Lights with Puck.js"
data:image/s3,"s3://crabby-images/b1a36/b1a36e99d345f21d8a5f5c125db16f13c1077ae3" alt="Bluetooth LE HTTP Proxies Bluetooth LE HTTP Proxies"
data:image/s3,"s3://crabby-images/46553/46553636a8fe8ef7eb756586d133f87bc84ddb3a" alt="Exercise Machine controlled Video Exercise Machine controlled Video"
data:image/s3,"s3://crabby-images/58482/584821f1a9ea87f48344e8c4f62a2981c42640b5" alt="BLE Communications BLE Communications"
data:image/s3,"s3://crabby-images/85c5c/85c5c183f6e9b41d0c50a461f89ea306b319d7ef" alt="About Bluetooth LE (BLE) About Bluetooth LE (BLE)"
data:image/s3,"s3://crabby-images/a970b/a970bf0b96f2e622141c124978767a605ff5ebe7" alt="Puck.js with SMS control Puck.js with SMS control"
data:image/s3,"s3://crabby-images/459cf/459cf12a47d71ad36ba3e3035f1ac26d3048a33e" alt="Pixl.js SMS Remote Monitoring Pixl.js SMS Remote Monitoring"
data:image/s3,"s3://crabby-images/78896/788967bb8891745d22ac040c1aefa739390a27a0" alt="Web IDE on a Raspberry Pi Web IDE on a Raspberry Pi"
data:image/s3,"s3://crabby-images/f85e7/f85e724df3fbf90eb5b168efd97704bef1deaf3b" alt="Puck.js Bluetooth with the Graphical Editor Puck.js Bluetooth with the Graphical Editor"
data:image/s3,"s3://crabby-images/5861a/5861a9641b686a6cc26a3110a12c23a9a6a29a86" alt="Controlling Other BLE Espruino Devices Controlling Other BLE Espruino Devices"
data:image/s3,"s3://crabby-images/dbb7d/dbb7d896a1c397de0de9417db3f3a82e571d6f0a" alt="Pixl.js Simple Logger Pixl.js Simple Logger"
data:image/s3,"s3://crabby-images/daa80/daa809d2c26cf05ed198ce66c200efa711981c61" alt="Pixl.js Multiplayer Pong Game Pixl.js Multiplayer Pong Game"
data:image/s3,"s3://crabby-images/e79b8/e79b8b0be6555de213e6251b9b4ca7a1d5ad9a27" alt="Pixl.js Bluetooth to Ethernet MQTT Bridge Pixl.js Bluetooth to Ethernet MQTT Bridge"
data:image/s3,"s3://crabby-images/bfc75/bfc75439714bf8ffa22aea60b9cb1401d29b55e2" alt="BLE Characteristic Scan BLE Characteristic Scan"
data:image/s3,"s3://crabby-images/bfc75/bfc75439714bf8ffa22aea60b9cb1401d29b55e2" alt="LED BLE Library LED BLE Library"
data:image/s3,"s3://crabby-images/bfc75/bfc75439714bf8ffa22aea60b9cb1401d29b55e2" alt="Bluefruit LE app interface Bluefruit LE app interface"
Tutorials using Bluetooth LE and functionality that may not be part of the micro:bit:
data:image/s3,"s3://crabby-images/a3985/a398564839309c5bd038152daa91328f29d51062" alt="Water Level Monitor Water Level Monitor"
data:image/s3,"s3://crabby-images/7d954/7d9545cfb2e27c99bdb8344ebac8ef2a4b5f76f8" alt="Puck.js Vibration Sensor Puck.js Vibration Sensor"
data:image/s3,"s3://crabby-images/f11fd/f11fd48d53bff40d0be153a94f37fd599ebff526" alt="DIY Smart Meter DIY Smart Meter"
data:image/s3,"s3://crabby-images/80226/802264bcf8838664a2556d39f706fe334586f4dc" alt="BTHome Door Sensor for Home Assistant BTHome Door Sensor for Home Assistant"
data:image/s3,"s3://crabby-images/af2c4/af2c4176c59c13f044ef57cc68a46194a3d977f6" alt="BTHome and Home Assistant Setup BTHome and Home Assistant Setup"
data:image/s3,"s3://crabby-images/2f1db/2f1dbd0a8e86794321f4a91c7ea3c0aa28010a7c" alt="Pixl.js Wireless Temperature Display Pixl.js Wireless Temperature Display"
data:image/s3,"s3://crabby-images/1f245/1f2453adea5e066ef577a72de2794eac5d0b6971" alt="Turning an Espruino Puck.js Into a Universal Presentation Clicker Turning an Espruino Puck.js Into a Universal Presentation Clicker"
data:image/s3,"s3://crabby-images/780f8/780f8c007fdf07762f2b17b5566a3789de9e667a" alt="Interfacing to a PC Interfacing to a PC"
data:image/s3,"s3://crabby-images/6b52a/6b52a230dcc542ba7b460bcd66afc7821adba44b" alt="Controlling Espruino from Tensorflow on the Desktop Controlling Espruino from Tensorflow on the Desktop"
data:image/s3,"s3://crabby-images/5453d/5453d36db5b07a4720bec100dab4f0b34c05c789" alt="Bookmarklets with Web Bluetooth Bookmarklets with Web Bluetooth"
data:image/s3,"s3://crabby-images/8bb04/8bb04f3a5c19d9aafc8c48e51f709a25ff9800f8" alt="Bangle.js Data Streaming Bangle.js Data Streaming"
data:image/s3,"s3://crabby-images/5cd2b/5cd2b657dfea2dd82e4ae907a8a8d95a8ff15ec1" alt="Puckmote - Universal Remote Control Puckmote - Universal Remote Control"
data:image/s3,"s3://crabby-images/a2b5c/a2b5cce584dea7e8991ec5e63667558412da5892" alt="IoT for Kitchen Gardens IoT for Kitchen Gardens"
data:image/s3,"s3://crabby-images/4ced5/4ced50b5e5aeabec22b9547ba14b8dbb2fe42572" alt="Time Machine Retro-Inspired Smartwatch Time Machine Retro-Inspired Smartwatch"
data:image/s3,"s3://crabby-images/43b9c/43b9cd7eeae646910b5a8be2b02f6e2b199f9ae1" alt="Talos, Keeping You Safe During Your Commute Talos, Keeping You Safe During Your Commute"
data:image/s3,"s3://crabby-images/13c0c/13c0c52cbdd0ac89d1e3376fef5ff015eaa2f21c" alt="Bluetooth Energy Usage Monitor Bluetooth Energy Usage Monitor"
data:image/s3,"s3://crabby-images/bac48/bac48c5965f44d2a8040fc812221665526976776" alt="Electric Skateboard Controller Electric Skateboard Controller"
data:image/s3,"s3://crabby-images/85d5b/85d5be7a4e74397144375cdeaf4fb6fa51e6f320" alt="Wooden Bluetooth Remote for Lego Duplo Train Wooden Bluetooth Remote for Lego Duplo Train"
data:image/s3,"s3://crabby-images/82171/82171ace4c1be4724ca161e9846bf1a57bf219fb" alt="Puck.js Control from Android using DroidScript Puck.js Control from Android using DroidScript"
data:image/s3,"s3://crabby-images/ab103/ab103b2990d0d8dd7dbe84f2a9a01c28396b302b" alt="Ikea Eneby Speaker Controller Ikea Eneby Speaker Controller"
data:image/s3,"s3://crabby-images/0102d/0102d7ecbf93f27b48b53348b7646fd5f6bfa28c" alt="Pixl.js Wireless Weather Station Pixl.js Wireless Weather Station"
data:image/s3,"s3://crabby-images/1dba8/1dba8a37317525320a23c52dd055eb15caa88ac9" alt="Temperature Controlled Night Light with Puck.js Temperature Controlled Night Light with Puck.js"
data:image/s3,"s3://crabby-images/18031/1803124fd58d36d236a041adf8ffa5f70a8d3328" alt="Infrared Record and Playback with Puck.js Infrared Record and Playback with Puck.js"
data:image/s3,"s3://crabby-images/87007/87007a797f212002b781ac4dc450e47e962523ab" alt="Door Controlled Light with Puck.js Door Controlled Light with Puck.js"
data:image/s3,"s3://crabby-images/be655/be655ed42b1b2e01c63be649d033a4d2ec2e3975" alt="Freezer Alarm Freezer Alarm"
Buying
micro:bits are currently available to buy all over the world.
Official Espruino Boards
This page is auto-generated from GitHub. If you see any mistakes or have suggestions, please let us know.