20 #ifndef _ADAFRUIT_SPITFT_H_ 21 #define _ADAFRUIT_SPITFT_H_ 24 #if !defined(__AVR_ATtiny85__) && !defined(__AVR_ATtiny84__) 26 #include "Adafruit_GFX.h" 33 #define USE_FAST_PINIO 34 #elif defined(ARDUINO_STM32_FEATHER) // WICED 35 typedef class HardwareSPI SPIClass;
37 #elif defined(__arm__) 38 #if defined(ARDUINO_ARCH_SAMD) 41 #define USE_FAST_PINIO 42 #define HAS_PORT_SET_CLR 43 #elif defined(CORE_TEENSY) 45 #if defined(__IMXRT1052__) || defined(__IMXRT1062__) // Teensy 4.x 51 #define USE_FAST_PINIO 52 #define HAS_PORT_SET_CLR 69 #if defined(__AVR__) && !defined(__LGT8F__) 70 #define DEFAULT_SPI_FREQ 8000000L 72 #define DEFAULT_SPI_FREQ 16000000L 75 #if defined(ADAFRUIT_PYPORTAL) || defined(ADAFRUIT_PYPORTAL_M4_TITANO) || \ 76 defined(ADAFRUIT_PYBADGE_M4_EXPRESS) || \ 77 defined(ADAFRUIT_PYGAMER_M4_EXPRESS) || \ 78 defined(ADAFRUIT_MONSTER_M4SK_EXPRESS) || defined(NRF52_SERIES) || \ 79 defined(ADAFRUIT_CIRCUITPLAYGROUND_M0) 91 #if defined(USE_SPI_DMA) && (defined(__SAMD51__) || defined(ARDUINO_SAMD_ZERO)) 92 #include <Adafruit_ZeroDMA.h> 107 #if defined(ARDUINO_ARCH_RP2040) 108 #ifndef __SPI0_DEVICE 109 #define __SPI0_DEVICE spi0 111 #ifndef __SPI1_DEVICE 112 #define __SPI1_DEVICE spi1 141 Adafruit_SPITFT(uint16_t w, uint16_t h, int8_t cs, int8_t dc, int8_t mosi,
142 int8_t sck, int8_t rst = -1, int8_t miso = -1);
152 #if !defined(ESP8266) // See notes in .cpp 157 int8_t dc, int8_t rst = -1);
158 #endif // end !ESP8266 166 int8_t wr, int8_t dc, int8_t cs = -1, int8_t rst = -1,
181 virtual void begin(uint32_t freq) = 0;
195 virtual void setAddrWindow(uint16_t x, uint16_t y, uint16_t w,
207 void initSPI(uint32_t freq = 0, uint8_t spiMode = SPI_MODE0);
213 void sendCommand(uint8_t commandByte, uint8_t *dataBytes,
214 uint8_t numDataBytes);
215 void sendCommand(uint8_t commandByte,
const uint8_t *dataBytes = NULL,
216 uint8_t numDataBytes = 0);
217 void sendCommand16(uint16_t commandWord,
const uint8_t *dataBytes = NULL,
218 uint8_t numDataBytes = 0);
219 uint8_t
readcommand8(uint8_t commandByte, uint8_t index = 0);
228 void writePixel(int16_t x, int16_t y, uint16_t color);
229 void writePixels(uint16_t *colors, uint32_t len,
bool block =
true,
230 bool bigEndian =
false);
231 void writeColor(uint16_t color, uint32_t len);
232 void writeFillRect(int16_t x, int16_t y, int16_t w, int16_t h,
234 void writeFastHLine(int16_t x, int16_t y, int16_t w, uint16_t color);
235 void writeFastVLine(int16_t x, int16_t y, int16_t h, uint16_t color);
242 int16_t h, uint16_t color);
249 void swapBytes(uint16_t *src, uint32_t len, uint16_t *dest = NULL);
255 void drawPixel(int16_t x, int16_t y, uint16_t color);
256 void fillRect(int16_t x, int16_t y, int16_t w, int16_t h, uint16_t color);
257 void drawFastHLine(int16_t x, int16_t y, int16_t w, uint16_t color);
258 void drawFastVLine(int16_t x, int16_t y, int16_t h, uint16_t color);
265 void drawRGBBitmap(int16_t x, int16_t y, uint16_t *pcolors, int16_t w,
269 uint16_t
color565(uint8_t r, uint8_t g, uint8_t b);
303 #if defined(USE_FAST_PINIO) 304 #if defined(HAS_PORT_SET_CLR) 305 #if defined(KINETISK) 308 *csPortSet = csPinMask;
309 #endif // end !KINETISK 310 #else // !HAS_PORT_SET_CLR 311 *csPort |= csPinMaskSet;
312 #endif // end !HAS_PORT_SET_CLR 313 #else // !USE_FAST_PINIO 314 digitalWrite(
_cs, HIGH);
315 #endif // end !USE_FAST_PINIO 325 #if defined(USE_FAST_PINIO) 326 #if defined(HAS_PORT_SET_CLR) 327 #if defined(KINETISK) 330 *csPortClr = csPinMask;
331 #endif // end !KINETISK 332 #else // !HAS_PORT_SET_CLR 333 *csPort &= csPinMaskClr;
334 #endif // end !HAS_PORT_SET_CLR 335 #else // !USE_FAST_PINIO 336 digitalWrite(
_cs, LOW);
337 #endif // end !USE_FAST_PINIO 344 #if defined(USE_FAST_PINIO) 345 #if defined(HAS_PORT_SET_CLR) 346 #if defined(KINETISK) 349 *dcPortSet = dcPinMask;
350 #endif // end !KINETISK 351 #else // !HAS_PORT_SET_CLR 352 *dcPort |= dcPinMaskSet;
353 #endif // end !HAS_PORT_SET_CLR 354 #else // !USE_FAST_PINIO 355 digitalWrite(
_dc, HIGH);
356 #endif // end !USE_FAST_PINIO 363 #if defined(USE_FAST_PINIO) 364 #if defined(HAS_PORT_SET_CLR) 365 #if defined(KINETISK) 368 *dcPortClr = dcPinMask;
369 #endif // end !KINETISK 370 #else // !HAS_PORT_SET_CLR 371 *dcPort &= dcPinMaskClr;
372 #endif // end !HAS_PORT_SET_CLR 373 #else // !USE_FAST_PINIO 374 digitalWrite(
_dc, LOW);
375 #endif // end !USE_FAST_PINIO 403 #if defined(USE_FAST_PINIO) 404 #if defined(HAS_PORT_SET_CLR) 409 #else // !HAS_PORT_SET_CLR 412 #endif // end HAS_PORT_SET_CLR 413 #endif // end USE_FAST_PINIO 414 #if defined(__cplusplus) && (__cplusplus >= 201100) 419 #if defined(SPI_HAS_TRANSACTION) 420 SPISettings settings;
427 #if defined(USE_FAST_PINIO) 429 #if defined(HAS_PORT_SET_CLR) 434 #if !defined(KINETISK) 437 #endif // end !KINETISK 438 #else // !HAS_PORT_SET_CLR 445 #endif // end HAS_PORT_SET_CLR 446 #if !defined(KINETISK) 448 #endif // end !KINETISK 449 #endif // end USE_FAST_PINIO 455 #if defined(USE_FAST_PINIO) 457 #if defined(__IMXRT1052__) || defined(__IMXRT1062__) // Teensy 4.x 458 volatile uint32_t *writePort;
459 volatile uint32_t *readPort;
461 volatile uint8_t *writePort;
462 volatile uint8_t *readPort;
464 #if defined(HAS_PORT_SET_CLR) 467 #if defined(__IMXRT1052__) || defined(__IMXRT1062__) // Teensy 4.x 468 volatile uint32_t *dirSet;
469 volatile uint32_t *dirClr;
471 volatile uint8_t *dirSet;
472 volatile uint8_t *dirClr;
478 #if !defined(KINETISK) 480 #endif // end !KINETISK 482 #else // !HAS_PORT_SET_CLR 485 volatile uint8_t *portDir;
492 #endif // end HAS_PORT_SET_CLR 493 #endif // end USE_FAST_PINIO 499 #if defined(__cplusplus) && (__cplusplus >= 201100) 502 #if defined(USE_SPI_DMA) && \ 503 (defined(__SAMD51__) || \ 504 defined(ARDUINO_SAMD_ZERO)) // Used by hardware SPI and tft8 505 Adafruit_ZeroDMA dma;
506 DmacDescriptor *dptr = NULL;
507 DmacDescriptor *descriptor = NULL;
508 uint16_t *pixelBuf[2];
510 uint16_t lastFillColor = 0;
511 uint32_t lastFillLen = 0;
514 #if defined(USE_FAST_PINIO) 515 #if defined(HAS_PORT_SET_CLR) 516 #if !defined(KINETISK) 519 #endif // end !KINETISK 520 #else // !HAS_PORT_SET_CLR 525 #endif // end HAS_PORT_SET_CLR 526 #endif // end USE_FAST_PINIO 540 #endif // end __AVR_ATtiny85__ __AVR_ATtiny84__ 541 #endif // end _ADAFRUIT_SPITFT_H_ void sendCommand(uint8_t commandByte, uint8_t *dataBytes, uint8_t numDataBytes)
Adafruit_SPITFT Send Command handles complete sending of commands and data.
Definition: Adafruit_SPITFT.cpp:1956
void write16(uint16_t w)
Issue a single 16-bit value to the display. Chip-select, transaction and data/command selection must ...
Definition: Adafruit_SPITFT.cpp:2287
uint32_t _freq
SPI bitrate (if no SPI transactions)
Definition: Adafruit_SPITFT.h:422
void writePixels(uint16_t *colors, uint32_t len, bool block=true, bool bigEndian=false)
Issue a series of pixels from memory to the display. Not self- contained; should follow startWrite() ...
Definition: Adafruit_SPITFT.cpp:1004
uint8_t invertOffCommand
Command to disable invert mode.
Definition: Adafruit_SPITFT.h:535
int8_t _rd
Read strobe pin # (or -1)
Definition: Adafruit_SPITFT.h:496
void writePixel(int16_t x, int16_t y, uint16_t color)
Draw a single pixel to the display at requested coordinates. Not self-contained; should follow a star...
Definition: Adafruit_SPITFT.cpp:954
struct Adafruit_SPITFT::@2 tft8
Parallel interface settings.
virtual void setAddrWindow(uint16_t x, uint16_t y, uint16_t w, uint16_t h)=0
Set up the specific display hardware's "address window" for subsequent pixel-pushing operations...
void SPI_WRITE16(uint16_t w)
Issue a single 16-bit value to the display. Chip-select, transaction and data/command selection must ...
Definition: Adafruit_SPITFT.cpp:2449
Definition: Adafruit_GFX.h:18
uint16_t readcommand16(uint16_t addr)
Read 16 bits of data from display register. For 16-bit parallel displays only.
Definition: Adafruit_SPITFT.cpp:2078
void SPI_BEGIN_TRANSACTION(void)
Start an SPI transaction if using the hardware SPI interface to the display. If using an earlier vers...
Definition: Adafruit_SPITFT.cpp:2120
int8_t _sck
SCK pin #.
Definition: Adafruit_SPITFT.h:452
void drawRGBBitmap(int16_t x, int16_t y, uint16_t *pcolors, int16_t w, int16_t h)
Draw a 16-bit image (565 RGB) at the specified (x,y) position. For 16-bit display devices; no color r...
Definition: Adafruit_SPITFT.cpp:1884
void TFT_RD_LOW(void)
Set the RD line LOW. Used for parallel-connected interfaces when reading data.
Definition: Adafruit_SPITFT.cpp:2609
int8_t _cs
Chip select pin # (or -1)
Definition: Adafruit_SPITFT.h:529
void writeColor(uint16_t color, uint32_t len)
Issue a series of pixels, all the same color. Not self- contained; should follow startWrite() and set...
Definition: Adafruit_SPITFT.cpp:1211
void writeCommand16(uint16_t cmd)
Write a single command word to the display. Chip-select and transaction must have been previously set...
Definition: Adafruit_SPITFT.cpp:2307
void SPI_SCK_HIGH(void)
Set the software (bitbang) SPI SCK line HIGH.
Definition: Adafruit_SPITFT.cpp:2388
int8_t _miso
MISO pin #.
Definition: Adafruit_SPITFT.h:451
uint8_t connection
TFT_HARD_SPI, TFT_SOFT_SPI, etc.
Definition: Adafruit_SPITFT.h:527
bool SPI_MISO_READ(void)
Read the state of the software (bitbang) SPI MISO line.
Definition: Adafruit_SPITFT.cpp:2427
void drawFastHLine(int16_t x, int16_t y, int16_t w, uint16_t color)
Draw a horizontal line on the display. Self-contained and provides its own transaction as needed (see...
Definition: Adafruit_SPITFT.cpp:1788
void writeFillRectPreclipped(int16_t x, int16_t y, int16_t w, int16_t h, uint16_t color)
A lower-level version of writeFillRect(). This version requires all inputs are in-bounds, that width and height are positive, and no part extends offscreen. NO EDGE CLIPPING OR REJECTION IS PERFORMED. If higher-level graphics primitives are written to handle their own clipping earlier in the drawing process, this can avoid unnecessary function calls and repeated clipping operations in the lower-level functions.
Definition: Adafruit_SPITFT.cpp:1676
void invertDisplay(bool i)
Invert the colors of the display (if supported by hardware). Self-contained, no transaction setup req...
Definition: Adafruit_SPITFT.cpp:1929
tftBusWidth
Definition: Adafruit_SPITFT.h:104
void dmaWait(void)
Wait for the last DMA transfer in a prior non-blocking writePixels() call to complete. This does nothing if DMA is not enabled, and is not needed if blocking writePixels() was used (as is the default case).
Definition: Adafruit_SPITFT.cpp:1177
Adafruit_SPITFT(uint16_t w, uint16_t h, int8_t cs, int8_t dc, int8_t mosi, int8_t sck, int8_t rst=-1, int8_t miso=-1)
Adafruit_SPITFT constructor for software (bitbang) SPI.
Definition: Adafruit_SPITFT.cpp:126
void setSPISpeed(uint32_t freq)
Allow changing the SPI clock speed after initialization.
Definition: Adafruit_SPITFT.cpp:907
void drawRGBBitmap(int16_t x, int16_t y, const uint16_t bitmap[], int16_t w, int16_t h)
Draw a PROGMEM-resident 16-bit image (RGB 5/6/5) at the specified (x,y) position. For 16-bit display ...
Definition: Adafruit_GFX.cpp:1001
void SPI_CS_LOW(void)
Set the chip-select line LOW. Does NOT check whether CS pin is set (>=0), that should be handled in c...
Definition: Adafruit_SPITFT.h:324
struct Adafruit_SPITFT::@0 hwspi
Hardware SPI values.
void drawFastVLine(int16_t x, int16_t y, int16_t h, uint16_t color)
Draw a vertical line on the display. Self-contained and provides its own transaction as needed (see w...
Definition: Adafruit_SPITFT.cpp:1829
int8_t _wr
Write strobe pin #.
Definition: Adafruit_SPITFT.h:495
void pushColor(uint16_t color)
Essentially writePixel() with a transaction around it. I don't think this is in use by any of our cod...
Definition: Adafruit_SPITFT.cpp:1862
int16_t _ystart
Internal framebuffer Y offset.
Definition: Adafruit_SPITFT.h:533
void SPI_SCK_LOW(void)
Set the software (bitbang) SPI SCK line LOW.
Definition: Adafruit_SPITFT.cpp:2407
void SPI_MOSI_HIGH(void)
Set the software (bitbang) SPI MOSI line HIGH.
Definition: Adafruit_SPITFT.cpp:2350
void sendCommand16(uint16_t commandWord, const uint8_t *dataBytes=NULL, uint8_t numDataBytes=0)
Adafruit_SPITFT sendCommand16 handles complete sending of commands and data for 16-bit parallel displ...
Definition: Adafruit_SPITFT.cpp:2023
void fillRect(int16_t x, int16_t y, int16_t w, int16_t h, uint16_t color)
Draw a filled rectangle to the display. Self-contained and provides its own transaction as needed (se...
Definition: Adafruit_SPITFT.cpp:1730
uint32_t _mode
SPI data mode (transactions or no)
Definition: Adafruit_SPITFT.h:424
void writeCommand(uint8_t cmd)
Write a single command byte to the display. Chip-select and transaction must have been previously set...
Definition: Adafruit_SPITFT.cpp:2208
void writeFillRect(int16_t x, int16_t y, int16_t w, int16_t h, uint16_t color)
Draw a filled rectangle to the display. Not self-contained; should follow startWrite(). Typically used by higher-level graphics primitives; user code shouldn't need to call this and is likely to use the self-contained fillRect() instead. writeFillRect() performs its own edge clipping and rejection; see writeFillRectPreclipped() for a more 'raw' implementation.
Definition: Adafruit_SPITFT.cpp:1544
bool dmaBusy(void) const
Check if DMA transfer is active. Always returts false if DMA is not enabled.
Definition: Adafruit_SPITFT.cpp:1197
void SPI_DC_HIGH(void)
Set the data/command line HIGH (data mode).
Definition: Adafruit_SPITFT.h:343
void SPI_CS_HIGH(void)
Set the chip-select line HIGH. Does NOT check whether CS pin is set (>=0), that should be handled in ...
Definition: Adafruit_SPITFT.h:302
uint16_t read16(void)
Read a single 16-bit value from the display. Chip-select and transaction must have been previously se...
Definition: Adafruit_SPITFT.cpp:2321
volatile ADAGFX_PORT_t * PORTreg_t
PORT register type.
Definition: Adafruit_SPITFT.h:67
SPIClass * _spi
SPI class pointer.
Definition: Adafruit_SPITFT.h:418
struct Adafruit_SPITFT::@1 swspi
Software SPI values.
void SPI_MOSI_LOW(void)
Set the software (bitbang) SPI MOSI line LOW.
Definition: Adafruit_SPITFT.cpp:2369
Adafruit_SPITFT is an intermediary class between Adafruit_GFX and various hardware-specific subclasse...
Definition: Adafruit_SPITFT.h:131
void drawPixel(int16_t x, int16_t y, uint16_t color)
Draw a single pixel to the display at requested coordinates. Self-contained and provides its own tran...
Definition: Adafruit_SPITFT.cpp:1700
void spiWrite(uint8_t b)
Issue a single 8-bit value to the display. Chip-select, transaction and data/command selection must h...
Definition: Adafruit_SPITFT.cpp:2165
uint16_t color565(uint8_t r, uint8_t g, uint8_t b)
Given 8-bit red, green and blue values, return a 'packed' 16-bit color value in '565' RGB format (5 b...
Definition: Adafruit_SPITFT.cpp:1945
int8_t _d0
Data pin 0 #.
Definition: Adafruit_SPITFT.h:494
void SPI_DC_LOW(void)
Set the data/command line LOW (command mode).
Definition: Adafruit_SPITFT.h:362
void endWrite(void)
Call after issuing command(s) or data to display. Performs chip-deselect (if required) and ends an SP...
Definition: Adafruit_SPITFT.cpp:933
uint8_t invertOnCommand
Command to enable invert mode.
Definition: Adafruit_SPITFT.h:534
void startWrite(void)
Call before issuing command(s) or data to display. Performs chip-select (if required) and starts an S...
Definition: Adafruit_SPITFT.cpp:921
void TFT_WR_STROBE(void)
Set the WR line LOW, then HIGH. Used for parallel-connected interfaces when writing data...
Definition: Adafruit_SPITFT.cpp:2569
bool wide
If true, is 16-bit interface.
Definition: Adafruit_SPITFT.h:497
int8_t _dc
Data/command pin #.
Definition: Adafruit_SPITFT.h:530
void SPI_END_TRANSACTION(void)
End an SPI transaction if using the hardware SPI interface to the display. No action is taken if the ...
Definition: Adafruit_SPITFT.cpp:2148
int16_t _xstart
Internal framebuffer X offset.
Definition: Adafruit_SPITFT.h:532
void initSPI(uint32_t freq=0, uint8_t spiMode=SPI_MODE0)
Configure microcontroller pins for TFT interfacing. Typically called by a subclass' begin() function...
Definition: Adafruit_SPITFT.cpp:536
virtual void begin(uint32_t freq)=0
Display-specific initialization function.
void TFT_RD_HIGH(void)
Set the RD line HIGH. Used for parallel-connected interfaces when reading data.
Definition: Adafruit_SPITFT.cpp:2593
void writeFastHLine(int16_t x, int16_t y, int16_t w, uint16_t color)
Draw a horizontal line on the display. Performs edge clipping and rejection. Not self-contained; shou...
Definition: Adafruit_SPITFT.cpp:1596
void SPI_WRITE32(uint32_t l)
Issue a single 32-bit value to the display. Chip-select, transaction and data/command selection must ...
Definition: Adafruit_SPITFT.cpp:2505
uint8_t spiRead(void)
Read a single 8-bit value from the display. Chip-select and transaction must have been previously set...
Definition: Adafruit_SPITFT.cpp:2224
uint32_t ADAGFX_PORT_t
PORT values are 32-bit.
Definition: Adafruit_SPITFT.h:65
uint8_t readcommand8(uint8_t commandByte, uint8_t index=0)
Read 8 bits of data from display configuration memory (not RAM). This is highly undocumented/supporte...
Definition: Adafruit_SPITFT.cpp:2059
void swapBytes(uint16_t *src, uint32_t len, uint16_t *dest=NULL)
Swap bytes in an array of pixels; converts little-to-big or big-to-little endian. Used by writePixels...
Definition: Adafruit_SPITFT.cpp:971
int8_t _rst
Reset pin # (or -1)
Definition: Adafruit_SPITFT.h:528
int8_t _mosi
MOSI pin #.
Definition: Adafruit_SPITFT.h:450
void writeFastVLine(int16_t x, int16_t y, int16_t h, uint16_t color)
Draw a vertical line on the display. Performs edge clipping and rejection. Not self-contained; should...
Definition: Adafruit_SPITFT.cpp:1632