# Adafruit QT Py ESP32 Pico

## Overview

![](https://cdn-learn.adafruit.com/assets/assets/000/111/953/medium800/adafruit_products_QTP_top.jpg?1653428809)

This development board is like when you're watching a super-hero movie and the protagonist shows up in a totally amazing costume in the third act and you're like 'OMG! That's the hero and they're here to kick some serious butt!" but in this case it's a microcontroller.

This QT Py board is a thumbnail-sized PCB that features the **ESP32-Pico-V3-02** , an all-in-one chip that has an **ESP32 chip with dual-core 240MHz Tensilica processor** , **WiFi** and **Bluetooth classic + BLE** , adds a bunch of required passives and oscillator, **8 MB of Flash memory** and **2 MB of PSRAM**. We add a USB to serial converter chip, some more passives, an antenna, USB C, buttons, NeoPixel and QT connector to outfit this super-hero chip for any task you want to throw it at.

![](https://cdn-learn.adafruit.com/assets/assets/000/111/954/medium800/adafruit_products_QTP_back.jpg?1653428818)

At the core of ESP32-PICO-V3-02 is the ESP32 (ECO V3) chip, which is a single 2.4 GHz Wi-Fi and Bluetooth combo chip designed with TSMC’s 40 nm low-power technology. ESP32-PICO-V3-02 integrates all peripheral components seamlessly, including a crystal oscillator, flash, PSRAM, filter capacitors, and RF matching links in one single package. This makes it perfect for stuffing into such a small space as the QT Py.

**Please note&nbsp;** the QT Py&nbsp;ESP32 Pico does not have native USB support - instead there's a USB to serial converter chip. This means it _cannot_ act like a USB keyboard or mouse - but it does have BLE and BT classic so you could do wireless.

![](https://cdn-learn.adafruit.com/assets/assets/000/111/955/medium800/adafruit_products_QTP_STEMMA_side.jpg?1653428834)

[OLEDs](https://www.adafruit.com/?q=qt+oled&main_page=category&cPath=1005&sort=BestMatch)!&nbsp;[Inertial Measurement Units](https://www.adafruit.com/?q=qt+imu&main_page=category&cPath=1005&sort=BestMatch)!&nbsp;[Sensors a-plenty](https://www.adafruit.com/?q=qt+sensor&main_page=category&cPath=1005&sort=BestMatch). All plug-and-play thanks to the innovative chainable design:&nbsp;[SparkFun Qwiic](https://www.sparkfun.com/qwiic)-compatible&nbsp;[STEMMA QT](https://learn.adafruit.com/introducing-adafruit-stemma-qt)&nbsp;connectors for the I2C bus so you don't even need to solder! Just plug in a compatible cable and attach it to your MCU of choice, and you’re ready to load up some software and measure some light.&nbsp;[Seeed Grove I2C boards](https://www.adafruit.com/product/4528)&nbsp;will also work with this adapter cable.

The pinout and shape are [Seeed Xiao](https://wiki.seeedstudio.com/Seeeduino-XIAO/) compatible, with castellated, solderable pads. In addition to the QT connector, we also added an **RGB NeoPixel** &nbsp;(with controllable power pin to allow for ultra-low-power usage),&nbsp; **a reset button** (great for restarting your program&nbsp;or entering the bootloader), and a button on GPIO 0 for entering the ROM bootloader or for user input.

This board runs Arduino like a dream, or use the ESP IDF for more control over your projects.

![](https://cdn-learn.adafruit.com/assets/assets/000/111/956/medium800/adafruit_products_QTP_top_header.jpg?1653428846)

- Same size, form-factor, and pin-out as Seeed Xiao
- **USB Type C connector&nbsp;** -&nbsp;[If you have only Micro B cables, this adapter will come in handy](https://www.adafruit.com/product/4299)!
- **ESP32-V2-03 Dual Core 240MHz Xtensa processor** - the ESP32 you know and love, with the latest engineering fixes. Massive user base and thousands of existing projects and libraries to use.
- WiFi, Bluetooth LE and Classic for any IoT project usage
- **8 MB Flash & 2 MB PSRAM**
- USB to Serial converter built in with high speed UART for debugging and uploading.
- Can be used with&nbsp; **Arduino IDE** &nbsp;or **MicroPython**
- **Built-in RGB NeoPixel LED** &nbsp;with power control to reduce quiescent power in deep sleep
- Battery input pads on underside with diode protection for external battery packs up to 6V input
- **13&nbsp;GPIO pins:**
  - 11 on breakout pads, 2 more on QT connector
  - 10 x 12-bit analog inputs
  - Dual 8-bit analog output DACs on A0/A1
  - PWM outputs on any pin
  - Two I2C ports, one on the breakout pads, and another&nbsp;with STEMMA QT plug-n-play connector
  - Hardware UART in addition to the USB-serial UART
  - Hardware SPI on the high speed SPI peripheral pins
  - Hardware I2S on any pins
  - 8 x Capacitive Touch with no additional components required

- 3.3V regulator with&nbsp;[**600mA peak output**](https://www.diodes.com/assets/Datasheets/AP2112.pdf)
- Light sleep at 4mA, deep sleep at ~70uA
- **Reset switch&nbsp;** for starting your project code over, boot 0 button for entering bootloader mode or for user reading
- **Really really small**

![](https://cdn-learn.adafruit.com/assets/assets/000/111/957/medium800/adafruit_products_QTP_USB_side.jpg?1653428856)

# Adafruit QT Py ESP32 Pico

## Pinouts

![](https://cdn-learn.adafruit.com/assets/assets/000/111/960/medium800/adafruit_products_QTP_pinouts_guide.jpg?1653430996)

The Adafruit QT Py ESP32 Pico is jam-packed with pins, connectors and buttons. This page covers all the features!

![](https://cdn-learn.adafruit.com/assets/assets/000/112/309/medium800/adafruit_products_Adafruit_QT_Py_ESP32-Pico_Pinout.png?1654628457)

PrettyPins PDF [on GitHub](https://github.com/adafruit/Adafruit-QT-Py-ESP32-Pico-PCB/blob/main/Adafruit%20QT%20Py%20ESP32-Pico%20Pinout.pdf).

## Power
- **USB-C port** - This is used for both powering and programming the board. You can power it with any USB C cable.
- **3.3V** - This pin is the output from the 3.3V regulator, it can supply 600mA peak.
- **GND** - This is the common ground for all power and logic.
- **5V** - This is 5V out from the USB port.&nbsp;

![adafruit_products_QTP_power.jpg](https://cdn-learn.adafruit.com/assets/assets/000/111/964/medium640/adafruit_products_QTP_power.jpg?1653431377)

**You can also use the 5V pin as a voltage _input_ but you must have some sort of diode (schottky, signal, power, really anything) between your external power source and this pin with anode to battery, cathode to 5V pin.** Note that you cannot power the USB port by supplying 5V to this pin: there is a protection diode that prevents the 5V from reaching the USB connector. This is to protect host computer USB ports, etc. You can draw 1A peak through the diode, but we recommend keeping it lower than that, about 500mA.

 **VBAT**  **pads** - On the back of the board are two pads labeled + and - (ground). These are the battery input pads with diode protection for external battery packs from 3V to 6V input.

![adafruit_products_QTP_VBAT.jpg](https://cdn-learn.adafruit.com/assets/assets/000/111/965/medium640/adafruit_products_QTP_VBAT.jpg?1653431796)

## ESP32 Module
The **ESP32-Pico-V3-02** is an all-in-one chip that has an **ESP32 chip with dual-core 240MHz Tensilica processor** , **WiFi** and **Bluetooth classic + BLE** , as well as **8 MB of Flash memory** and **2 MB of PSRAM.**

![adafruit_products_QTP_ESP32.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/055/medium640/adafruit_products_QTP_ESP32.jpg?1653503478)

At the core of ESP32-PICO-V3-02 is the ESP32 (ECO V3) chip, which is a single 2.4 GHz Wi-Fi and Bluetooth combo chip designed with TSMC’s 40 nm low-power technology. ESP32-PICO-V3-02 integrates all peripheral components seamlessly, including a crystal oscillator, flash, PSRAM, filter capacitors, and RF matching links in one single package. The 8 MB of flash is inside the chip and is used for **both** program firmware and filesystem storage.&nbsp;

The ESP32-Pico is an ideal choice for a wide variety of application scenarios relating to the [Internet of Things (IoT)](https://www.adafruit.com/category/342), [wearable electronics](https://www.adafruit.com/category/65), and smart homes.&nbsp;

## Logic Pins
There are eleven GPIO pins broken out to pads. There is hardware I2C, UART, and SPI.

Ten pads are 12-bit analog inputs.

You can do PWM output or hardware I2S on any pin.

There are eight pins (A2, A3, SCL, SDA, TX, MOSI, MISO, SCK) that can do capacitive touch without any external components needed.

![adafruit_products_QTP_GPIO.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/059/medium640/adafruit_products_QTP_GPIO.jpg?1653505257)

That's the general overview. Now for the details!

There are four analog pins.

- **A0 and A1** are the only DAC output pins. These can be used as 8-bit true analog outputs. No other pins can do so. These pins can also be analog inputs. A0 and A1 are on ADC2.
- **A2 and A3** can also be analog inputs. A2 and A3 are on ADC2. These two pins can do capacitive touch.

The I2C pins. **These are NOT shared by the STEMMA QT connector!**

- **SCL** - This is the I2C clock pin. There is _no_ pull-up on this pin, so for I2C please add an external pull-up if the breakout doesn't have one already. This pin can do capacitive touch and also analog input
- **SDA** - This is the I2C data pin.There is _no_ pull-up on this pin, so for I2C please add an external pull-up if the breakout doesn't have one already. This pin can do capacitive touch and also analog input

The UART interface.

- **RX** - This is the UART receive pin. Connect to TX (transmit) pin on your sensor or breakout.
- **TX** - This is the UART transmit pin. Connect to RX (receive) pin on your sensor or breakout. This pin can do capacitive touch.

The SPI pins are on the ESP32 high-speed peripheral. You can set any pins to be the low-speed peripheral but you won't get the speedy interface!

- **SCK** - This is the SPI clock pin. This pin can do capacitive touch.
- **MI** - This is the SPI **M** icrocontroller **I** n / **S** ensor **O** ut pin. This pin can do capacitive touch.
- **MO** - This is the SPI **M** icrocontroller **O** ut / **S** ensor **I** n pin. This pin can do capacitive touch.

## STEMMA QT Connector
This **JST SH 4-pin [STEMMA QT](https://learn.adafruit.com/introducing-adafruit-stemma-qt) connector** breaks out a second I2C interface (SCL1, SDA1, 3.3V, GND). It allows you to connect to [various breakouts and sensors with **STEMMA QT** connectors](https://www.adafruit.com/category/1018) or to other things using&nbsp;[assorted associated accessories](https://www.adafruit.com/?q=JST%20SH%204). It works great with any STEMMA QT or Qwiic sensor/device. You can also use it with Grove I2C devices thanks to [this handy cable](https://www.adafruit.com/product/4528).

![adafruit_products_QTP_STEMMA_QT.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/079/medium640/adafruit_products_QTP_STEMMA_QT.jpg?1653585124)

The STEMMA QT connector IO pins in Arduino are `19` (SCL1) and `22` (SDA1) and are available on `Wire1`.

## NeoPixel LED
- Above the SCK and MI on the silk, is the **RGB NeoPixel LED**. This addressable LED can be controlled with code. It is available in Arduino as `PIN_NEOPIXEL`.
- There is a **&nbsp;** `NEOPIXEL_POWER` **power pin** that is pulled high in Arduino by default. It is necessary for the NeoPixel to work. This is so it can be fully de-powered for low power usage.

![adafruit_products_QTP_NeoPixel.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/080/medium640/adafruit_products_QTP_NeoPixel.jpg?1653585308)

## Buttons
- **Reset button** - This button restarts the board and helps enter the bootloader. You can click it once to reset the board without unplugging the USB cable or battery.
- **BOOT button** - This button can be read in code as `SWITCH` or GPIO 0 (set it to be an input-with-pullup). 

![adafruit_products_QTP_buttons.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/081/medium640/adafruit_products_QTP_buttons.jpg?1653585838)

Both buttons combined can be used to enter the _ROM bootloader_. To enter ROM bootloader mode, press and continue to hold down the BOOT button while tapping the reset button. When in the ROM bootloader, you can upload code and query the chip using `esptool`.

## CH9102 USB-to-Serial Converter
The **CH9102F USB to serial converter** can handle 50bps to 4Mbps max rate.

![adafruit_products_QTP_CH9102.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/090/medium640/adafruit_products_QTP_CH9102.jpg?1653598043)

Info: 

## CP2102 USB-to-Serial Converter
The **CP2102N USB to serial**  **converter** can handle 3 mbps max rate.

![adafruit_products_QTP_CP2102N.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/083/medium640/adafruit_products_QTP_CP2102N.jpg?1653587202)

# Adafruit QT Py ESP32 Pico

## Low Power Usage

This microcontroller board can be used for low power usage thanks to the ESP32's multiple sleep modes.

There are three basic operating states to Espressif chips: normal, light sleep and deep sleep.

**Normal power** usage is as you expect: you can use the chip and run code as you like - connecting to WiFi, reading sensors, etc.

**Light sleep** is sort of a 'hibernation' - power usage is minimal and WiFi is disconnected, but the internal clock and memory is kept. That means you can wake up where you left off, in the middle of the code as desired. You'll still need to re-initialize any external hardware that got disconnected, and WiFi, but it's often faster than waking from a deep sleep

**Deep sleep** is the lowest power but the tradeoff is that all memory and state is lost - the only thing that's running is the real time clock that can wake the chip up. When woken up, the chip starts as if it was physically reset - from the beginning of the code. This can be beneficial if you want to have a fresh start each time

A _rough_ guideline is:

- Normal power: 100mA+ can be as much power as need and spike during WiFi connection
- Light sleep: 2mA assuming all external hardware is de-powered
- Deep sleep: 100uA assuming all external hardware is de-powered

There is a NeoPixel power pin available to cut power to the NeoPixel if desired.

Here's a generic sketch we use for all our boards that has a macro-defined section for enabling and disabling all external powered elements. For example, if there's a power pin for NeoPixels, I2C port, TFT, etc...we turn that off before going into light or deep sleep! This will minimize power usage

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/Adafruit_ESP32_Arduino_Demos/ESP32_sleeptest/ESP32_sleeptest.ino

The best way to really test power draw is with a specialty power meter such as the Nordic PPK 2

### Nordic nRF-PPK2 - Power Profiler Kit II

[Nordic nRF-PPK2 - Power Profiler Kit II](https://www.adafruit.com/product/5048)
The **Power Profiler Kit II** &nbsp;is a standalone unit, which can measure and optionally supply currents all the way from sub-uA and as high as 1A on all Nordic DKs, in addition to external hardware. [As we've featured on...](https://www.youtube.com/watch?v=60q8QCiYhjc)

In Stock
[Buy Now](https://www.adafruit.com/product/5048)
[Related Guides to the Product](https://learn.adafruit.com/products/5048/guides)
![Angled shot of Nordic nrF Power Profiler board.](https://cdn-shop.adafruit.com/640x480/5048-00.jpg)

When running the above code and monitoring with a PPK, you'll get a graph like this:

![](https://cdn-learn.adafruit.com/assets/assets/000/109/375/medium800/low_power_esp32_qtpy_esp32pico_sleepcycle.png?1645930315)

The big pulse is normal mode, you can see the ESP32 booting up, loading code, and then pausing 1 second. Then there's a big drop for one sec to light sleep, and finally one more 1 second pause at deep sleep.

## Power Draw for QT Py ESP32 Pico

The following graphs show the power draw for the QT Py ESP32 Pico in normal power mode, light sleep mode, and deep sleep mode.

### Normal Mode
![](https://cdn-learn.adafruit.com/assets/assets/000/112/298/medium800/adafruit_products_qtpy_esp32_pico_normalop.png?1654622988)

The power draw, running normally, is 45.5mA.

### Light Sleep
![](https://cdn-learn.adafruit.com/assets/assets/000/112/299/medium800/adafruit_products_qtpy_esp32_pico_lightsleep.png?1654622998)

The power draw in light sleep mode is 2mA.

### Deep Sleep
![](https://cdn-learn.adafruit.com/assets/assets/000/112/300/medium800/adafruit_products_qtpy_esp32_pico_deepsleep.png?1654623009)

The power draw in deep sleep is 73.5uA.

# Adafruit QT Py ESP32 Pico

## Arduino IDE Setup

You need to install the right USB-to-serial driver for your chip in addition to the Arduino IDE. If you are unsure which is the right one, install both!

### Install Arduino IDE

The first thing you will need to do is to download the latest release of the Arduino IDE. You will need to&nbsp;be using&nbsp; **version 1.8** &nbsp;or higher for this guide

[Arduino IDE Download](http://www.arduino.cc/en/Main/Software)
### Install CP2104 / CP2102N USB Driver

The USB-to-Serial converter that talks to the ESP32 chip itself will need a driver on your computer's operating system. The driver is available for Mac and Windows. It is already built into Linux.

[Click here to download the CP2104 USB Driver](http://www.silabs.com/products/development-tools/software/usb-to-uart-bridge-vcp-drivers)
### Install CH9102 / CH34X USB Driver

Newer ESP32 boards have a different USB-to-serial converter that talks to the chip itself, and will need a driver on your computer's operating system. The driver is available for Mac and Windows. It is already built into Linux.

If you would like more detail, check out [the guide on installing these drivers](https://learn.adafruit.com/how-to-install-drivers-for-wch-usb-to-serial-chips).

[Click here to download the Windows driver](http://www.wch-ic.com/downloads/CH341SER_ZIP.html)
[Click here to download the Mac driver](http://www.wch-ic.com/downloads/CH34XSER_MAC_ZIP.html)
### Install ESP32 Board Support Package

After you have downloaded and installed **&nbsp;the latest version of Arduino IDE** , you will need to start the IDE&nbsp;and navigate to&nbsp;the&nbsp; **Preferences** &nbsp;menu. You can access it from the&nbsp; **File** &nbsp;menu in&nbsp;_Windows_&nbsp;or&nbsp;_Linux_, or the&nbsp; **Arduino** &nbsp;menu on&nbsp;_OS X_.

![](https://cdn-learn.adafruit.com/assets/assets/000/101/639/medium800/esp32_s2_arduino_ide_setup_flora_prefs.png?1618870383)

A dialog will pop up just like the one shown below.

![](https://cdn-learn.adafruit.com/assets/assets/000/101/640/medium800/esp32_s2_arduino_ide_setup_flora_Screen_Shot_2015-05-07_at_9.07.21_AM.png?1618870405)

We will be adding a URL to the new&nbsp; **Additional Boards Manager URLs** &nbsp;option. The list of URLs is comma separated, and&nbsp;_you will only have to add each&nbsp;URL once._&nbsp;New Adafruit boards and updates to existing boards&nbsp;will automatically be picked up&nbsp;by the Board Manager each time&nbsp;it is opened. The URLs point to index files that the Board Manager uses to build the list of available & installed boards.

To find the most up to date list of URLs you can&nbsp;add, you can visit the list of&nbsp;[third party board URLs on the Arduino IDE wiki](https://github.com/arduino/Arduino/wiki/Unofficial-list-of-3rd-party-boards-support-urls#list-of-3rd-party-boards-support-urls). We will only need to add one URL to the IDE in this example, but&nbsp;_ **you can add multiple URLS by separating them with commas** _. Copy and paste the link below into the&nbsp; **Additional Boards Manager URLs** &nbsp;option in the Arduino IDE preferences.

`https://raw.githubusercontent.com/espressif/arduino-esp32/gh-pages/package_esp32_dev_index.json`

![](https://cdn-learn.adafruit.com/assets/assets/000/101/641/medium800/esp32_s2_arduino_ide_setup_Screen_Shot_2021-04-19_at_3.14.19_PM.png?1618870509)

If you have multiple boards you want to support, say ESP8266 and Adafruit, have both URLs in the text box separated by a comma (,)

Once done click&nbsp; **OK** &nbsp;to save the new preference settings.

The next step is to actually install the Board Support Package (BSP). Go to the **Tools → Board → Board Manager** &nbsp;submenu. A dialog should come up with various BSPs. Search for **esp32**.

![](https://cdn-learn.adafruit.com/assets/assets/000/107/162/medium800/esp32_s2_arduino_ide_setup_Screen_Shot_2021-12-09_at_9.58.40_AM.png?1639072797)

Click the **Install** button and wait for it to finish. Once it is finished, you can close the dialog.

In the **Tools → Board** submenu you should see **ESP32 Arduino** and in that dropdown it should contain the ESP32 boards along with all the latest ESP32 boards.

Look for the board called Adafruit QT Py ESP32.

![](https://cdn-learn.adafruit.com/assets/assets/000/112/089/medium800/adafruit_products_QTP_Arduino_choose_board.png?1653596988)

The upload speed can be changed: faster speed makes uploads take less time but sometimes can cause upload issues. **921600** should work fine, but if you're having issues, you can drop down lower.

# Adafruit QT Py ESP32 Pico

## Blink

The first and most basic program you can upload to your Arduino is the classic Blink sketch. This takes something on the board and makes it, well, blink! On and off. It's a great way to make sure everything is working and you're uploading your sketch to the right board and right configuration.

When all else fails, you can always come back to Blink!

Now _traditionally_ you would use an onboard LED to make a blink occur. **However, this board does not have an onboard single-color LED** , so we will 'mimic' the same blink sketch but instead of using a digital output pin, we will use NeoPixel support to blink the onboard RGB LED!

![](https://cdn-learn.adafruit.com/assets/assets/000/122/514/medium800thumb/adafruit_products_QTP_Arduino_Blink.jpg?1689191129)

# Pre-Flight Check: Get Arduino IDE & Hardware Set Up

This lesson assumes you have Arduino IDE set up. This is a generalized checklist, some elements may not apply to your hardware. If you haven't yet, check the previous steps in the guide to make sure you:

- **Install the very latest Arduino IDE for Desktop** (not all boards are supported by the Web IDE so we don't recommend it)
- **Install any board support packages (BSP) required for your hardware.** Some boards are built in defaults on the IDE, but lots are not! You may need to install plug-in support which is called the BSP.
- **Get a Data/Sync USB cable for connecting your hardware.** A _significant_ amount of problems folks have stem from not having a USB cable with data pins. Yes, these cursed cables roam the land, making your life hard. If you find a USB cable that doesn't work for data/sync, _throw it away immediately_! There is no need to keep it around, cables are very inexpensive these days.
- **Install any drivers required** - If you have a board with a FTDI or CP210x chip, you may need to get separate drivers. If your board has native USB, it probably doesn't need anything. After installing, reboot to make sure the driver sinks in.
- **Connect the board to your computer.** If your board has a power LED, make sure its lit. Is there a power switch? Make sure its turned On!

There is a NeoPixel power pin which must be pulled high to enable the NeoPixel LED.

The QT Py ESP32 Pico does not have a power LED.

# Start up Arduino IDE and Select Board/Port

OK, now you are prepared! Open the Arduino IDE on your computer. Now you have to tell the IDE what board you are using, and how you want to connect to it.

In the IDE find the **Tools** menu. You will use this to select the board. If you switch boards, you _must switch the selection!_ So always double-check before you upload code in a new session.

![](https://cdn-learn.adafruit.com/assets/assets/000/122/516/medium800/adafruit_products_QTP_Arduino_Tools_menu.png?1689191258)

# Install NeoPixel Library

Despite their popularity, NeoPixel RGB LEDs are not supported 'out of the box' in Arduino IDE! You will need to add support by installing the library. Good news it is _very easy_ to do it. Go to the **Library Manager** here

![](https://cdn-learn.adafruit.com/assets/assets/000/107/534/medium800/arduino_neopixel_blink_installlib.png?1640487409)

Search for and install the **Adafruit NeoPixel** library. It might not be first in the list so make sure you get the name matched up right!

![](https://cdn-learn.adafruit.com/assets/assets/000/107/535/medium800/arduino_neopixel_blink_neolib.png?1640487504)

# New NeoPixel Blink Sketch

OK lets make a new blink sketch! From the **File** menu, select **New**

![](https://cdn-learn.adafruit.com/assets/assets/000/107/498/medium800/blink__image.png?1640454932)

Then in the new window, copy and paste this text:

```auto
#include &lt;Adafruit_NeoPixel.h&gt;

// How many internal neopixels do we have? some boards have more than one!
#define NUMPIXELS        1

Adafruit_NeoPixel pixels(NUMPIXELS, PIN_NEOPIXEL, NEO_GRB + NEO_KHZ800);

// the setup routine runs once when you press reset:
void setup() {
  Serial.begin(115200);

#if defined(NEOPIXEL_POWER)
  // If this board has a power control pin, we must set it to output and high
  // in order to enable the NeoPixels. We put this in an #if defined so it can
  // be reused for other boards without compilation errors
  pinMode(NEOPIXEL_POWER, OUTPUT);
  digitalWrite(NEOPIXEL_POWER, HIGH);
#endif

  pixels.begin(); // INITIALIZE NeoPixel strip object (REQUIRED)
  pixels.setBrightness(20); // not so bright
}

// the loop routine runs over and over again forever:
void loop() {
  // say hi
  Serial.println("Hello!");
  
  // set color to red
  pixels.fill(0xFF0000);
  pixels.show();
  delay(500); // wait half a second

  // turn off
  pixels.fill(0x000000);
  pixels.show();
  delay(500); // wait half a second
}
```

Info: 

One note you'll see is that we reference the LED with the constant `PIN_NEOPIXEL` rather than a number. That's because each board could have the built in NeoPixels on a different pin and this makes the code a little more portable!

The NeoPixel LED is on pin 5. The NeoPixel power pin is on pin 8.

# Verify (Compile) Sketch

OK now you can click the Verify button to convert the sketch into binary data to be uploaded to the board.

Note that Verifying a sketch is the same as Compiling a sketch - so these terms will be used interchangeably.

![](https://cdn-learn.adafruit.com/assets/assets/000/107/533/medium800/arduino_neopixel_blink_compile.png?1640487310)

During verification/compilation, the computer will do a bunch of work to collect all the libraries and code and the results will appear in the bottom window of the IDE.

![](https://cdn-learn.adafruit.com/assets/assets/000/107/500/medium800/blink__image.png?1640455335)

If something went wrong with compilation, you will get red warning/error text in the bottom window letting you know what the error was. It will also highlight the line with an error.

For example, here I had the wrong board selected - and the selected board does not have a built-in NeoPixel pin defined!

![](https://cdn-learn.adafruit.com/assets/assets/000/107/536/medium800/arduino_neopixel_blink_deferr.png?1640487615)

Here's another common error, in my haste I forgot to add a `;` at the end of a line. The compiler warns me that it's looking for one - note that the error is actually a few lines up!

![](https://cdn-learn.adafruit.com/assets/assets/000/107/537/medium800/arduino_neopixel_blink_semi.png?1640487755)

Info: 

On success you will see something like this white text output and the message **Done compiling.** in the message area.

![](https://cdn-learn.adafruit.com/assets/assets/000/107/504/medium800/blink__image.png?1640455995)

# Upload Sketch

Once the code is verified/compiling cleanly you can upload it to your board. Click the **Upload** button:

![](https://cdn-learn.adafruit.com/assets/assets/000/107/538/medium800/arduino_neopixel_blink_upload.png?1640487820)

The IDE will try to compile the sketch again for good measure, then it will try to connect to the board and upload a the file.

**This is actually one of the hardest parts for beginners because it's where a lot of things can go wrong.**

However, start with what it looks like: success! Here's what your board upload process looks like when it goes right:

![](https://cdn-learn.adafruit.com/assets/assets/000/122/517/medium800/adafruit_products_QTP_Arudino_NeoPixel_success.png?1689191327)

Often times you will get a warning like this, which is kind of vague:

`No device found on COM66` (or whatever port is selected)  
`An error occurred while uploading the sketch```

![](https://cdn-learn.adafruit.com/assets/assets/000/107/505/medium800/blink__image.png?1640456582)

This could be a few things.

**Check again that you have the correct board selected!** Many electronics boards have very similar names or look, and often times folks grab a board different from what they thought.

Then give it another try!

# Finally, a Blink!

OK it was a journey but now we're here and you can enjoy your blinking LED. Next up, try to change the delay between blinks and re-upload. It's a good way to make sure your upload process is smooth and practiced.

![](https://cdn-learn.adafruit.com/assets/assets/000/122/518/medium800thumb/adafruit_products_QTP_Arduino_Blink.jpg?1689191342)

# Adafruit QT Py ESP32 Pico

## I2C Scan Test

A lot of sensors, displays, and devices can connect over I2C. I2C is a 2-wire 'bus' that allows multiple devices to all connect on one set of pins so it's very convenient for wiring!

When using your board, you'll probably want to connect up I2C devices, and it can be a little tricky the first time. The best way to debug I2C is go through a checklist and then perform an I2C scan

# Common I2C Connectivity Issues

- **Have you connected four wires (at a minimum) for each I2C device?** Power the device with whatever is the logic level of your microcontroller board (probably 3.3V), then a ground wire, and a SCL clock wire, and and a SDA data wire.
- **If you're using a STEMMA QT board - check if the power LED is lit.** It's usually a green LED to the left side of the board.
- **Does the STEMMA QT/I2C port have switchable power or pullups?** To reduce power, some boards have the ability to cut power to I2C devices or the pullup resistors. Check the documentation if you have to do something special to turn on the power or pullups.
- **If you are using a DIY I2C device, do you have pullup resistors?** Many boards do _not_ have pullup resistors built in and they are _required!_ We suggest any common 2.2K to 10K resistors. You'll need two: one each connects from SDA to positive power, and SCL to positive power. Again, positive power (a.k.a VCC, VDD or V+) is often 3.3V
- **Do you have an address collision?** You can only have _one_ board per address. So you cannot, say, connect two AHT20's to one I2C port because they have the same address and will interfere. Check the sensor or documentation for the address. Sometimes there are ways to adjust the address.
- **Does your board have multiple I2C ports?** Historically, boards only came with one. But nowadays you can have two or even three! This can help solve the "hey, but what if I want two devices with the same address" problem: just put one on each bus.
- **Are you hot-plugging devices?** I2C does _not_ support dynamic re-connection, you cannot connect and disconnect sensors as you please. They should all be connected on boot and not change. ([Only exception is if you're using a hot-plug assistant but that'll cost you](https://www.adafruit.com/product/5159)).
- **Are you keeping the total bus length reasonable?** I2C was designed for maybe 6" max length. We like to push that with plug-n-play cables, but really please keep them as short as possible! ([Only exception is if you're using an active bus extender](https://www.adafruit.com/product/4756)).

The QT Py ESP32 Pico has two I2C ports. One port is on the SCL/SDA pin pads. The second port is on the STEMMA QT connector which is available as SCL1/SDA1.

# Perform an I2C scan!

### Install TestBed Library

To scan I2C, the Adafruit TestBed library is used. This library and example just makes the scan a little easier to run because it takes care of some of the basics. You will need to add support by installing the library. Good news: it is _very easy_ to do it. Go to the **Arduino Library Manager.**

![](https://cdn-learn.adafruit.com/assets/assets/000/107/555/medium800/i2c_scan_test_installlib.png?1640562425)

Search for **TestBed** and install the **Adafruit TestBed** library

![](https://cdn-learn.adafruit.com/assets/assets/000/107/556/medium800/i2c_scan_test_testbedlib.png?1640562581)

Now open up the I2C Scan example

![](https://cdn-learn.adafruit.com/assets/assets/000/107/557/medium800/i2c_scan_test_i2cscan.png?1640562632)

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/I2C_Scanners/arduino/i2c_scanner/i2c_scanner.ino

### Wire up I2C device

While the examples here will be using the [Adafruit MCP9808](https://www.adafruit.com/product/5027), a high accuracy temperature sensor, the overall process is the same for just about any I2C sensor or device.

The first thing you'll want to do is get the sensor connected so your board has I2C to talk to.

### Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout

[Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout](https://www.adafruit.com/product/5027)
The MCP9808 digital temperature sensor is one of the more accurate/precise we've ever seen, with a typical accuracy of ±0.25°C over the sensor's -40°C to +125°C range and precision of +0.0625°C. They work great with any microcontroller using standard I2C. With...

Out of Stock
[Buy Now](https://www.adafruit.com/product/5027)
[Related Guides to the Product](https://learn.adafruit.com/products/5027/guides)
![Top view of temperature sensor breakout above an OLED display FeatherWing. The OLED display reads "MCP9808 Temp: 24.19ºC"](https://cdn-shop.adafruit.com/640x480/5027-04.jpg)

### STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long

[STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long](https://www.adafruit.com/product/4399)
This 4-wire cable is&nbsp;50mm / 1.9" long and fitted with JST SH female 4-pin connectors on both ends. Compared with the chunkier JST PH these are 1mm pitch instead of 2mm, but still have a nice latching feel, while being easy to insert and remove.

<a...></a...>

In Stock
[Buy Now](https://www.adafruit.com/product/4399)
[Related Guides to the Product](https://learn.adafruit.com/products/4399/guides)
![Angled of of JST SH 4-Pin Cable.](https://cdn-shop.adafruit.com/640x480/4399-00.jpg)

## Wiring the MCP9808

The MCP9808 comes with a STEMMA QT connector, which makes wiring it up quite simple and solder-free.

Simply plug a **STEMMA QT to STEMMA QT cable** into **the port on the QT Py** , and **a port on the MCP9808 breakout**.

![adafruit_products_QTP_MCP9808_bb.jpg](https://cdn-learn.adafruit.com/assets/assets/000/112/301/medium640/adafruit_products_QTP_M%10CP9808_bb.jpg?1654624033)

Now upload the scanning sketch to your microcontroller and open the serial port to see the output. You should see something like this:

![](https://cdn-learn.adafruit.com/assets/assets/000/112/303/medium800/adafruit_products_QTP_I2C_scan_Arduino.png?1654624346)

# Adafruit QT Py ESP32 Pico

## WiFi Test

Thanksfully if you have ESP32 sketches, they'll 'just work' with variations of ESP32. You can find a wide range of examples in the **File-\>Examples-\>Examples for Adafruit Metro ESP32-S2** subheading (the name of the board may vary so it could be **"Examples for Adafruit Feather ESP32 V2"** etc)

![](https://cdn-learn.adafruit.com/assets/assets/000/097/028/medium800/adafruit_products_image.png?1605222761)

Let's start by scanning the local networks.

**Load up the WiFiScan example** under **Examples-\>Examples for YOUR BOARDNAME-\>WiFi-\>WiFiScan**

![](https://cdn-learn.adafruit.com/assets/assets/000/096/993/medium800/adafruit_products_Screen_Shot_2020-11-11_at_12.28.51_PM.png?1605115789)

And **upload this example to your board**. The ESP32 should scan and find WiFi networks around you.

For ESP32, open the serial monitor, to see the scan begin.

For ESP32-S2, -S3 and -C3, don't forget you have to click Reset after uploading through the ROM bootloader. Then select the new USB Serial port created by the ESP32. It will take a few seconds for the board to complete the scan.

![](https://cdn-learn.adafruit.com/assets/assets/000/097/029/medium800/adafruit_products_image.png?1605223012)

If you can not scan any networks, check your power supply. You need a solid power supply in order for the ESP32 to not brown out. A skinny USB cable or drained battery can cause issues.

## WiFi Connection Test

Now that you can scan networks around you, its time to connect to the Internet!

Copy the example below and paste it into the Arduino IDE:

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/ESP32_S2_WiFi_Tests/WiFiWebClient/WiFiWebClient.ino

 **NOTE:** You must **change the `SECRET_SSID` and `SECRET_PASS` in the example code to your WiFi SSID and password** before uploading this to your board.

![](https://cdn-learn.adafruit.com/assets/assets/000/097/030/medium800/adafruit_products_image.png?1605223125)

After you've set it correctly, upload and check the serial monitor. You should see the following. If not, go back, check wiring, power and your SSID/password

![](https://cdn-learn.adafruit.com/assets/assets/000/097/009/medium800/adafruit_products__dev_cu_usbmodem14101.png?1605127946)

## Secure Connection Example

Many servers today do not allow non-SSL connectivity. Lucky for you the ESP32 has a great TLS/SSL stack so you can have that all taken care of for you. Here's an example of a using a secure WiFi connection to connect to the Twitter API.

Copy and paste it into the Arduino IDE:

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/ESP32_S2_WiFi_Tests/WiFiSSLClient/WiFiSSLClient.ino

As before, **update the ssid and password first** , then upload the example to your board.

Note we use `WiFiClientSecure client` instead of `WiFiClient client;` to require a SSL connection!&nbsp;

![](https://cdn-learn.adafruit.com/assets/assets/000/097/010/medium800/adafruit_products__dev_cu_usbmodem14101.png?1605128497)

# Adafruit QT Py ESP32 Pico

## WipperSnapper Setup

Warning: 

## What is WipperSnapper

WipperSnapper is a firmware designed to turn any WiFi-capable board into an Internet-of-Things device without programming a single line of code. WipperSnapper connects to [Adafruit IO](https://io.adafruit.com/), a web&nbsp;platform designed ([by Adafruit!](https://www.adafruit.com/about)) to&nbsp;_display_,&nbsp;_respond_, and&nbsp;_interact_&nbsp;with your project's data.

Simply load the WipperSnapper firmware onto your board, add credentials, and plug it into power. Your board will automatically register itself with your Adafruit IO account.

From there, you can add&nbsp;_components_&nbsp;to your board such as buttons, switches, potentiometers, sensors, and more! Components are&nbsp;_dynamically&nbsp;_added to hardware, so you can&nbsp;immediately start interacting, logging, and streaming the data your projects produce without writing code.

## Sign up for Adafruit.io

You will need an Adafruit IO account to use WipperSnapper on your board. If you do not already have one, head over to [io.adafruit.com](https://io.adafruit.com/) to create a&nbsp;_free_ account.

## Install USB Driver

### Install CP2104 / CP2102N USB Driver

Many ESP32 boards have a USB-to-Serial converter that talks to the chip itself, and will need a driver on your computer's operating system. The driver is available for Mac, Windows, and Linux.

[Click here to download the CP2104/CP2102N driver](http://www.silabs.com/products/development-tools/software/usb-to-uart-bridge-vcp-drivers)
### Install CH9102 / CH34X USB Driver

Newer ESP32 boards have a different USB-to-serial converter that talks to the chip itself, and will need a driver on your computer's operating system. The driver is available for Mac and Windows. It is already built into Linux.

If you would like more detail, check out&nbsp;[the guide on installing these drivers](https://learn.adafruit.com/how-to-install-drivers-for-wch-usb-to-serial-chips).

[Click here to download the Windows driver](http://www.wch-ic.com/downloads/CH341SER_ZIP.html)
[Click here to download the Mac driver](http://www.wch-ic.com/downloads/CH34XSER_MAC_ZIP.html)
## Add a New Device to Adafruit IO

Log into your [Adafruit IO](https://io.adafruit.com/) account. Click the _New Device_ button at the top of the page.

![](https://cdn-learn.adafruit.com/assets/assets/000/112/548/medium800/wippersnapper_setup__board_selector__web__new_device_1.png?1655919766)

After clicking New Device, you should be on the _board selector_ page. This page displays every board that is compatible with the WipperSnapper firmware.

![](https://cdn-learn.adafruit.com/assets/assets/000/112/550/medium800/wippersnapper_setup__board_selector__web__selector_maion.png?1655920178)

In the board selector page's search bar, search for the _QT Py ESP32 Pico__.&nbsp;_Once you've located the board you'd like to install WipperSnapper on,_&nbsp;_click the&nbsp;_Choose Board_&nbsp;button to bring you to the self-guided installation wizard.

![](https://cdn-learn.adafruit.com/assets/assets/000/113/136/medium800/adafruit_products_qtpy_32_pico.png?1657648825)

Follow the step-by-step instructions on the page to install Wippersnapper on your device and connect it to Adafruit IO.

![](https://cdn-learn.adafruit.com/assets/assets/000/120/541/medium800/adafruit_products_qtpy_esp32_ss.png?1682710491)

If the installation was successful, a popover should appear displaying that your board has successfully been detected by Adafruit IO.

Give your board a name and click "Continue to Device Page".

![](https://cdn-learn.adafruit.com/assets/assets/000/113/138/medium800/adafruit_products_qtpy_pico.png?1657648851)

You should be brought to your board's device page.

![](https://cdn-learn.adafruit.com/assets/assets/000/113/139/medium800/adafruit_products_qtpy_32_pico_device_page.png?1657648859)

## Feedback

Adafruit.io WipperSnapper is in **beta** and you can help improve it!

If you have&nbsp; suggestions or general feedback about the installation process - visit [https://io.adafruit.com/support](https://io.adafruit.com/support), click _"Contact Adafruit IO Support"_ and select _"I have feedback or suggestions for the WipperSnapper Beta"._

## Troubleshooting

If you encountered an issue during installation, please try the steps below first.

If you're still unable to resolve the issue, or if your issue is not listed below, get in touch with us directly at [https://io.adafruit.com/support](https://io.adafruit.com/support "https://io.adafruit.com/support"). Make sure to click&nbsp; _"Contact Adafruit IO Support"_ and select "_There is an issue with WipperSnapper. Something is broken!"_

### 

First, make sure that you selected the correct board on the board selector.

Next, please make sure that you entered your WiFi credentials properly, there are no spaces/special characters in either your network name (SSID) or password, and that you are connected to a 2.4GHz wireless network.

If you're still unable to connect your board to WiFi, please [make a new post on the WipperSnapper technical support forum with the error you're experiencing, the LED colors which are blinking, and the board you're using.](https://forums.adafruit.com/viewforum.php?f=66)

### 

Try hard-resetting your board by unplugging it from USB power and plugging it back in.

If the error is still occurring, please&nbsp;[make a new post on the WipperSnapper technical support forum with information about what you're experiencing, the LED colors which are blinking (if applicable), and the board you're using.](https://forums.adafruit.com/viewforum.php?f=66)

## "Uninstalling" WipperSnapper&nbsp;

WipperSnapper firmware is an application that is loaded onto your board. There is nothing to "uninstall". However, you may want to "move" your board from running WipperSnapper to running Arduino or CircuitPython. You also may need to restore your board to the state it was shipped to you from the Adafruit factory.&nbsp;

### Moving from WipperSnapper to CircuitPython

Follow the steps on the [Installing CircuitPython page](https://learn.adafruit.com/welcome-to-circuitpython/installing-circuitpython) to install CircuitPython on your board running WipperSnapper.

- If you are unable to double-tap the RST button to enter the UF2 bootloader, follow the _"Factory Resetting a WipperSnapper Board"_ instructions below.

Uploading this sketch will overwrite WipperSnapper. If you want to re-install WipperSnapper, follow the instructions at the top of this page.

### Moving from WipperSnapper to Arduino

If you want to use your board with Arduino, you will use the Arduino IDE to load&nbsp;_any_ sketch onto your board.

First, follow the page below to set up your Arduino IDE environment for use with your board.

[Arduino IDE Setup](https://learn.adafruit.com/adafruit-qt-py-esp32-pico/arduino-ide-setup)
Then, follow the page below to upload the "Arduino Blink" sketch to your board.

[Upload Arduino "Blink" Sketch](https://learn.adafruit.com/adafruit-qt-py-esp32-pico/blink)
Uploading this sketch will overwrite WipperSnapper. If you want to re-install WipperSnapper, follow the instructions at the top of this page.

### Factory Resetting a WipperSnapper Board

Sometimes, hardware gets into a state that requires it to be "restored" to the original state it shipped in. If you'd like to get your board back to its original factory state, follow the guide below.

[Factory Reset Adafruit QT Py ESP32 Pico](https://learn.adafruit.com/adafruit-qt-py-esp32-pico/factory-reset)
# Adafruit QT Py ESP32 Pico

## WipperSnapper Essentials

![](https://cdn-learn.adafruit.com/assets/assets/000/117/601/medium800/wippersnapper_essentials_heading__required_parts__sensors_boardspread.jpg?1674497784)

You've installed WipperSnapper firmware on your board and connected it to Adafruit IO. Next, let's learn how to use Adafruit IO!

The Adafruit IO supports a large number of _components. Components_ are physical parts such as buttons, switches, sensors, servos, LEDs, RGB LEDs, and more.&nbsp;

The following pages will get you up and running with WipperSnapper as you interact with your board's LED, read the value of a push button, send the value of an I2C sensor to the internet, and wirelessly control colorful LEDs.

### Parts

The following parts are&nbsp; **required** to complete the WipperSnapper essentials pages for this board:

### STEMMA Wired Potentiometer Breakout Board - 10K ohm Linear

[STEMMA Wired Potentiometer Breakout Board - 10K ohm Linear](https://www.adafruit.com/product/4493)
For the easiest way possible to measure twists, turn to this STEMMA potentiometer breakout (ha!). This plug-n-play pot comes with a JST-PH 2mm connector and a matching &nbsp;[JST PH 3-Pin to Male Header Cables - 200mm](https://www.adafruit.com/product/3893), so wiring up is a cinch....

Out of Stock
[Buy Now](https://www.adafruit.com/product/4493)
[Related Guides to the Product](https://learn.adafruit.com/products/4493/guides)
![Video of a white hand turning the knob on a STEMMA Wired Potentiometer Breakout Board connect to a breadboard. Color changes when the knob is twisted. ](https://cdn-shop.adafruit.com/product-videos/640x480/4493-04.jpg)

### Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout

[Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout](https://www.adafruit.com/product/5027)
The MCP9808 digital temperature sensor is one of the more accurate/precise we've ever seen, with a typical accuracy of ±0.25°C over the sensor's -40°C to +125°C range and precision of +0.0625°C. They work great with any microcontroller using standard I2C. With...

Out of Stock
[Buy Now](https://www.adafruit.com/product/5027)
[Related Guides to the Product](https://learn.adafruit.com/products/5027/guides)
![Top view of temperature sensor breakout above an OLED display FeatherWing. The OLED display reads "MCP9808 Temp: 24.19ºC"](https://cdn-shop.adafruit.com/640x480/5027-04.jpg)

### STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long

[STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long](https://www.adafruit.com/product/4399)
This 4-wire cable is&nbsp;50mm / 1.9" long and fitted with JST SH female 4-pin connectors on both ends. Compared with the chunkier JST PH these are 1mm pitch instead of 2mm, but still have a nice latching feel, while being easy to insert and remove.

<a...></a...>

In Stock
[Buy Now](https://www.adafruit.com/product/4399)
[Related Guides to the Product](https://learn.adafruit.com/products/4399/guides)
![Angled of of JST SH 4-Pin Cable.](https://cdn-shop.adafruit.com/640x480/4399-00.jpg)

# Adafruit QT Py ESP32 Pico

## NeoPixel LED

Your board has a WS281x RGB LED (NeoPixel, in Adafruit jargon) built in. Boards running the WipperSnapper firmware can be wirelessly controlled by Adafruit IO to interact with NeoPixels.

On this page, you'll learn how to change the color and brightness of the NeoPixel built into your board from Adafruit IO.

## Where is the NeoPixel on my board?
- Above the SCK and MI on the silk, is the&nbsp; **RGB NeoPixel LED** (outlined in black).&nbsp;

![adafruit_products_QTP_NeoPixel.jpg](https://cdn-learn.adafruit.com/assets/assets/000/119/020/medium640/adafruit_products_QTP_NeoPixel.jpg?1677620162)

## Create the NeoPixel Component
Primary: If you used the Magic Config button to automatically configure the components on your board, then the NeoPixel component will already be configured. Skip ahead to the **Usage** section.

Don't know about Magic Config? Click the Auto-Config button on the device page for further details!

On the device page, click the New Component (or "+") button to open the component picker.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/021/medium800/adafruit_products_qtpy-pico-new-component.png?1677620537)

Search for the component name by entering&nbsp;`neopixel`&nbsp;into the text box on the component picker, the list of components should update as soon as you stop typing

![neopixel_led__built_in__NaP8Tyf3AP.png](https://cdn-learn.adafruit.com/assets/assets/000/127/434/medium640/neopixel_led__built_in__NaP8Tyf3AP.png?1706807288)

### Filtering and searching for components

Since WipperSnapper supports such a large number of components, you can use keyword filtering. Try searching for various keywords, like:

- component names:&nbsp;`aht20`,&nbsp;`servo`,&nbsp;`buzzer`,&nbsp;`button`, `neopixel`, etc
- sensor types:&nbsp;`light`,&nbsp;`temperature`,&nbsp;`pressure`,&nbsp;`humidity`, etc
- interface:&nbsp;`i2c`,&nbsp;`uart`,&nbsp;`ds18x20`,&nbsp;`pin`, etc (also I2C addresses e.g.&nbsp;`0x44`)
- vendor:&nbsp;`Adafruit`,&nbsp;`ASAIR`,&nbsp;`Infineon`,&nbsp;`Bosch`,&nbsp;`Honeywell`,&nbsp;`Sensirion`, etc

There is also added product and documentation links for every component, follow the links beneath the component descriptions to be taken to the appropriate product page or Learn Guide

Select the **NeoPixel** &nbsp;from the list of results to go to the component configuration page.

There will be a back button if you select the wrong component, and you can use the Edit component icon (⚙️) on the device page to update the component configuration in the future.

![neopixel_led__built_in__NaP8Tyf3AP.png](https://cdn-learn.adafruit.com/assets/assets/000/127/447/medium640/neopixel_led__built_in__NaP8Tyf3AP.png?1706818377)

The board NeoPixel pin is automatically found and selected.

Click&nbsp; **Create Component**

![](https://cdn-learn.adafruit.com/assets/assets/000/119/022/medium800/adafruit_products_qtpy-pico-neopixel-form.png?1677620645)

Behind the scenes, Adafruit IO sends a command to your board running WipperSnapper firmware telling it to configure the pin as a NeoPixel component with the settings from the form.

The Device page shows the NeoPixel component.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/023/medium800/adafruit_products_qtpy-pico-neopixel-page.png?1677620689)

## Set the NeoPixel's RGB Color

Since no colors have been set yet, the color picker's default value is `#000000` (black in hex color code) and appears "off". You can change that to make the NeoPixel shine brightly!&nbsp;

On the NeoPixel component, click the color dropper at the end of the color swatch list.

![](https://cdn-learn.adafruit.com/assets/assets/000/127/438/medium800/neopixel_led__built_in__gU5CxAW05e_ARROW.png?1706808192)

A color picker pops open! Next: learning how Adafruit IO uses hex color codes to represent the colors on your NeoPixel.

![](https://cdn-learn.adafruit.com/assets/assets/000/118/313/medium800/neopixel_led__built_in__picker-no-color-set.png?1675876687)

### Hex Colors 101

The color picker on Adafruit IO uses hex color codes to represent Red, Green, and Blue values. For example, `#FF0000` is the hex color code for the color red. The colors (`#FF0000`) red component is `FF` (255 translated to decimal), the green component is `00` and the blue component is `00`. Translated to RGB format, the color is `RGB (255, 0, 0)`.&nbsp;

Using the color picker, or by manually entering a hex color code, select a color.

![](https://cdn-learn.adafruit.com/assets/assets/000/117/677/medium800thumb/neopixel_led_ezgif.com-gif-maker_%283%29.jpg?1674668859)

When you're ready to set the color of your device's NeoPixel, click **FILL WITH COLOR**.&nbsp;The NeoPixel will immediately glow!

![](https://cdn-learn.adafruit.com/assets/assets/000/119/024/medium800thumb/adafruit_products_ezgif.com-video-to-gif_%2831%29.jpg?1677620985)

## Set NeoPixel Brightness

If the NeoPixel is too bright (or too dim), you can change the overall brightness. Click the gear/cog icon on the NeoPixel component to open its settings.

![](https://cdn-learn.adafruit.com/assets/assets/000/127/439/medium800/neopixel_led__built_in__arrow_FTzWrYk8MV.png?1706810370)

On the NeoPixel component form, set Brightness to a value between 0 (fully off) and 255 (full brightness).

Click the **Update Component&nbsp;** button to send the updated configuration to your device.&nbsp;

![](https://cdn-learn.adafruit.com/assets/assets/000/117/675/medium800/neopixel_led_IO_-_Device__Adafruit_Feather_ESP32_V2.png?1674666662)

# Adafruit QT Py ESP32 Pico

## Read a Push-button

Info: This demo shows reading the state of a push-button from WipperSnapper. But the same kind of control can be used for reading switches, break beam sensors, and other digital sensors.

You can configure a board running WipperSnapper to read data from standard input buttons, switches, or digital sensors, and send the value to Adafruit IO.

From Adafruit IO, you will configure one of the pushbuttons on your board as a push button component. Then, when the button is pressed (or released), a value will be published to Adafruit IO.

## Button Location

This example uses the board's built-in push-button and internal pull-up resistor instead of wiring a push-button up.

The BOOT button on the QT Py ESP32 Pico is located underneath the USB-C port.

![adafruit_products_qtpy-esp32-boot-btn.png](https://cdn-learn.adafruit.com/assets/assets/000/119/025/medium640/adafruit_products_qtpy-esp32-boot-btn.png?1677621061)

## Create a Push-button Component on Adafruit IO
On the device page, click the New Component (or "+") button to open the component picker.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/026/medium800/adafruit_products_qtpy-pico-new-component.png?1677621092)

Search for the component name by entering&nbsp;`push`&nbsp;into the text box on the component picker, the list of components should update as soon as you stop typing.

![read_a_push_button__built_in__5NrzQhD0zT.png](https://cdn-learn.adafruit.com/assets/assets/000/127/430/medium640/read_a_push_button__built_in__5NrzQhD0zT.png?1706749773)

### Filtering and searching for components

Since WipperSnapper supports such a large number of components, you can use filtering. Try searching for various keywords, like:

- component names:` aht20`,&nbsp;`servo`,&nbsp;`buzzer`,&nbsp;`button`,&nbsp;`potentiometer`, etc
- sensor types:&nbsp;`light`,&nbsp;`temperature`,&nbsp;`pressure`,&nbsp;`humidity`, etc
- interface:&nbsp;`i2c`,&nbsp;`uart`,&nbsp;`ds18x20`,&nbsp;`pin`, etc (also I2C addresses e.g.&nbsp;`0x44`)
- vendor:&nbsp;`Adafruit`,&nbsp;`ASAIR`,&nbsp;`Infineon`,&nbsp;`Bosch`,&nbsp;`Honeywell`,&nbsp;`Sensirion`, etc

There are also added product and documentation links for every component. Follow the links beneath the component descriptions to be taken to the appropriate product page or Learn Guide.

Select the **Push Button** &nbsp;from the list of results to go to the component configuration page.

There will be a back button if you select the wrong component, and you can use the Edit component icon (⚙️) on the device page to update the component configuration in the future.

![read_a_push_button__built_in__5NrzQhD0zT.png](https://cdn-learn.adafruit.com/assets/assets/000/127/431/medium640/read_a_push_button__built_in__5NrzQhD0zT.png?1706749847)

The "Create Push Button Component" form&nbsp;presents you with options for configuring the push button.

Start by selecting the board's pin connected to the push button.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/027/medium800/adafruit_products_qtpy-esp32-pb-1.png?1677621251)

The&nbsp;_Return Interval_&nbsp;dictates how frequently the value of the push-button will be sent from the board to Adafruit IO.

For this example, you will configure the push button's value to be only sent when the value changes (i.e. when it's either pressed or depressed).

![](https://cdn-learn.adafruit.com/assets/assets/000/119/028/medium800/adafruit_products_qtpy-esp32-pb-2.png?1677621258)

Finally, check the&nbsp; **Specify Pin Pull Direction&nbsp;** checkbox and select the pull direction.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/029/medium800/adafruit_products_qtpy-esp32-pb-3.png?1677621266)

Make sure the form's settings look like the following screenshot. Then, click&nbsp; **Create Component**.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/030/medium800/adafruit_products_qtpy-esp32-pb-4.png?1677621272)

Adafruit IO sends a command to your WipperSnapper board, telling it to configure the GPIO pin you selected to behave as a digital input pin and to enable it to pull up the internal resistor.

Your board's page should also show the new push-button component.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/031/medium800/adafruit_products_qtpy-esp32-pb-page.png?1677621279)

Push the button on your board to change the value of the push-button component on Adafruit IO.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/032/medium800thumb/adafruit_products_ezgif.com-video-to-gif_%2832%29.jpg?1677621381)

# Adafruit QT Py ESP32 Pico

## Analog Input

Your microcontroller board has both digital and analog signal capabilities. Some pins are analog, some are digital, and some are capable of both. Check the **Pinouts** page in this guide for details about your board.

Analog signals are different from digital signals in that they can be _any_ voltage and can vary continuously and smoothly between voltages. An analog signal is like a dimmer switch on a light, whereas a digital signal is like a simple on/off switch.&nbsp;

Digital signals only can ever have two states, they are either are **on** (high logic level voltage like 3.3V) or **off** (low logic level voltage like 0V / ground).

By contrast, analog signals can be any voltage in-between on and off, such as 1.8V or 0.001V or 2.98V and so on.

![](https://cdn-learn.adafruit.com/assets/assets/000/102/411/medium800/analog_in_Analog_Template_analog.jpg?1622144011)

Analog signals are continuous values which means they can be an _infinite_ number of different voltages. Think of analog signals like a floating point or fractional number, they can smoothly transiting to _any_ in-between value like 1.8V, 1.81V, 1.801V, 1.8001V, 1.80001V and so forth to infinity.

Many devices use analog signals, in particular sensors typically output an analog signal or voltage that varies based on something being sensed like light, heat, humidity, etc.

## Analog to Digital Converter (ADC)

An analog-to-digital-converter, or ADC, is the key to reading analog signals and voltages with a microcontroller. An ADC is a device that reads the voltage of an analog signal and converts it into a digital, or numeric, value. The microcontroller can’t read analog signals directly, so the analog signal is first converted into a numeric value by the ADC.&nbsp;

The black line below shows a digital signal over time, and the red line shows the converted analog signal over the same amount of time.

![](https://cdn-learn.adafruit.com/assets/assets/000/102/412/medium800/analog_in_Analog_Template_ADC.jpg?1622144080)

Once that analog signal has been converted by the ADC, the microcontroller can use those digital values any way you like!

## Potentiometers

A potentiometer is a small variable resistor that you can twist a knob or shaft to change its resistance. It has three pins. By twisting the knob on the potentiometer you can change the resistance of the middle pin (called the wiper) to be anywhere within the range of resistance of the potentiometer.

By wiring the potentiometer to your board in a special way (called a voltage divider) you can turn the change in resistance into a change in voltage that your board’s analog to digital converter can read.

![](https://cdn-learn.adafruit.com/assets/assets/000/102/413/medium800/analog_in_Analog_Template_potentiometer.jpg?1622144123)

To wire up a potentiometer as a voltage divider:

- Connect **one outside pin** to **ground**
- Connect **the other outside pin** to **voltage in (e.g. 3.3V)**
- Connect **the middle pin** to **an analog pin (e.g. A0)**

![analog_in_Analog_template_pot_voltage_divider.jpg](https://cdn-learn.adafruit.com/assets/assets/000/102/481/medium640/analog_in_Analog_template_pot_voltage_divider.jpg?1622481955)

## Hardware

In addition to your microcontroller board, you will need the following hardware to follow along with this example.

 **Potentiometer**

### STEMMA Wired Potentiometer Breakout Board - 10K ohm Linear

[STEMMA Wired Potentiometer Breakout Board - 10K ohm Linear](https://www.adafruit.com/product/4493)
For the easiest way possible to measure twists, turn to this STEMMA potentiometer breakout (ha!). This plug-n-play pot comes with a JST-PH 2mm connector and a matching &nbsp;[JST PH 3-Pin to Male Header Cables - 200mm](https://www.adafruit.com/product/3893), so wiring up is a cinch....

Out of Stock
[Buy Now](https://www.adafruit.com/product/4493)
[Related Guides to the Product](https://learn.adafruit.com/products/4493/guides)
![Video of a white hand turning the knob on a STEMMA Wired Potentiometer Breakout Board connect to a breadboard. Color changes when the knob is twisted. ](https://cdn-shop.adafruit.com/product-videos/640x480/4493-04.jpg)

## Wire Up the Potentiometer

Connect the potentiometer to your board as follows.

- **QT Py 3V&nbsp;** to **&nbsp;potentiometer left pin**
- **QT Py A2&nbsp;** to **&nbsp;potentiometer middle pin**
- **QT Py GND&nbsp;** to **&nbsp;potentiometer right pin**

**Note:** &nbsp;On WipperSnapper, the ESP32's ADC1 pins are unusable for analog input since WiFi is constantly running.&nbsp;

- [For information on what Analog Input pins can (and can't) be used on this board, click here \>\>\>](https://learn.adafruit.com/adafruit-huzzah32-esp32-feather/esp32-faq#faq-2991123)

![adafruit_products_qtpy-pico-pot.png](https://cdn-learn.adafruit.com/assets/assets/000/119/033/medium640/adafruit_products_qtpy-pico-pot.png?1677621639)

## Create a Potentiometer Component on Adafruit IO

On the device page, click the New Component (or "+") button to open the component picker.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/035/medium800/adafruit_products_qtpy-pico-new-component.png?1677621689)

Search for the component name by entering `potentiometer`&nbsp;into the text box on the component picker, the list of components should update as soon as you stop typing.

![analog_in__pot___N0AyUqauwx.png](https://cdn-learn.adafruit.com/assets/assets/000/128/616/medium640/analog_in__pot___N0AyUqauwx.png?1709746646)

### Filtering and searching for components

Since WipperSnapper supports such a large number of components, there is keyword filtering. Try searching for various keywords, like:

- component names: `aht20`,&nbsp;`servo`,&nbsp;`buzzer`,&nbsp;`button`,&nbsp;`potentiometer`, etc
- sensor types:&nbsp;`light`,&nbsp;`temperature`,&nbsp;`pressure`,&nbsp;`humidity`, etc
- interface:&nbsp;`i2c`,&nbsp;`uart`,&nbsp;`ds18x20`,&nbsp;`pin`, etc (also I2C addresses e.g.&nbsp;`0x44`)
- vendor:&nbsp;`Adafruit`,&nbsp;`ASAIR`,&nbsp;`Infineon`,&nbsp;`Bosch`,&nbsp;`Honeywell`,&nbsp;`Sensirion`, etc

There are also added product and documentation links for every component, follow the links beneath the component descriptions to be taken to the appropriate product page or Learn Guide.

Select the&nbsp; **Potentiometer** &nbsp;from the list of results to go to the component configuration page.

There will be a back button if you select the wrong component, and you can use the Edit component icon (⚙️) on the device page to update the component configuration in the future.

![analog_in__pot___N0AyUqauwx.png](https://cdn-learn.adafruit.com/assets/assets/000/128/617/medium640/analog_in__pot___N0AyUqauwx.png?1709746737)

On the _Create Potentiometer Component_ form:

- Set&nbsp; **Potentiometer Pin** &nbsp;to&nbsp; **A2**

- Select **"On Change"** as the **Return Interval**
- Select **Raw Analog Value** as the **Return Type**

Then, click Create Component

![](https://cdn-learn.adafruit.com/assets/assets/000/119/036/medium800/adafruit_products_qtpy-pico-pot-form.png?1677621760)

The potentiometer component appears on your board page! Next, learning to read values from it.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/037/medium800/adafruit_products_qtpy-pico-pot-pg.png?1677621768)

## Read Analog Pin Values

Rotate the potentiometer to see the value change.

![](https://cdn-learn.adafruit.com/assets/assets/000/118/240/medium800thumb/analog_in__pot___ezgif.com-video-to-gif.jpg?1675792293)

_What do these values mean?_

WipperSnapper reports ADC "raw values" as 16-bit unsigned integer values. Your potentiometer will read between 0 (twisting the pot to the leftmost position) and 65535 (twisting the pot to the rightmost position).&nbsp;

## Read Analog Pin Voltage Values

You can update the potentiometer component (or any analog pin component in WipperSnapper) to report values in Volts. To do this, on the right-hand side of the potentiometer component, click the cog button.

![](https://cdn-learn.adafruit.com/assets/assets/000/118/241/medium800/analog_in__pot___cog-click.png?1675792568)

Under **Return Type** , click Voltage.

Click Update Component to send the updated component settings to your board running WipperSnapper.

![](https://cdn-learn.adafruit.com/assets/assets/000/118/242/medium800/analog_in__pot___voltage-select.png?1675792603)

Now, twist the potentiometer to see the value reported to Adafruit IO in Volts!

![](https://cdn-learn.adafruit.com/assets/assets/000/118/243/medium800thumb/analog_in__pot___ezgif.com-video-to-gif_%281%29.jpg?1675792716)

# Adafruit QT Py ESP32 Pico

## I2C Sensors

Info: 

Inter-Integrated Circuit, aka **I2C** , is a two-wire protocol for connecting sensors and "devices" to a microcontroller. A large number of sensors, including the ones sold by Adafruit, use I2C to communicate.&nbsp;

**Typically, using I2C with a microcontroller involves programming. Adafruit IO and WipperSnapper let you configure a microcontroller to read data from an I2C sensor and publish that data to the internet without writing code.**

The WipperSnapper firmware supports a number of I2C sensors,&nbsp;[viewable in list format here](https://github.com/adafruit/Wippersnapper_Components/tree/main/components/i2c).

- If you do not see the I2C sensor you're attempting to use with WipperSnapper,&nbsp;[Adafruit has a guide on adding a component to Adafruit IO WipperSnapper here](https://learn.adafruit.com/how-to-add-a-new-component-to-adafruit-io-wippersnapper).&nbsp;

On this page, you'll learn how to wire up an I2C sensor to your board. Then, you'll create a new component on Adafruit IO for your I2C sensor and send the sensor values to Adafruit IO. Finally, you'll learn how to locate, interpret, and download the data produced by your sensors.

## Parts

You will need the following parts to complete this page:

### Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout

[Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout](https://www.adafruit.com/product/5027)
The MCP9808 digital temperature sensor is one of the more accurate/precise we've ever seen, with a typical accuracy of ±0.25°C over the sensor's -40°C to +125°C range and precision of +0.0625°C. They work great with any microcontroller using standard I2C. With...

Out of Stock
[Buy Now](https://www.adafruit.com/product/5027)
[Related Guides to the Product](https://learn.adafruit.com/products/5027/guides)
![Top view of temperature sensor breakout above an OLED display FeatherWing. The OLED display reads "MCP9808 Temp: 24.19ºC"](https://cdn-shop.adafruit.com/640x480/5027-04.jpg)

### STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long

[STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long](https://www.adafruit.com/product/4399)
This 4-wire cable is&nbsp;50mm / 1.9" long and fitted with JST SH female 4-pin connectors on both ends. Compared with the chunkier JST PH these are 1mm pitch instead of 2mm, but still have a nice latching feel, while being easy to insert and remove.

<a...></a...>

In Stock
[Buy Now](https://www.adafruit.com/product/4399)
[Related Guides to the Product](https://learn.adafruit.com/products/4399/guides)
![Angled of of JST SH 4-Pin Cable.](https://cdn-shop.adafruit.com/640x480/4399-00.jpg)

## Wiring
Connect the&nbsp; **QT Py's STEMMA QT Port** &nbsp;to&nbsp; **MCP9808's STEMMA QT Port**

- **NOTE** : At the time of writing, **&nbsp;the QT Py's second I2C port&nbsp;** (mapped to the SCL/SDA pins on the board) **&nbsp;is not supported by WipperSnapper.&nbsp;** Only the STEMMA I2C port is supported.

![adafruit_products_qtpy-mcp_bb.png](https://cdn-learn.adafruit.com/assets/assets/000/119/040/medium640/adafruit_products_qtpy-mcp_bb.png?1677621935)

## Add an MCP9808 Component

On the device page, click the New Component (or "+") button to open the component picker.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/038/medium800/adafruit_products_qtpy-pico-new-component.png?1677621833)

Search for the component name by entering `MCP9808`&nbsp;into the text box on the component picker, the list of components should update as soon as you stop typing.

![i2c__external__ARROW_YHKeButdWT.png](https://cdn-learn.adafruit.com/assets/assets/000/127/456/medium640/i2c__external__ARROW_YHKeButdWT.png?1706830517)

### Filtering and searching for components

Since WipperSnapper supports such a large number of components, there is keyword filtering. Try searching for various keywords, like:

- component names:&nbsp;`aht20`,&nbsp;`servo`,&nbsp;`buzzer`,&nbsp;`button`,&nbsp;`potentiometer`, etc
- sensor types:&nbsp;`light`,&nbsp;`temperature`,&nbsp;`pressure`,&nbsp;`humidity`, etc
- interface:&nbsp;`i2c`,&nbsp;`uart`,&nbsp;`ds18x20`,&nbsp;`pin`, etc (also I2C addresses e.g.&nbsp;`0x44`)
- vendor:&nbsp;`Adafruit`,&nbsp;`ASAIR`,&nbsp;`Infineon`,&nbsp;`Bosch`,&nbsp;`Honeywell`,&nbsp;`Sensirion`, etc

There are added product and documentation links for every component, follow the links beneath the component descriptions to be taken to the appropriate product page or Learn Guide.

Select the&nbsp; **MCP9808** &nbsp;from the list of results to go to the component configuration page.

There will be a back button if you select the wrong component, and you can use the Edit component icon (⚙️) on the device page to update the component configuration in the future.

![i2c__external__ARROW_YHKeButdWT.png](https://cdn-learn.adafruit.com/assets/assets/000/127/457/medium640/i2c__external__ARROW_YHKeButdWT.png?1706830625)

On the component configuration page, the MCP9808's I2C sensor address should be listed along with the sensor's settings.

![](https://cdn-learn.adafruit.com/assets/assets/000/117/981/medium800/i2c__external__mcp9808-form.png?1675199307)

The MCP9808 sensor can measure ambient temperature. This page has individual options for reading the ambient temperature, in either Celsius or Fahrenheit. You may select the readings which are appropriate to your application and region.

The&nbsp; **Send Every** &nbsp;option is specific to each sensor measurement. This option will tell the board how often it should read from the sensor and send the data to Adafruit IO. Measurements can range from every 30 seconds to every 24 hours.

For this example, set the&nbsp; **Send Every&nbsp;** interval for both seconds to&nbsp; **Every 30 seconds.&nbsp;** Click&nbsp; **Create Component**.

![](https://cdn-learn.adafruit.com/assets/assets/000/117/982/medium800/i2c__external__mcp9808-form-2.png?1675199314)

The board page should now show the MCP9808 component you created. After the interval you configured elapses, the WipperSnapper firmware running on your board automatically reads values from the sensor and sends them to Adafruit IO.

![](https://cdn-learn.adafruit.com/assets/assets/000/119/039/medium800/adafruit_products_qtpy-pico-mcp9808.png?1677621842)

## Read I2C Sensor Values

Now to look behind the scenes at a powerful element of using Adafruit IO and WipperSnapper. When a new component is created on Adafruit IO, an&nbsp;[Adafruit IO Feed](https://learn.adafruit.com/adafruit-io-basics-feeds)&nbsp;is also created. This Feed holds your sensor component values for long-term storage (30 days of storage for Adafruit IO Free and 60 days for Adafruit IO Plus plans).

Aside from holding the&nbsp; **values** &nbsp;read by a sensor, the component's feed also holds&nbsp; **metadata** &nbsp;about the data pushed to Adafruit IO. This includes settings for whether the data is public or private, what license the stored sensor data falls under, and a general description of the data.

Next, to look at the sensor temperature feed. To navigate to a component's feed, click on the chart icon in the upper-right-hand corner of the component.

![](https://cdn-learn.adafruit.com/assets/assets/000/117/984/medium800/i2c__external__chart-icon.png?1675199374)

On the component's feed page, you'll each data point read by your sensor and when they were reported to Adafruit IO.

![](https://cdn-learn.adafruit.com/assets/assets/000/117/985/medium800/i2c__external__mcpx-feed.png?1675199406)

### Doing more with your sensor's Adafruit IO Feed

This only scratches the surface of what Adafruit IO Feeds can accomplish for your IoT projects. For a complete overview of Adafruit IO Feeds, including tasks like downloading feed data, sharing a feed, removing erroneous data points from a feed, and more,&nbsp;[head over to the "Adafruit IO Basics: Feed" learning guide](https://learn.adafruit.com/adafruit-io-basics-feeds).

# Adafruit QT Py ESP32 Pico

## MicroPython Setup

This board is also supported by MicroPython. This page covers the basics to get you started.

## Load MicroPython using `esptool`

Before you can load MicroPython, you'll need to install `esptool`. Follow the instructions found [here](https://docs.espressif.com/projects/esptool/en/latest/esp32/index.html#quick-start).

Once you have `esptool` installed, you will first want to erase the flash on your QT Py. You can do so by running something similar to the following command. Make sure you update the port to match the serial port to which your board is connected, i.e. change `/dev/tty.wchusbserial54780341901` to match your connection.

`esptool.py --chip esp32 --port /dev/tty.wchusbserial547803419010 erase_flash`

![](https://cdn-learn.adafruit.com/assets/assets/000/112/280/medium800/adafruit_products_QTP_esptool_erase_flash.png?1654543819)

Once the flash is successfully erased, you can load MicroPython by running something similar to the command below. Make sure you update the following:

- The port to match the serial port to which your board is connected, i.e. change **/dev/tty.wchusbserial54780341901** to match your connection.
- The **firmware.bin** file name to match the MicroPython firmware you downloaded, i.e. change **firmware.bin** to something like **esp32-20220117-v1.18.bin**.

Load MicroPython using something similar to the following command, with the above changes:

`esptool.py --chip esp32  --port /dev/tty.wchusbserial547803419010 write_flash -z 0x1000 firmware.bin`

![](https://cdn-learn.adafruit.com/assets/assets/000/112/281/medium800/adafruit_products_QTP_esptool_load_MP.png?1654543850)

## MicroPython Code

To manage and run code, you can use Thonny - set up to be a **MicroPython (ESP32)** board, then pick the matching serial port.

![](https://cdn-learn.adafruit.com/assets/assets/000/112/289/medium800/adafruit_products_QTP_thonny_interpreter_setup.png?1654547521)

That's all there is to getting Thonny set up to work with MicroPython!

## MicroPython Blink

The first example is blinking the onboard NeoPixel LED.

Download the following code and save it to your QT Py as **main.py**

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/MicroPython_NeoPixel_Blink/main.py

Once you have the **main.py** file on your computer, open the **main.py** file into Thonny, and click **Save**.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/393/medium800/adafruit_products_FV2_MP_save_Thonny.png?1648664635)

The first time you do this, you will receive the following popup. Click **MicroPython**  **Device**.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/394/medium800/adafruit_products_FV2_MP_where_to_save_MP_device.png?1648664711)

The following window will show up next, allowing you to save the **main.py** file to your QT Py.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/395/medium800/adafruit_products_FV2_MP_save_main_py.png?1648664753)

Once saved to your QT Py, in Thonny, click **STOP (red button)** followed by **Run (green arrow button)** to load the **main.py** file and run it.

![](https://cdn-learn.adafruit.com/assets/assets/000/112/282/medium800/adafruit_products_QTP_run_in_thonny.png?1654545666)

The NeoPixel LED will begin blinking blue.

That's all there is to blinking the onboard NeoPixel LED using MicroPython!

## MicroPython WiFi Connection
First, install the `urequests` library via the package manager. Click&nbsp; **Tools \> Manage Packages&nbsp;** to open the package manager. Type **urequests** into the search bar, and click **Search on PyPI**.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/390/medium800/adafruit_products_FV2_MP_urequests_search.png?1648663762)

You may be greeted with the following popup. Click **Yes**.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/391/medium800/adafruit_products_FV2_MP_urequests_install_popup.png?1648663810)

Once installed, the package manager will show it as installed.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/392/medium800/adafruit_products_FV2_MP_urequests_installed.png?1648663868)

Click **Close**.

Download the following code and save it to your ESP32 as **main.py**

Don't forget to change `MY_SSID` and `MY_PASSWORD` to your WiFi access point name and credentials.

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/MicroPython_WiFi/main.py

Follow the same instructions above to load the WiFi code onto your QT Py.

In the Shell, you should see something like the following indicating it could connect to WiFI and read the data from our webserver.

![](https://cdn-learn.adafruit.com/assets/assets/000/110/397/medium800/adafruit_products_FV2_MP_WiFi_demo_success.png?1648665171)

# Adafruit QT Py ESP32 Pico

## Factory Reset

Your microcontroller ships running a factory demo. It's lovely, but you probably had other plans for the board. As you start working with your board, you may want to return to the original code to begin again, or you may find your board gets into a bad state. Either way, this page has you covered.

## Factory Reset Example Code
If you're still able to load Arduino sketches, you can load the following sketch onto your board to return it to its original state.

https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/Factory_Tests/QTPy_ESP32_FactoryTest/QTPy_ESP32_FactoryTest.ino

Your board is now back to its factory-shipped state! You can now begin again with your plans for your board.

## Factory Reset .bin
If your board is in a state where Arduino isn't working, you may need to use these tools to flash a .bin file directly onto your board.

There are two ways to do a factory reset. The first is using WebSerial through a Chromium-based browser, and the second is using `esptool` via command line. **We highly recommend using WebSerial through Chrome/Chromium.**

First you'll need to download the factory-reset.bin file. Save the following file wherever is convenient for you. You'll need access to it for both tools.

[Click to download qt-py-esp32-pico-factory-reset.bin](https://github.com/adafruit/Adafruit-QT-Py-ESP32-Pico-PCB/raw/main/factory-reset/qt-py-esp32-pico-factory-reset.bin)
Now that you've downloaded the .bin file, you're ready to continue with the factory reset process. The next two sections walk you through using WebSerial and `esptool`.

## The WebSerial ESPTool Method
Primary: 

This method uses the WebSerial ESPTool through Chrome or a Chromium-based browser. The WebSerial ESPTool was designed to be a web-capable option for programming ESP32 boards. It allows you to erase the contents of the microcontroller and program up to four files at different offsets.

You will have to use a Chromium browser (like Chrome, Opera, Edge...) for this to work, Safari and Firefox, etc. are _not_ supported because we need Web Serial and only Chromium is supporting it to the level needed.

Follow the steps to complete the factory reset.

Warning: 

### Connect

You should have plugged in **only the ESP32 that you intend to flash**. That way there's no confusion in picking the proper port when it's time!

In the **Chrome browser** visit [https://adafruit.github.io/Adafruit\_WebSerial\_ESPTool/](https://adafruit.github.io/Adafruit_WebSerial_ESPTool/). You should see something like the image shown.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.07.03_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/492/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.07.03_PM.png?1649110083)

Press the&nbsp; **Connect** &nbsp;button in the top right of the web browser. You will get a pop up asking you to select the COM or Serial port.

**Remember, you should remove all other USB devices so**  **_only_ the ESP32 board is attached, that way there's no confusion over multiple ports!**

On some systems, such as MacOS, there may be additional system ports that appear in the list.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.12.49_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/493/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.12.49_PM.png?1649110453)

The Javascript code will now try to connect to the ROM bootloader. It may timeout for a bit until it succeeds. On success, you will see that it is&nbsp; **Connected** &nbsp;and will print out a unique&nbsp; **MAC address** identifying the board along with other information that was detected.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.16.00_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/494/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.16.00_PM.png?1649110590)

&nbsp;

&nbsp;

Once you have successfully connected, the command toolbar will appear.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.18.26_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/496/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.18.26_PM.png?1649110775)

### Erase the Contents
To erase the contents, click the Erase button. You will be prompted whether you want to continue. Click OK to continue or if you changed your mind, just click cancel.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.19.58_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/497/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.19.58_PM.png?1649110871)

&nbsp;

You'll see "Erasing flash memory. Please wait..." This will eventually be followed by "Finished." and the amount of time it took to erase.

**Do not disconnect!** Immediately continue on to programming the ESP32.

![factory_reset___esp32_s2_WebSerial_ESPTool_erase_board_text.png](https://cdn-learn.adafruit.com/assets/assets/000/106/947/medium640/factory_reset___esp32_s2_WebSerial_ESPTool_erase_board_text.png?1638491869)

Danger: 

### Program the ESP32
Programming the microcontroller can be done with up to four files at different locations, but with the board-specific **factory-reset.bin** file, which you should have downloaded earlier, you only need to use one file.

Click on the first **Choose a file...**. (The tool will only attempt to program buttons with a file and a unique location.) Then, select the \*- **factory-reset.bin** file you downloaded in Step 1 that matches your board.

Verify that the&nbsp; **Offset** &nbsp;box next to the file location you used is (0x) **0**.

![install_uf2_bootloader_adafruit_products_image_(3).png](https://cdn-learn.adafruit.com/assets/assets/000/101/574/medium640/install_uf2_bootloader_adafruit_products_image_%283%29.png?1618608677)

Once you choose a file, the button text will change to match your filename. You can then select the **Program** button to begin flashing.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.22.13_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/500/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.22.13_PM.png?1649111131)

A progress bar will appear and after a minute or two, you will have written the firmware.

![esp32_factory_reset_Screen_Shot_2022-04-04_at_3.23.42_PM.png](https://cdn-learn.adafruit.com/assets/assets/000/110/499/medium640/esp32_factory_reset_Screen_Shot_2022-04-04_at_3.23.42_PM.png?1649111082)

Once completed, you can skip down to the section titled Reset the Board.

## The `esptool` Method (for advanced users)
Danger: 

Alternatively, you can [use Espressif's esptool program](https://github.com/espressif/esptool)&nbsp;to communicate with the chip!&nbsp;`esptool`&nbsp;is the 'official' programming tool and is the most common/complete way to program an ESP chip.

### Install ESPTool.py

You will need to use the command line / Terminal to install and run&nbsp;`esptool`.

You will also need to have pip and Python installed (any version!).

Install the latest version using pip (you may be able to run&nbsp;`pip`&nbsp;without the&nbsp;`3`&nbsp;depending on your setup):

`pip3 install --upgrade esptool`

Then, you can run:

`esptool.py`

### Test the Installation

Run&nbsp;`esptool.py`&nbsp;in a new terminal/command line and verify you get something like the below:

![](https://cdn-learn.adafruit.com/assets/assets/000/109/599/medium800/esp32_factory_reset_ESP_factory_reset_esptool_verify.png?1646862954)

### Connect

Run the following command, replacing the `COM88` identifier after&nbsp;`--port`&nbsp;with the&nbsp;`COMxx`,&nbsp;`/dev/cu.usbmodemxx`&nbsp;or&nbsp;`/dev/ttySxx`&nbsp;you found above.

`esptool.py --port COM88 chip_id`

You should get a notice that it connected over that port and found an ESP32.

![](https://cdn-learn.adafruit.com/assets/assets/000/109/600/medium800/esp32_factory_reset_ESP_factory_reset_esptool_connect.png?1646862962)

### Installing the Factory Test file

Run this command and replace the serial port name, `COM88`, with your matching port and `*-factory-reset.bin` with file you just downloaded

`esptool.py --port COM88 write_flash 0x0 *-factory-reset.bin`

Don't forget to change the `--port` name to match.

There might be a bit of a 'wait' when programming, where it doesn't seem like it's working. Give it a minute, it has to erase the old flash code which can cause it to seem like it's not running.

You'll finally get an output like this:

![](https://cdn-learn.adafruit.com/assets/assets/000/109/601/medium800/esp32_factory_reset_ESP_factory_reset_esptool_install.png?1646862974)

Once completed, you can continue to the next section.

## Reset the board
Now that you've reprogrammed the board, you need to reset it to continue. Click the reset button to launch the new firmware.

Info: 

The NeoPixel LED on the QT Py ESP32 Pico will light up green, followed by a rainbow swirl.

You've successfully returned your board to a factory reset state!

## Older Versions of Chrome
Primary: 

We suggest updating to Chrome 89 or newer, as Web Serial is enabled by default.

If you must continue using an older version of Chrome, follow these steps to enable Web Serial.

If you receive an error like the one shown when you visit the WebSerial ESPTool site, you're likely running an older version of Chrome.

**You must be using Chrome 78 or later to use Web Serial.**

![factory_reset___esp32_s2_WebSerial_ESPTool_Not_Supported_Error.png](https://cdn-learn.adafruit.com/assets/assets/000/106/929/medium640/factory_reset___esp32_s2_WebSerial_ESPTool_Not_Supported_Error.png?1638484333)

To enable Web Serial in Chrome versions 78 through 88:

- Visit **chrome://flags** &nbsp;from within Chrome.
- Find and enable the&nbsp; **Experimental Web Platform features**
- **Restart Chrome**

![install_uf2_bootloader_adafruit_products_Enable_Features.jpg](https://cdn-learn.adafruit.com/assets/assets/000/101/562/medium640/install_uf2_bootloader_adafruit_products_Enable_Features.jpg?1618608210)

# Adafruit QT Py ESP32 Pico

## Downloads

## Files

- [ESP32 Pico datasheet](https://cdn-learn.adafruit.com/assets/assets/000/117/489/original/esp32-pico-v3-02_datasheet_en.pdf?1673379076)
- [CP2102N datasheet](https://cdn-learn.adafruit.com/assets/assets/000/109/587/original/cp2102n-datasheet.pdf?1646851900)
- [EagleCAD PCB files on GitHub](https://github.com/adafruit/Adafruit-QT-Py-ESP32-Pico-PCB)
- [3D Models on GitHub](https://github.com/adafruit/Adafruit_CAD_Parts/tree/main/5395%20QT%20Py%20ESP32%20PICO)
- [Fritzing object in the Adafruit Fritzing Library](https://github.com/adafruit/Fritzing-Library/blob/master/parts/Adafruit%20QT%20Py%20ESP32%20Pico.fzpz)
- [PrettyPins pinout PDF on GitHub](https://github.com/adafruit/Adafruit-QT-Py-ESP32-Pico-PCB/blob/main/Adafruit%20QT%20Py%20ESP32-Pico%20Pinout.pdf)
- [PrettyPins pinout SVG](https://cdn-learn.adafruit.com/assets/assets/000/112/308/original/Adafruit_QT_Py_ESP32-Pico_Pinout.svg?1654628411)

# Schematic and Fab Print
![](https://cdn-learn.adafruit.com/assets/assets/000/111/951/medium800/adafruit_products_QTP_sch.png?1653427567)

![](https://cdn-learn.adafruit.com/assets/assets/000/111/952/medium800/adafruit_products_QTP_fab_print.png?1653427575)

# 3D Model
![](https://cdn-learn.adafruit.com/assets/assets/000/119/991/medium800/adafruit_products_5395-QT-Py-ESP32-PICO.jpg?1680270398)


## Primary Products

### Adafruit QT Py ESP32 Pico - WiFi Dev Board with STEMMA QT

[Adafruit QT Py ESP32 Pico - WiFi Dev Board with STEMMA QT](https://www.adafruit.com/product/5395)
This dev board is like when you're watching a super-hero movie and the protagonist shows up in a totally amazing costume in the third act and you're like 'OMG! That's the hero and they're here to kick some serious butt!" but in this case its a...

Out of Stock
[Buy Now](https://www.adafruit.com/product/5395)
[Related Guides to the Product](https://learn.adafruit.com/products/5395/guides)

## Featured Products

### STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long

[STEMMA QT / Qwiic JST SH 4-Pin Cable - 50mm Long](https://www.adafruit.com/product/4399)
This 4-wire cable is&nbsp;50mm / 1.9" long and fitted with JST SH female 4-pin connectors on both ends. Compared with the chunkier JST PH these are 1mm pitch instead of 2mm, but still have a nice latching feel, while being easy to insert and remove.

<a...></a...>

In Stock
[Buy Now](https://www.adafruit.com/product/4399)
[Related Guides to the Product](https://learn.adafruit.com/products/4399/guides)
### Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout

[Adafruit MCP9808 High Accuracy I2C Temperature Sensor Breakout](https://www.adafruit.com/product/5027)
The MCP9808 digital temperature sensor is one of the more accurate/precise we've ever seen, with a typical accuracy of ±0.25°C over the sensor's -40°C to +125°C range and precision of +0.0625°C. They work great with any microcontroller using standard I2C. With...

Out of Stock
[Buy Now](https://www.adafruit.com/product/5027)
[Related Guides to the Product](https://learn.adafruit.com/products/5027/guides)
### STEMMA Wired Potentiometer Breakout Board - 10K ohm Linear

[STEMMA Wired Potentiometer Breakout Board - 10K ohm Linear](https://www.adafruit.com/product/4493)
For the easiest way possible to measure twists, turn to this STEMMA potentiometer breakout (ha!). This plug-n-play pot comes with a JST-PH 2mm connector and a matching &nbsp;[JST PH 3-Pin to Male Header Cables - 200mm](https://www.adafruit.com/product/3893), so wiring up is a cinch....

Out of Stock
[Buy Now](https://www.adafruit.com/product/4493)
[Related Guides to the Product](https://learn.adafruit.com/products/4493/guides)

## Related Guides

- [Adafruit PiCowbell Adalogger for Pico](https://learn.adafruit.com/adafruit-picowbell-adalogger-for-pico.md)
- [NeoPixel Star Crown with WLED](https://learn.adafruit.com/neopixel-star-crown-with-wled.md)
- [EPCOT Spaceship Earth with WLED](https://learn.adafruit.com/epcot-spaceship-earth-with-wled.md)
- [CircuitPython on ESP32 Quick Start](https://learn.adafruit.com/circuitpython-with-esp32-quick-start.md)
- [Jellyfish Umbrella with easy WLED WiFi Control](https://learn.adafruit.com/jellyfish-umbrella-with-easy-wled-wifi-control.md)
- [Synchronized NeoPixel Shoelaces with WLED](https://learn.adafruit.com/neopixel-shoelaces-with-wled.md)
- [Fog Machine with Motion Sensor and Adafruit IO](https://learn.adafruit.com/fog-machine-remote-trigger.md)
- [NeoPixel Remote: IR Control with WLED](https://learn.adafruit.com/neopixel-remote-ir-control-with-wled.md)
- [No-Code IoT CO2 "Canary In a Coalmine"](https://learn.adafruit.com/iot-canary.md)
- [Adafruit QT Py ESP32-C3 WiFi Dev Board](https://learn.adafruit.com/adafruit-qt-py-esp32-c3-wifi-dev-board.md)
- [Sound Reactive LED Top Hat](https://learn.adafruit.com/sound-reactive-led-top-hat.md)
- [Icicle Crown with Pebble Pixels & WLED](https://learn.adafruit.com/icicle-crown-with-pebble-pixels-wled.md)
- [Adafruit Trinkey QT2040](https://learn.adafruit.com/adafruit-trinkey-qt2040.md)
- [Floor Lamp with NeoPixels and WLED Custom Animations](https://learn.adafruit.com/floor-lamp-with-wled.md)
- [Video Nub Shank: ESP32 QT Py Composite Video Injector](https://learn.adafruit.com/video-nub-shank-esp32-qt-py-composite-video-injector.md)
