# Adafruit 3.5" 480x320 TFT FeatherWing

## Overview

![](https://cdn-learn.adafruit.com/assets/assets/000/126/143/medium800/adafruit_products_3651-05.jpg?1700514734)

A Feather board without ambition is a Feather board without FeatherWings! Spice up your Feather project with a beautiful 3.5" touchscreen display shield with built in microSD card socket. This TFT display is 3.5" diagonal with a bright 6 white-LED backlight. You get a massive 480x320 pixels with individual 16-bit color pixel control. It has way more resolution than a black and white 128x64 display, and twice as much as our 2.4" TFT FeatherWing.

As a bonus, this display comes with a resistive touchscreen attached to it already, so you can detect finger presses anywhere on the screen.

![](https://cdn-learn.adafruit.com/assets/assets/000/047/642/medium800/adafruit_products_3651_iso_ORIG.jpg?1508958207)

 **New! As of Nov 15, 2023 we've made a big redesign to this product:** We now use the TSC2007 instead of the discontinued STMPE811 touchscreen controller. The screen and micro SD card are the same but any touchscreen code will need to be updated to use our Arduino or CircuitPython library. We've also updated the reset button to be right-angle and added a STEMMA QT port.

![](https://cdn-learn.adafruit.com/assets/assets/000/126/142/medium800/adafruit_products_3651-07.jpg?1700514706)

This FeatherWing uses a SPI display, touchscreen and SD card socket.&nbsp; **It works with any and all Feathers** but, given the large display, it works _best_ with our faster boards like the ESP32-S2, ESP32-S3, RP2040, M4, M0, nRF52, WICED, and Teensy. We also include a I2C resistive touchscreen controller with a separate IRQ line so you only need one additional pin to add a high quality touchscreen controller with interrupt support! One more pin is used for an optional SD card that can be used for storing images for display.

![](https://cdn-learn.adafruit.com/assets/assets/000/126/144/medium800/adafruit_products_3651-06.jpg?1700514758)

This 'Wing comes fully assembled with dual sockets for your Feather to plug into. You get two sockets per pin so you can plug in wires if you want to connect to Feather pins. Alternatively, each pin has a large square pad on the PCB for direct soldering.

![](https://cdn-learn.adafruit.com/assets/assets/000/047/663/medium800/adafruit_products_3651_CC_screen_demo_ORIG.jpg?1508968884)

# Adafruit 3.5" 480x320 TFT FeatherWing

## Pinouts - V1

Unlike most FeatherWings, the TFT FeatherWing is fully assembled and has a dual socket set for your Feather to plug into.

This makes it really easy to use, but a little different to change if you don't want the default setup

Warning: 

## Power Pins
The 3.5" TFT FeatherWing has a really beefy backlight, and we don't want to overwhem the 3.3V regulator on the Feather so we use two Schottkey diodes to take the higher of **VBAT** and **VUSB** to feed into the backlight boost converter.

The **GND** and **3.3V** pins are used for powering the rest of the device such as the TFT and touchscreen controller

![adafruit_products_power.jpg](https://cdn-learn.adafruit.com/assets/assets/000/047/648/medium640/adafruit_products_power.jpg?1508960165)

You can turn off the 3.3V power supply with the **EN** pin or the switch attached to that pin. The enable/disable switch on the bottom of the Wing will also deactivate the backlight

Note that on the Teensy 3x Feather Adapter, this pin doesn't do anything and on the FONA feather, this will not disable the VBAT power supply which is used to power the cellular module.

![adafruit_products_enable.jpg](https://cdn-learn.adafruit.com/assets/assets/000/047/647/medium640/adafruit_products_enable.jpg?1508960144)

## SPI Pins
The TFT display, SD card and touch screen use the SPI interface to communicate. That means **MISO** , **MOSI** and **SCK** are used whenever either are accessed.

_(Ooops the highlighted pins are off by one, they should be shifted to the right one pin!)_

![adafruit_products_spi.jpg](https://cdn-learn.adafruit.com/assets/assets/000/047/649/medium640/adafruit_products_spi.jpg?1508960227)

In addition, for the TFT display there is are **DC** (Data/Command) and **CS** (Chip Select) pins. These are used to select the display and tell it what kind of data is being sent. By default, **DC** is connected to **pin 10** and **CS** is connected to **pin 9**. These pins can theoretically be changed by cutting the jumper trace and soldering a small wire from the farther-from-the-socket-header pad to the pin you'd like to use.

On the **ESP8266** , TFT\_CS is pin #0, TFT\_DC is pin #15

On the **ESP32** , TFT\_CS is pin #15, TFT\_DC is pin #33

On the **Atmega32u4, ATmega328p, M4 or M0** Feather, TFT\_CS is pin #9, TFT\_DC is pin #10

On the **Teensy Feather** , TFT\_CS is pin #4, TFT\_DC is pin #10

On the **WICED Feather** , TFT\_CS is PA15 and TFT\_DC is PB4

On the **nRF52 Feather** , TFT\_CS is #31 and TFT\_DC is #11

![adafruit_products_tftpins.jpg](https://cdn-learn.adafruit.com/assets/assets/000/047/652/medium640/adafruit_products_tftpins.jpg?1508960331)

There is also **LITE** pin which is not connected to any pads but you can use to control the backlight. Pull low to turn off the backlight. You can connect it to a PWM output pin.

Warning: 

## Touch Screen control pins
The touch screen also has a Chip Select line, labeled **RT**. By default **RT** is connected to **pin 6**. This pin can theoretically be changed by cutting the jumper trance and soldering a small wire from the right-hand pad to the pin you'd like to use.

On the **ESP8266** , RT is pin #16

On the **ESP32** , RT is pin #32

On the **Atmega32u4, ATmega328p, M4 or M0** Feather, RT is pin #6

On the **Teensy Feather** , RT is pin #3

On the **WICED Feather** , RT is PC7

On the **nRF52 Feather** , RT is #30

There is also an **IRQ** pin which is not connected to any pads but you can use to detect when touch events have occured.

![adafruit_products_ts.jpg](https://cdn-learn.adafruit.com/assets/assets/000/047/653/medium640/adafruit_products_ts.jpg?1508960398)

## SD Card control pins
The SD Card also has a Chip Select line, labeled **SD**. By default, it is connected to **pin 5**. This pin can theoretically be changed by cutting the jumper trance and soldering a small wire from the right-hand pad to the pin you'd like to use.

On the **ESP8266** , SD is pin #2

On the **ESP32** SD is pin #14

On the **Atmega32u4, ATmega328p, M4 or M0** Feather, SD is pin #5

On the **Teensy Feather** , SD is pin #8

On the **WICED Feather** , SD is PC5

On the **nRF52 Feather** , SD is pin #27

![adafruit_products_sd.jpg](https://cdn-learn.adafruit.com/assets/assets/000/047/654/medium640/adafruit_products_sd.jpg?1508960461)

# Adafruit 3.5" 480x320 TFT FeatherWing

## Pinouts - V2

![](https://cdn-learn.adafruit.com/assets/assets/000/126/146/medium800/adafruit_products_3651-07.jpg?1700569827)

The default I2C address for the TSC2007 touchscreen controller is **0x48**.

## STEMMA QT Connector

- **[STEMMA QT](https://learn.adafruit.com/introducing-adafruit-stemma-qt) -** This connector, located between the on/off switch and microSD card slot, allows you to connect to sensors and breakout boards with STEMMA QT / Qwiic connectors or to other things with **[various associated accessories](https://www.adafruit.com/category/619).**
- **SDA/SCL** - The I2C pins for the STEMMA QT connector are connected to the default I2C GPIO pins directly next to pin 5.
- **3.3V/GND** - The power for the STEMMA QT connector is 3.3V. Ground is the common ground for power and logic.

## Default SPI Pins

The TFT (connected to an **HX8357** chipset) and microSD card on the FeatherWing are controlled via SPI.

- **MOSI** - This is the SPI MOSI ( **M** icrocontroller **O** ut / **S** erial **I** n) pin.
- **MISO** - This is the SPI MISO ( **M** icrocontroller **I** n / **S** erial **O** ut) pin.
- **SCK** - This is the **S** PI clo **ck** input pin.

## TFT Control Pins and Jumpers

- **DC** - This is the display SPI **d** ata/ **c** ommand selector pin. By default, it is connected to **pin 10**. To change this, cut the jumper. Then, connect the signal pad (closest to the label on the board silk) to one of the available and compatible GPIO pads.
- **TCS** - This is the TFT SPI **c** hip **s** elect pin. By default, is connected to **pin 9**. To change this, cut the jumper. Then, connect the signal pad (closest to the label on the board silk) to one of the available and compatible GPIO pads.
- **LITE** - This is the TFT backlight pad, located between the Feather headers and the TFT ribbon cable towards the top of the board. It is not connected to any pins by default. Pull this pin low to turn off the backlight.

## microSD Card Slot

- On the back of the FeatherWing, below the STEMMA QT port, is the microSD card slot. You can use any microSD card that supports SPI mode with one CS pin.

## SD Card Pins and Jumper

- **SCS** &nbsp;- This is the SD card **c** hip **s** elect pin. By default, it is connected to **pin 5**. To change this, cut the jumper. Then, connect the signal pad (closest to the label on the board silk) to one of the available and compatible GPIO pads.
- **SDDET** &nbsp;- This is the **c** ard **d** etect pad, located above the microSD card slot. It is not connected to any pins by default. This pin will read low when a card is _not_ inserted.

## Touch Screen Interrupt Jumper

- **IRQ** - This is the touchscreen interrupt pin. By default, it is connected to **pin 6**. To change this, cut the jumper. Then, connect the signal pad (closest to the label on the board silk) to one of the available and compatible GPIO pads.

Warning: Settings an alternate I2C address on the TSC2007 requires a resistor across the jumper pad. Using a Pull-Up between 2k - 10k ohms is ideal. An 0805 SMD fits well on the jumper pad.

## TSC2007 Address Jumpers

On the back of the board are **two**  **address jumpers** , labeled **A0** and **A1**** ,** towards the bottom center of the board. These jumpers allow you to change the default I2C address of the TSC2007 on the FeatherWing. To do so, you solder the jumpers "closed" by connecting the two pads.

The default I2C address is **0x48**. The other address options can be calculated by “adding” the **A0/A1** to the base of **0x48**.

**A0** sets the lowest bit with a value of **1** , **A1** sets the next bit with a value of **2**. The final address is **0x48 + A1 + A0** which would be **0x4B**.

 If only **A0** is soldered closed, the address is **0x48 + 1 = 0x49**

 If only **A1** is soldered closed, the address is **0x48 + 2 = 0x4A**

The table below shows all possible addresses, and whether the pin(s) should be high (closed) or low (open).

![](https://cdn-learn.adafruit.com/assets/assets/000/126/147/medium800/featherwings_adafruit_products_i2cTable.png?1700570470)

## Reset Button

- **Reset** - The reset button, located in the top left corner on the FeatherWing, is connected to the reset pin. It is mounted at a right angle so that it is easier to press.

## On/Off Switch

- **ON/OFF** - The On/Off switch, located on the left side of the FeatherWing, is connected to the **EN pin**. You can disconnect 3.3V power by setting the switch to **OFF**.

# Adafruit 3.5" 480x320 TFT FeatherWing

## TFT Graphics Test

![](https://cdn-learn.adafruit.com/assets/assets/000/047/661/medium800/adafruit_products_3651_screen_demo_06_ORIG.jpg?1508968813)

The TFT FeatherWing is basically a combination of our [3.5" TFT Breakout](https://www.adafruit.com/product/2050) with the [STMPE610 resistive touch-screen breakout attached](https://www.adafruit.com/products/1571).

Danger: 

# Install Libraries

You'll need a few libraries to use this FeatherWing!

From within the Arduino IDE, open up the **Library Manager...**

![](https://cdn-learn.adafruit.com/assets/assets/000/048/905/medium800/adafruit_products_libmanager.png?1512428223)

## Install Adafruit HX8357D TFT Library

We have example code ready to go for use with these TFTs.  
  
_Two_ libraries need to be downloaded and installed: first is the [Adafruit HX8357 library](https://github.com/adafruit/Adafruit_HX8357_Library) (this contains the low-level code specific to this device), and second is the [Adafruit GFX Library](https://github.com/adafruit/Adafruit-GFX-Library) (which handles graphics operations common to many displays we carry). If you have **Adafruit\_GFX** already, make sure its the most recent version since we've made updates for better performance

Search for **HX8357** and install the **Adafruit HX8357** library that pops up!

![](https://cdn-learn.adafruit.com/assets/assets/000/048/908/medium800/adafruit_products_hx8357.png?1512428278)

Next up, search for&nbsp; **Adafruit GFX** and locate the core library. A lot of libraries may pop up because we reference it in the description so just make sure you see **Adafruit GFX Library** in bold at the top.

Install it!

![](https://cdn-learn.adafruit.com/assets/assets/000/050/155/medium800/adafruit_products_gfxlib.png?1515895080)

If using an earlier version of the Arduino IDE (pre-1.8.10), locate and install&nbsp; **Adafruit\_BusIO** (newer versions handle this prerequisite automatically).

Repeat the search and install steps for the **Adafruit\_ImageReader** &nbsp;library.

[For more details about this process, we have a tutorial introducing Arduino library concepts and installation](http://learn.adafruit.com/adafruit-all-about-arduino-libraries-install-use).

# Basic Graphics Test

After restarting the Arduino software, you should see a new **example** folder called **Adafruit\_HX8357** and inside, an example called **graphicstest\_featherwing**.

![](https://cdn-learn.adafruit.com/assets/assets/000/047/655/medium800/adafruit_products_gfx.png?1508963394)

Upload that sketch to your Feather. You should see a collection of graphical tests draw out on the TFT.

![](https://cdn-learn.adafruit.com/assets/assets/000/047/660/medium800/adafruit_products_3651_screen_demo_01_ORIG.jpg?1508968788)

If you're having difficulties, check the serial console. The first thing the sketch does is read the driver configuration from the TFT, you should see the same numbers as below. That will help you determine if the TFT is found, if not, check your Feather soldering!

![](https://cdn-learn.adafruit.com/assets/assets/000/047/665/medium800/adafruit_products_testout.png?1508971199)

Once you've got the demo working, check out the detailed documentation over at [http://learn.adafruit.com/adafruit-gfx-graphics-library](http://learn.adafruit.com/adafruit-gfx-graphics-library) for more information on how to use the GFX library to draw whatever you like!

![](https://cdn-learn.adafruit.com/assets/assets/000/047/662/medium800/adafruit_products_3651_screen_demo_04_ORIG.jpg?1508968863)

# Adafruit 3.5" 480x320 TFT FeatherWing

## Adafruit GFX Library

![](https://cdn-learn.adafruit.com/assets/assets/000/025/661/medium800/adafruit_products_2478_screen_05_ORIG.jpg?1432756186)

The Adafruit\_GFX library for Arduino provides a common syntax and set of graphics functions for all of our TFT, LCD and OLED displays. This allows Arduino sketches to easily be adapted between display types with minimal fuss…and any new features, performance improvements and bug fixes will immediately apply across our complete offering of color displays.  
  
The GFX library is what lets you draw points, lines, rectangles, round-rects, triangles, text, etc.

![](https://cdn-learn.adafruit.com/assets/assets/000/025/662/medium800/adafruit_products_2478_screen_01_ORIG.jpg?1432756213)

Check out our detailed tutorial here [http://learn.adafruit.com/adafruit-gfx-graphics-library](http://learn.adafruit.com/adafruit-gfx-graphics-library)  
  
It covers the latest and greatest of the GFX library. The GFX library is used in both 8-bit and SPI modes so the underlying commands (drawLine() for example) are identical!

# Adafruit 3.5" 480x320 TFT FeatherWing

## Drawing Bitmaps

There is a built-in microSD card slot on the FeatherWing, and we can use that to load bitmap images! You will need a **microSD** card formatted **FAT16 or FAT32** (they almost always are by default), and an SD card reader on whatever computer you’re currently reading this with.  
  
It's really easy to draw bitmaps. Lets start by downloading this image of Adabot and friends:

![](https://cdn-learn.adafruit.com/assets/assets/000/047/656/medium800/adafruit_products_adabot.bmp?1508963711)

Download these two smaller images as well:

![](https://cdn-learn.adafruit.com/assets/assets/000/070/039/medium800/adafruit_products_parrot.bmp?1548457534)

![](https://cdn-learn.adafruit.com/assets/assets/000/070/040/medium800/adafruit_products_wales.bmp?1548457541)

The files should be renamed (if needed) to “ **adabot.bmp** ”, “ **parrot.bmp** ” and “ **wales.bmp** ”, respectively, and copied to the base directory of the microSD card (_not_ inside a folder).

(If it’s easier, you can also find these images in the “images” folder within the Adafruit\_ImageReader library folder.)

Insert the microSD card into the socket in the shield. Now select the sketch&nbsp; **file→examples→Adafruit\_ImageReader→**** FeatherWingHX8357&nbsp;**and upload this example to your Feather + Wing. You will see the your electronic friends appear! (Plus parrots…and if you’re using one of the more powerful Feather boards, a whole lot of dragons.)

![](https://cdn-learn.adafruit.com/assets/assets/000/047/659/medium800/adafruit_products_3651_CC_screen_demo_ORIG.jpg?1508968745)

**The Adafruit\_ImageReader library, which is being used here to display .BMP images, is [fully explained in its own page of the Adafruit\_GFX guide](https://learn.adafruit.com/adafruit-gfx-graphics-library/loading-images).**

# Adafruit 3.5" 480x320 TFT FeatherWing

## Resistive Touch Screen - V1

The LCD has a 4-wire resistive touch screen glued onto it. You can use this for detecting finger-presses, stylus', etc. Normally, you'll need 4 pins to talk to the touch panel **but** we decided to go all snazzy and put a dedicated touch screen driver onto the shield. The driver shares the SPI pins with the TFT and SD card, so only one extra pin is needed. This allows you to query the controller when you're ready to read touchscreen data, and saves 3 pins.  
  
[To control the touchscreen you'll need one more library](https://github.com/adafruit/Adafruit_STMPE610) - the STMPE610 controller library which does all the low level chatting with the STMPE610 driver chip. Use the library manager to install the **Adafruit STMPE610** library

![](https://cdn-learn.adafruit.com/assets/assets/000/050/042/medium800/featherwings_stmpe.png?1515773665)

# Touchscreen Paint Demo

Now that you've got the basic TFT graphics demo working, let's add in the touchscreen. Run and upload the **touchpaint\_featherwing** demo

- If you have the **2.4" TFT** Featherwing, run the **Adafruit ILI9341-\>touchpaint\_featherwing** demo
- If you have the **3.5" TFT** Featherwing, run the **Adafruit HX8357-\>touchpaint\_featherwing** demo

![](https://cdn-learn.adafruit.com/assets/assets/000/037/202/medium800/feather_touchpaint.png?1478725413)

Upload to your Feather and have fun!

![](https://cdn-learn.adafruit.com/assets/assets/000/037/218/medium800/feather_heart.jpg?1478730535)

Danger: 

Getting data from the touchscreen is fairly straight forward. Start by creating the touchscreen object with

> **Adafruit\_STMPE610 ts = Adafruit\_STMPE610(STMPE\_CS);**

We're using hardware SPI so the clock, mosi and miso pins are not defined here.  
Then you can start the touchscreen with

> **ts.begin()**

Check to make sure this returns a True value, which means the driver was found. If it wasn't, make sure you have the Feather soldered right and the correct CS pin!  
  
Now you can call

> **if (! ts.bufferEmpty()**)

to check if there's any data in the buffer. The touchscreen driver will store touchpoints at all times. When you're ready to get the data, just check if there's any data in the buffer. If there is, you can call

> **TS\_Point p = ts.getPoint();**

To get the oldest point from the buffer. TS\_Point has **.x .y** and . **z** data points. The **x** and **y** points range from 0 to 4095. The STMPE610 does not store any calibration data in it and it doesn't know about rotation. **So if you want to rotate the screen you'll need to manually rotate the x/y points!** The z point is 'pressure' and ranges from 0 to 255, we don't use it here but you can experiment with it on your own, the harder you press, the lower the number.  
  
Since data from the STMPE610 comes in 0-4095 but our screen is 320 pixels by 240 pixels, we can use **map** to convert 0-4095 to 0-320 or 0-240. Something like

> **p.x = map(p.x, 0, 4095, 0, tft.width());**  
> **p.y = map(p.y, 0, 4095, 0, tft.height());**

However, the touchscreen is a bit bigger than the screen, so we actually need to ignore presses beyond the touchscreen itself. We found that these numbers reflected the true range that overlaps the screen

> **#define TS\_MINX 150**  
> **#define TS\_MINY 130**  
> **#define TS\_MAXX 3800**  
> **#define TS\_MAXY 4000**

So we use

> **p.x = map(p.x, TS\_MINX, TS\_MAXX, 0, tft.width());**  
> **p.y = map(p.y, TS\_MINY, TS\_MAXY, 0, tft.height());**

instead.  
  
One last point (pun intended!) since the touchscreen driver stores points in a buffer, you may want to ask the driver "is the touchscreen being pressed RIGHT NOW?" You can do that with

> **if (ts.touched())**

# Adafruit 3.5" 480x320 TFT FeatherWing

## Resistive Touch Screen - V2

Using the 3.5" TFT FeatherWing V2 with Arduino involves plugging a Feather board into the FeatherWing. Then, you'll install the necessary libraries and upload the example code to the Feather board.

This page uses the Feather RP2040 for demonstrating Arduino usage. You can use the same concepts to get going with any Feather board.

### Adafruit Feather RP2040

[Adafruit Feather RP2040](https://www.adafruit.com/product/4884)
A new chip means a new Feather, and the Raspberry Pi RP2040 is no exception. When we saw this chip we thought "this chip is going to be awesome when we give it the Feather Treatment" and so we did! This Feather features the&nbsp; **RP2040** , and all niceties you know and...

In Stock
[Buy Now](https://www.adafruit.com/product/4884)
[Related Guides to the Product](https://learn.adafruit.com/products/4884/guides)
![Angled shot of black rectangular microcontroller "Feather RP2040"](https://cdn-shop.adafruit.com/640x480/4884-04.jpg)

## Hardware Setup
Plug your Feather into the FeatherWing. The USB port on the Feather will be pointing away from the microSD card slot.&nbsp;

![adafruit_products_IMG_0095.png](https://cdn-learn.adafruit.com/assets/assets/000/126/154/medium640/adafruit_products_IMG_0095.png?1700587171)

## Library Installation

You can install the **Adafruit HX8357** library for Arduino using the Library Manager in the Arduino IDE.

![](https://cdn-learn.adafruit.com/assets/assets/000/126/149/medium800/adafruit_products_Arduino_Open_Library_Manager.png?1700571109)

Click the **Manage Libraries...** menu item, search for **Adafruit HX8357** , and select the **Adafruit\_HX8357\_Library** &nbsp;library:

![](https://cdn-learn.adafruit.com/assets/assets/000/126/155/medium800/adafruit_products_ard_lib.png?1700604687)

If asked about dependencies, click "Install all".

![](https://cdn-learn.adafruit.com/assets/assets/000/126/156/medium800/adafruit_products_depends.png?1700604694)

Warning: 

## Example Code
https://github.com/adafruit/Adafruit_HX8357_Library/blob/master/examples/touchpaint_featherwing/touchpaint_featherwing.ino

![](https://cdn-learn.adafruit.com/assets/assets/000/126/157/medium800/adafruit_products_ard_serial.png?1700604705)

Upload the sketch to your board and open up the Serial Monitor ( **Tools -\> Serial Monitor** ) at 115200 baud. In the Serial Monitor, you should see the values from the touch screen being printed out.

The first number is the X coordinate, the second number is the Y coordinate and the last two numbers are Z "pressure" coordinates that can tell you how hard the touch pad is being pressed.

On the TFT, you'll be able to doodle with the different colors on the left side of the screen.

![](https://cdn-learn.adafruit.com/assets/assets/000/126/184/medium800thumb/adafruit_products_paintdemo.jpg?1701115957)

# Adafruit 3.5" 480x320 TFT FeatherWing

## Arduino Docs

# Adafruit 3.5" 480x320 TFT FeatherWing

## CircuitPython Displayio Quickstart - V1

The steps to get the 3.5" TFT FeatherWing, which has an HX8357 display on it, are very similar to the 2.4" TFT FeatherWing. If you would like more information on this display, be sure to check out our&nbsp;[Adafruit 3.5" TFT FeatherWing guide](https://learn.adafruit.com/adafruit-3-5-tft-featherwing).

# Parts

To use this display with displayio, you will only need two main parts. First, you will need the TFT FeatherWing itself. One thing to note with this display is because of the increased resolution, updates will be a little slower for this display than for the other displays.

### Adafruit TFT FeatherWing - 3.5" 480x320 Touchscreen for Feathers

[Adafruit TFT FeatherWing - 3.5" 480x320 Touchscreen for Feathers](https://www.adafruit.com/product/3651)
Spice up your Feather project with a beautiful 3.5" touchscreen display shield with built in microSD card socket. This TFT display is 3.5" diagonal with a bright 6 white-LED backlight. You get a massive 480x320 pixels with individual 16-bit color pixel control. It has way more...

In Stock
[Buy Now](https://www.adafruit.com/product/3651)
[Related Guides to the Product](https://learn.adafruit.com/products/3651/guides)
![Overhead shot of a Black woman's hands with a blue and pinkish-red manicure drawing a heart on a touchscreen breakout.](https://cdn-shop.adafruit.com/640x480/3651-05.jpg)

And second, you will need a Feather such as theFeather M0 Express or the Feather M4 Express. We recommend the Feather M4 Express because it's much faster and works better for driving a display.

### Adafruit Feather M4 Express - Featuring ATSAMD51

[Adafruit Feather M4 Express - Featuring ATSAMD51](https://www.adafruit.com/product/3857)
It's what you've been waiting for, the Feather M4 Express featuring ATSAMD51. This Feather is fast like a swift, smart like an owl, strong like a ox-bird (it's half ox, half bird, OK?) This feather is powered by our new favorite chip, the **ATSAMD51J19** -&nbsp; with...

In Stock
[Buy Now](https://www.adafruit.com/product/3857)
[Related Guides to the Product](https://learn.adafruit.com/products/3857/guides)
![Angled shot of a Adafruit Feather M4 Express. ](https://cdn-shop.adafruit.com/640x480/3857-10.jpg)

For this guide, we'll assume you have a Feather M4 Express. The steps should be about the same for the Feather M0 Express. To start, if you haven't already done so, follow the assembly instructions for the Feather M4 Express in our&nbsp;[Feather M4 Express guide](https://learn.adafruit.com/adafruit-feather-m4-express-atsamd51/assembly). We'll start by looking at the back of the 3.5" TFT FeatherWing.&nbsp;

![](https://cdn-learn.adafruit.com/assets/assets/000/075/032/medium800/circuitpython_3.5-reverse.png?1556509731)

After that, it's just a matter of inserting the Feather M4 Express into the back of the TFT FeatherWing.

![](https://cdn-learn.adafruit.com/assets/assets/000/075/033/medium800/circuitpython_3.5-assembled.png?1556509770)

# Required CircuitPython Libraries

To use this display with `displayio`, there is only one required library.

[Adafruit_CircuitPython_HX8357](https://github.com/adafruit/Adafruit_CircuitPython_HX8357/releases)
First, make sure you are running the&nbsp;[latest version of Adafruit CircuitPython](https://learn.adafruit.com/welcome-to-circuitpython/installing-circuitpython)&nbsp;for your board.

Next, you'll need to install the necessary libraries&nbsp;to use the hardware--carefully follow the steps to find and install these libraries from&nbsp;[Adafruit's CircuitPython library bundle](https://github.com/adafruit/Adafruit_CircuitPython_Bundle).&nbsp; Our introduction guide has&nbsp;[a great page on how to install the library bundle](https://learn.adafruit.com/welcome-to-circuitpython/circuitpython-libraries)&nbsp;for both express and non-express boards.

Remember for non-express boards, you'll need to manually install the necessary libraries from the bundle:

- **adafruit\_hx8357**

Before continuing make sure your board's lib folder or root filesystem has the&nbsp; **adafruit\_hx8357** &nbsp;file copied over.

## Code Example Additional Libraries

For the Code Example, you will need an additional library. We decided to make use of a library so the code didn't get overly complicated.

[Adafruit_CircuitPython_Display_Text](https://github.com/adafruit/Adafruit_CircuitPython_Display_Text)
Go ahead and install this in the same manner as the driver library by copying the&nbsp; **adafruit\_display\_text** folder over to the **lib** folder on your CircuitPython device.

# CircuitPython Code Example
https://github.com/adafruit/Adafruit_CircuitPython_HX8357/blob/main/examples/hx8357_simpletest.py

Let's take a look at the sections of code one by one.&nbsp;We start by importing the board so that we can initialize `SPI`, `displayio`, `terminalio` for the font, a `label`, and the `adafruit_hx8357`&nbsp;driver.

```
import board
import displayio
import terminalio
from adafruit_display_text import label
from adafruit_hx8357 import HX8357
```

Next we release any previously used displays. This is important because if the Feather is reset, the display pins are not automatically released and this makes them available for use again.

```
displayio.release_displays()
```

Next, we set the SPI object to the board's SPI with the easy shortcut function `board.SPI()`. By using this function, it finds the SPI module and initializes using the default SPI parameters. Next we set the Chip Select and Data/Command pins that will be used.

```
spi = board.SPI()
tft_cs = board.D9
tft_dc = board.D10
```

In the next line, we set the display bus to FourWire which makes use of the SPI bus.

```
display_bus = displayio.FourWire(spi, command=tft_dc, chip_select=tft_cs)
```

Finally, we initialize the driver with a width of 480 and a height of 320. If we stopped at this point and ran the code, we would have a terminal that we could type at and have the screen update.

```
display = HX8357(display_bus, width=480, height=320)
```

![](https://cdn-learn.adafruit.com/assets/assets/000/075/037/medium800/circuitpython_3.5-terminal.png?1556511521)

Next we create a background splash image. We do this by creating a group that we can add elements to and adding that group to the display. The display will automatically handle updating the group.

```auto
splash = displayio.Group()
display.show(splash)
```

After that we create a Bitmap which is like a canvas that we can draw on. In this case we are creating the Bitmap to be the same size as the screen, but only have one color. The Bitmaps can currently handle up to 256 different colors. We create a Palette with one color and set that color to 0x00FF00 which happens to be green. Colors are Hexadecimal values in the format of RRGGBB. Even though the Bitmaps can only handle 256 colors at a time, you get to define what those 256 different colors are.

```
color_bitmap = displayio.Bitmap(480, 320, 1)
color_palette = displayio.Palette(1)
color_palette[0] = 0x00FF00 # Bright Green
```

With all those pieces in place, we create a TileGrid by passing the bitmap and palette and draw it at `(0, 0)` which represents the display's upper left.

```
bg_sprite = displayio.TileGrid(color_bitmap,
                               pixel_shader=color_palette,
                               x=0, y=0)
splash.append(bg_sprite)
```

This creates a solid green background which we will draw on top of.

![](https://cdn-learn.adafruit.com/assets/assets/000/079/142/medium800/circuitpython_3.5-green.jpg?1565135041)

Next we will create a smaller purple rectangle. The easiest way to do this is the create a new bitmap that is a little smaller than the full screen with a single color and place it in a specific location. In this case we will create a bitmap that is 20 pixels smaller on each side. The screen is 480x320, so we'll want to subtract 40 from each of those numbers.

We'll also want to place it at the position&nbsp;`(20, 20)` so that it ends up centered.

```
# Draw a smaller inner rectangle
inner_bitmap = displayio.Bitmap(440, 280, 1)
inner_palette = displayio.Palette(1)
inner_palette[0] = 0xAA0088 # Purple
inner_sprite = displayio.TileGrid(inner_bitmap,
                                  pixel_shader=inner_palette,
                                  x=20, y=20)
splash.append(inner_sprite)
```

Since we are adding this after the first rectangle, it's automatically drawn on top. Here's what it looks like now.

![](https://cdn-learn.adafruit.com/assets/assets/000/079/143/medium800/circuitpython_3.5-green-purple.jpg?1565135072)

Next let's add a label that says "Hello World!" on top of that. We're going to use the built-in Terminal Font and scale it up by a factor of three. To scale the label only, we will make use of a subgroup, which we will then add to the main group.

Labels are centered vertically, so we'll place it at 160 for the Y coordinate, and around 137 pixels make it appear to be centered horizontally, but if you want to change the text, change this to whatever looks good to you. Let's go with some yellow text, so we'll pass it a value of `0xFFFF00`.

```auto
# Draw a label
text_group = displayio.Group(scale=3, x=137, y=160)
text = "Hello World!"
text_area = label.Label(terminalio.FONT, text=text, color=0xFFFF00)
text_group.append(text_area) # Subgroup for text scaling
splash.append(text_group)
```

Finally, we place an infinite loop at the end so that the graphics screen remains in place and isn't replaced by a terminal.

![](https://cdn-learn.adafruit.com/assets/assets/000/079/144/medium800/circuitpython_3.5-hello-world.jpg?1565135110)

```
while True:
    pass
```

## Using Touch

We won't be covering how to use the touchscreen on the shield with CircuitPython in this guide, but the library required for enabling resistive touch is the&nbsp;[Adafruit\_CircuitPython\_STMPE610](https://github.com/adafruit/Adafruit_CircuitPython_STMPE610) library.

# Where to go from here

Be sure to check out this excellent&nbsp;[guide to CircuitPython Display Support Using displayio](https://learn.adafruit.com/circuitpython-display-support-using-displayio)

# Adafruit 3.5" 480x320 TFT FeatherWing

## CircuitPython Displayio Quickstart - V2

Using the 3.5" TFT FeatherWing V2 with CircuitPython involves plugging a Feather board into the FeatherWing. Then, you load the code and necessary libraries onto your Feather board to run the example.

This page uses the Feather RP2040 for demonstrating CircuitPython usage. You can use the same concepts to get going with any classic Feather board.

### Adafruit Feather RP2040

[Adafruit Feather RP2040](https://www.adafruit.com/product/4884)
A new chip means a new Feather, and the Raspberry Pi RP2040 is no exception. When we saw this chip we thought "this chip is going to be awesome when we give it the Feather Treatment" and so we did! This Feather features the&nbsp; **RP2040** , and all niceties you know and...

In Stock
[Buy Now](https://www.adafruit.com/product/4884)
[Related Guides to the Product](https://learn.adafruit.com/products/4884/guides)
![Angled shot of black rectangular microcontroller "Feather RP2040"](https://cdn-shop.adafruit.com/640x480/4884-04.jpg)

## Hardware Setup
Plug your Feather into the FeatherWing. The bottom of the Feather will be above the FeatherWing STEMMA QT port.

![adafruit_products_IMG_0095.png](https://cdn-learn.adafruit.com/assets/assets/000/126/153/medium640/adafruit_products_IMG_0095.png?1700587009)

## CircuitPython Usage

To use with CircuitPython, you need to first install the necessary libraries, and their dependencies, into the **lib** folder on your **CIRCUITPY** drive. Then you need to update **code.py** with the example script.

Thankfully, we can do this in one go. In the example below, click the **Download Project Bundle** button below to download the necessary libraries and the **code.py** file in a zip file. Extract the contents of the zip file.

Connect the microcontroller to your computer via a known-good USB power+data cable. The board shows up as a thumb drive named **CIRCUITPY**. Copy the **entire lib folder** , the **bitmap image files** , and the **code.py** file to your **CIRCUITPY** drive.

Your **CIRCUITPY/lib** folder should contain the following folder and files:

- **/adafruit\_bus\_device**
- **adafruit\_hx8357.mpy**
- **adafruit\_tsc2007.mpy**

Once you have copied over the necessary folders and files, your **CIRCUITPY** drive should resemble the following:

![CIRCUITPY](https://adafruit.github.io/Adafruit_Learning_System_Guides/TFT_FeatherWing_V2_CircuitPython_Example.png )

## Example Code
https://github.com/adafruit/Adafruit_Learning_System_Guides/blob/main/TFT_FeatherWing_V2_CircuitPython_Example/code.py

Once everything is saved to the **CIRCUITPY** drive, [connect to the serial console](https://learn.adafruit.com/welcome-to-circuitpython/kattni-connecting-to-the-serial-console) to see the data printed out!

![](https://cdn-learn.adafruit.com/assets/assets/000/126/150/medium800/adafruit_products_cp_repl.png?1700585379)

The code will open all of the bitmap files that are on the **CIRCUITPY** drive and add them to the `images` array. The first image will then be displayed on the TFT. In the loop, if you touch the screen you'll see the coordinates and pressure print to the serial console.

If you press on the left side of the screen, the display will show the previous bitmap in the array. If you press on the right side of the screen, the display will show the next bitmap in the array.

# Adafruit 3.5" 480x320 TFT FeatherWing

## Python Docs

# Adafruit 3.5" 480x320 TFT FeatherWing

## Troubleshooting

### 

The display driver circuit needs a small amount of time to be ready after initial power. If your code tries to write to the display too soon, it may not be ready. It will work on reset since that typically does not cycle power. If you are having this issue, try adding a small amount of delay before trying to write to the display.

In Arduino, use **delay()** to add a few milliseconds before calling **tft.begin()**. Adjust the amount of delay as needed to see how little you can get away with for your specific setup.

# Adafruit 3.5" 480x320 TFT FeatherWing

## Downloads

## Datasheets & More

- [STMPE610 Touch Controller Datasheet](http://www.adafruit.com/datasheets/STMPE610.pdf)
- [TSC2007 Touch Controller Datasheet](https://cdn-learn.adafruit.com/assets/assets/000/110/401/original/tsc2007.pdf?1648820788)
- [Datasheet for the HX8357D chipset controller](http://www.adafruit.com/datasheets/HX8357-D_DS_April2012.pdf)
- [Datasheet for the 3.5" TFT display (raw)](http://www.adafruit.com/datasheets/Adafruit35inTFT.pdf)
- [EagleCAD PCB files on GitHub](https://github.com/adafruit/Adafruit-3.5in-TFT-Featherwing-PCB)
- [Fritzing object in Adafruit Fritzing library - V1](https://github.com/adafruit/Fritzing-Library/blob/master/parts/Adafruit%203.5in%20480x320%20TFT%20FeatherWing.fzpz)
- [Fritzing object in Adafruit Fritzing library - V2](https://github.com/adafruit/Fritzing-Library/blob/master/parts/Adafruit%20TFT%20FeatherWing%20-%203.5%20inch%20480x320%20-%20V2.fzpz)

## Schematic and Fab Print

### Rev B
![](https://cdn-learn.adafruit.com/assets/assets/000/126/140/medium800/adafruit_products_schem.png?1700508411)

![](https://cdn-learn.adafruit.com/assets/assets/000/126/141/medium800/adafruit_products_fab.png?1700508421 dimensions are in inches)

### Rev A
![](https://cdn-learn.adafruit.com/assets/assets/000/047/657/medium800/adafruit_products_schem.png?1508965762)

![](https://cdn-learn.adafruit.com/assets/assets/000/047/658/medium800/adafruit_products_fabprint.png?1508965770)


## Primary Products

### Adafruit TFT FeatherWing - 3.5" 480x320 Touchscreen for Feathers

[Adafruit TFT FeatherWing - 3.5" 480x320 Touchscreen for Feathers](https://www.adafruit.com/product/3651)
Spice up your Feather project with a beautiful 3.5" touchscreen display shield with built in microSD card socket. This TFT display is 3.5" diagonal with a bright 6 white-LED backlight. You get a massive 480x320 pixels with individual 16-bit color pixel control. It has way more...

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

## Related Guides

- [CircuitPython Display_Text Library](https://learn.adafruit.com/circuitpython-display-text-library.md)
- [Using LittlevGL with Adafruit Displays](https://learn.adafruit.com/using-littlevgl-with-adafruit-displays.md)
- [CircuitPython displayio Setup for TFT FeatherWings](https://learn.adafruit.com/using-circuitpython-displayio-with-a-tft-featherwing.md)
- [TFT Spirit Board](https://learn.adafruit.com/tft-spirit-board.md)
- [CircuitPython Text Editor On The Go](https://learn.adafruit.com/circuitpython-text-editor-on-the-go.md)
- [ESP32-S3 BLE iOS Media Controller](https://learn.adafruit.com/esp32-s3-ble-ios-media-controller.md)
- [Creating Custom Symbol Fonts for Adafruit GFX Library](https://learn.adafruit.com/creating-custom-symbol-font-for-adafruit-gfx-library.md)
- [Touch Deck: DIY Customizable TFT Control Pad](https://learn.adafruit.com/touch-deck-diy-tft-customized-control-pad.md)
- [MIDI Foot Pedal](https://learn.adafruit.com/midi-foot-pedal.md)
- [Adafruit Radio Bonnets with OLED Display - RFM69 or RFM9X](https://learn.adafruit.com/adafruit-radio-bonnets.md)
- [LED Glasses Custom Animated Graphics with Sprites](https://learn.adafruit.com/led-glasses-custom-animated-graphics-with-sprites.md)
- [Making oscilloscope images with DACs](https://learn.adafruit.com/dac-oscilloscope-images.md)
- [Adafruit 9-DOF IMU Breakout](https://learn.adafruit.com/adafruit-9-dof-imu-breakout.md)
- [Wireless ESP32-S2 Touch Screen Controller for Pure Data](https://learn.adafruit.com/wireless-esp32-s2-controller-for-pure-data.md)
- [Neo Trinkey Zoom Shortcuts](https://learn.adafruit.com/neo-trinkey-zoom-shortcuts.md)
