/NeoBit

KiCad files for a board that lets you hook up NeoPixels to a BBC micro:bit. The board also has a couple of slide potentiometers for input.

Creative Commons Attribution Share Alike 4.0 InternationalCC-BY-SA-4.0

neo:bit

The neo:bit is a board which attaches to the edge connector of the BBC micro:bit and provides:

  • Two slide potentiometers, connected to micro:bit pins P1 and P2, which can be read as analog inputs.

  • A terminal block for connecting "NeoPixels" (WS-2812 LEDs), with a level shifter to convert from 3.3V logic (on pin P16) to 5V logic.

  • A terminal block for connecting "DotStars" (APA-102 LEDs), with a level shifter to convert from 3.3V logic (on pins P13 and P15) to 5V logic.

  • A Qwiic connector for attaching I2C peripherals.

  • A 3.5mm audio jack for headphones. (Connected to pin P0).

  • A barrel connector for an external 5-12V power supply, which is mandatory for powering the NeoPixels, and can also optionally backpower the micro:bit safely.

This repository contains KiCad and gerber files for the neo:bit board.

neo:bit board

Usage

Power

Note that the voltage which comes in on the barrel jack is used directly to power the NeoPixels and DotStars, so you need to choose a voltage which is appropriate for the NeoPixels and/or DotStars you are using. Most NeoPixels are 5V, although there are a few 12V ones. I don't know of any DotStars which are not 5V. You can't have a different voltage for the NeoPixels and the DotStars.

The neo:bit contains a low-dropout 3.3V voltage regulator, which is used for back-powering the micro:bit, and for supplying the 3.3V power on the Qwiic connector. You probably shouldn't draw more than 90 mA on the Qwiic connector's power pin.

The neo:bit also contains a low-dropout 5V voltage regulator, but that is just to supply the 5V signal on the NeoPixel and DotStar data lines.

Potentiometers

To read the slide potentiometers, just configure P1 and P2 as analog inputs, and read them. The idea is that you could use these inputs to control your NeoPixel animation, such as the speed, color, or brightness.

NeoPixels

J4 has the NeoPixel output, along with +V and GND. You may want to connect a JST-SM pigtail to the J4 screw terminals. This will let you connect strings of 5V NeoPixels, such as ones from Alitove or Wesiri, or my chainable NeoPixel butterflies. (The Wesiri lights come with the necessary pigtail, so you don't need to buy one separately.)

You must have an external power supply (such as this one or this one for 5V, or this one for 12V) connected to the neo:bit's barrel jack in order to power the NeoPixels. If the external power supply is connected, the neo:bit will also supply 3.3V back to the micro:bit, so it is not necessary to power the micro:bit from another source. (However, this is done with a protection diode, so it is OK to have the micro:bit connected to another source at the same time the external supply is connected.) If you only want to use the potentiometers and/or Qwiic but not the NeoPixel output or DotStar output, then you do not need to have an external supply connected, as long as the micro:bit is powered by another source.

Following the NeoPixel best practices, the neo:bit includes a 470 ohm resistor on the NeoPixel data line, and there is a 1000µF capacitor on the +V power line.

Once you have your NeoPixels hooked up, you should be able to access them by instantiating a NeoPixel strip on pin P16 in either MakeCode or Python. The Alitove and Wesiri strings, as well as my NeoPixel butterflies, use RGB order instead of the default GRB order.

example MakeCode program

Qwiic

I have an example for how to use the Qwiic Keypad, and another example for how to use the Qwiic Joystick.

Ordering the Board

You can order this board directly from OSH Park without needing to upload anything.

Or, if you prefer to go with another fab like Elecrow or JLCPCB, all you need to do is zip up the files in the gerber directory, and upload that zip file to the fab.

If you want to modify the design, the source is provided in KiCad format.

Bill of Materials

Ref Description MPN Digi-Key PN
C1 CAP ALUM 1000UF 20% 25V RADIAL 25PX1000MEFCT810X16 1189-1583-1-ND
C2 CAP CER 0.1UF 50V X7R RADIAL K104K10X7RF5UH5 BC2665CT-ND
C3-C6 CAP CER 1UF 50V Y5V RADIAL K105Z20Y5VF5TH5 BC1168CT-ND
C7 CAP ALUM 47UF 20% 16V RADIAL ECE-A1CKS470 P969-ND
C8, C9 CAP ALUM 220UF 20% 10V RADIAL UVK1A221MDD1TD 493-7455-1-ND
C10 CAP CER 10000PF 50V X7R RADIAL K103K15X7RF5TL2 BC1078CT-ND
D1 DIODE SCHOTTKY 20V 1A DO41 1N5817 1N5817FSCT-ND
J1 CONN JACK STEREO 3.5MM R/A SJ1-3533NG CP1-3533NG-ND
J2 CONN PWR JACK 2X5.5MM SOLDER PJ-063AH CP-063AH-ND
J3 Qwiic JST Connector - SMD 4-pin PRT-14417 (SparkFun)
J4 TERM BLOCK 4POS SIDE ENT 3.5MM 1776275-4 A98038-ND
J5 micro:bit through-hole right-angle edge connector 3342 (Adafruit)
J6 TERM BLOCK 3POS SIDE ENT 3.5MM 1776275-3 A98037-ND
R1 RES 100 OHM 1/4W 5% AXIAL CF14JT100R CF14JT100RCT-ND
R2 RES 470 OHM 1/4W 5% AXIAL CF14JT470R CF14JT470RCT-ND
R3 RES 22 OHM 1/4W 5% AXIAL CF14JT22R0 CF14JT22R0CT-ND
RV1, RV2 SLIDE POT 10K OHM 0.25W TOP 45MM PTA4553-2015CPB103 PTA4553-2015CPB103-ND
U1 IC BUF NON-INVERT 5.5V 14DIP SN74AHCT125N 296-4655-5-ND
U2 IC REG LINEAR 3.3V 250MA TO92-3 MCP1702-3302E/TO MCP1702-3302E/TO-ND
U3 IC REG LINEAR 5V 250MA TO92-3 MCP1702-5002E/TO MCP1702-5002E/TO-ND
(qty 2) KNOB SMOOTH 0.157 X 0.039" NYLON 1300-E [1722-1329-ND][61]

Plus you'll need a micro:bit, a power supply (such as this one), and some NeoPixels.

The right-angle micro:bit edge connector (J5) is 4UCON 10156, which is available from Adafruit in the US and from Cool Components in the UK.

Assembly

Most of the assembly should be straightforward, but there are a few connectors worthy of more discussion.

Qwiic connector

The four electrical pins are not enough to hold this connector in place. There are two mounting pins which are also meant to be soldered, but I found hand-soldering them was nearly impossible. So, I used a drop of epoxy to hold the Qwiic connector in place.

Terminal blocks

I've found that stranded wires don't stay in the terminal blocks very well, so I recommend using solid wire. Or, you may wish to omit the terminal blocks entirely and solder wires directly to the board.

micro:bit connector

The micro:bit connector has 80 pins, but only 40 of them need to be soldered. The pins that need to be soldered are the two rows farthest from the edge. (These pins are slightly taller than the others.) I usually solder just a few of the pins on the row closest to the edge, too, just for mechanical stability.

neo:bit edge connector

License

The files in this repo are licensed under CC-BY-SA 4.0.

Some symbols and footprints in this repo are under different licenses:

neo:bit with string of LEDs neo:bit with Qwiic keypad and joystick