There are so many great features on the Adafruit PyPortal Titano. Let's take a look at what's available!
The main processor chip is the ATSAMD51J20 Cortex M4 running at 120MHz with 3.3v logic/power. It has 1MB of Flash and 256KB of RAM.
We also include 8 MB of QSPI Flash for storing images, sounds, animations, whatever!
The WiFi capability uses an Espressif ESP32 Wi-Fi coprocessor with TLS/SSL support built-in.
The ESP32 uses the SPI port for data, and also uses a CS pin (board.ESP_CS
or Arduino 8
), Ready/Busy pin (board.ESP_BUSY
or Arduino 5
), and reset pin (board.ESP_RESET
or Arduino 7
)
- You can also connect to the ESP32 RTS pin (used in some serial contexts) on
board.ESP_RTS
or Arduino51
. - The ESP32 GPIO0 pin for bootloader enable is connected to
board.ESP_GPIO0
or Arduino6
On the front is a 3.5″ diagonal 320 x 480 color TFT with resistive touch screen! The display uses the HX8357 chipset - check out the datasheet for more information.
On the back, there is a large connector near the middle, the display connector. It connects the display on the front to the board.
To give you the most data throughput, we configure the screen for 8-bit interfacing. That means 8 data lines and a collection of 4 or 5 control lines. If you really want to use the screen in SPI mode, you can do so by soldering closed the SPI jumper and cutting/resoldering the 8/SPI jumper over to the SPI side. That's for advanced users!
The touchscreen is fully analog/resistive. It can be read using our Arduino/CircuitPython drivers. The connections are as follows:
- YD on
board.TOUCH_YD
or ArduinoA4
- XL on
board.TOUCH_XL
or ArduinoA5
- YU on
board.TOUCH_YU
or ArduinoA6
- XR on
board.TOUCH_XR
or ArduinoA7
The 8 bit LCD interface is not exposed in CircuitPython (its managed internally). In Arduino it's on Digital 34 thru 41, which is on a PORTA 8-bit boundary (PA16-PA23) and can be used for DMA or fast port writes. This probably doesn't affect you.
There are multiple control pins
-
TFT Reset -
board.TFT_RESET
or Arduino24
-
TFT WR -
board.TFT_WR
or Arduino26
(this is also theboard.TFT_DC
pin if using in SPI mode) -
TFT RD -
board.TFT_RD
or Arduino9
-
TFT RS -
board.TFT_RS
or Arduino10
-
TFT CS -
board.TFT_CS
or Arduino11
-
TFT TE -
board.TFT_TE
or Arduino12
There is also a TFT backlight, transistor-connected to board.TFT_BACKLIGHT
or Arduino 25
. You can PWM control it. There are 6 white LEDs connected in parallel, so having it be full on will draw quite a bit of current (over 100mA!)
There is an ambient light sensor on the side, which points through to the front, as seen in the second image. The light sensor is an analog input, connected to board.LIGHT
(CircuitPython) or A2
(Arduino) you can read it as any analog value ranging from 0
(dark) to 1023
(in Arduino) or 65535
(CircuitPython) when bright.
On the left side, there is a microSD card slot. A microSD card is the best way to add extra storage to your project and provide space for streams to be processed!
The SD card is on the main SPI port (shared with the ESP32) and a CS line. In CircuitPython, the CS pin is board.SD_CS
. In Arduino, it's digital 32
.
There is also a card detect pin on board.SD_CARD_DETECT
(CircuitPython) or Arduino 33
There is a speaker and a speaker connector.
The grey squarish bit on the bottom is a speaker. There is a small class D amplifier connected to the speaker, so it can get quite loud!
There is also a speaker connector, which is a Molex PicoBlade. You can attach one of the speakers available in the Adafruit shop, or solder a connector to your favorite speaker. If you do, cut the small solder jumper to the left of the buzzer so that you only have one speaker activated (and also it will be louder!)
The speaker is connected to the DAC0 output from the SAMD51, via a class D amplifier. The analog output is known as board.AUDIO_OUT
in CircuitPython. In Arduino its A0
.
You can disable the speaker amplifier by setting the shutdown pin to output and low. It's on board.SPEAKER_ENABLE
and Arduino 50
There is a 4-pin JST I2C connector in the center on the right, that is STEMMA and Grove compatible. The I2C has level-shifting & pullups to 3.3V power.
The I2C connector defaults to 5V. There is a jumper you can cut or solder to change it between 5V and 3V.
In CircuitPython, you can use the STEMMA connector with board.SCL
and board.SDA
, or board.STEMMA_I2C()
.
The connector is a JST PH-sized connector. STEMMA QT breakouts use JST SH connectors, which are smaller, so you will need a JST PH to SH connector (for example, this one).
On the right side are two connectors labeled D3 and D4. These are 3-pin JST digital or analog connectors for sensors or NeoPixels. These pins can be analog inputs or digital I/O.
They have protection 1K resistors + 3.6V zener diodes so you can drive an LED directly from the output. Connect to them via board.D3
and board.D4
or Arduino 3
and 4
. For analog reading in Arduino use A1 for D3 and A3 for D4 (yeah, sorry it's not matchy!)
D3/A1 is the second DAC.
There are two LEDs on the board.
There is the RGB status NeoPixel labeled "STATUS". It is connected to board.NEOPIXEL
or Arduino 2
As well, there is the D13 LED. This is attached to board.L
and Arduino 13
There is one USB port on the board.
On the left side, towards the bottom, is a USB Type-C port, which is used for powering and programming the board.
Text editor powered by tinymce.