|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354 |
- /***************************************************
- This is a library for the Adafruit STMPE610 Resistive
- touch screen controller breakout
- ----> http://www.adafruit.com/products/1571
-
- Check out the links above for our tutorials and wiring diagrams
- These breakouts use SPI or I2C to communicate
-
- Adafruit invests time and resources providing this open source code,
- please support Adafruit and open-source hardware by purchasing
- products from Adafruit!
-
- Written by Limor Fried/Ladyada for Adafruit Industries.
- MIT license, all text above must be included in any redistribution
- ****************************************************/
-
-
- #if ARDUINO >= 100
- #include "Arduino.h"
- #else
- #include "WProgram.h"
- #endif
-
- #include <Wire.h>
- #include <SPI.h>
-
- #include "Adafruit_STMPE610.h"
-
- #if defined (SPI_HAS_TRANSACTION)
- // SPI transaction support allows managing SPI settings and prevents
- // conflicts between libraries, with a hardware-neutral interface
- static SPISettings mySPISettings;
- #elif defined (__AVR__)
- static uint8_t SPCRbackup;
- static uint8_t mySPCR;
- #endif
-
- /**************************************************************************/
- /*!
- @brief Instantiates a new STMPE610 class
- */
- /**************************************************************************/
- // software SPI
- Adafruit_STMPE610::Adafruit_STMPE610(uint8_t cspin, uint8_t mosipin, uint8_t misopin, uint8_t clkpin) {
- _CS = cspin;
- _MOSI = mosipin;
- _MISO = misopin;
- _CLK = clkpin;
- }
-
- // hardware SPI
- Adafruit_STMPE610::Adafruit_STMPE610(uint8_t cspin) {
- _CS = cspin;
- _MOSI = _MISO = _CLK = -1;
- }
-
- // I2C
- Adafruit_STMPE610::Adafruit_STMPE610() {
- // use i2c
- _CS = -1;
- }
-
-
- /**************************************************************************/
- /*!
- @brief Setups the HW
- */
- /**************************************************************************/
- boolean Adafruit_STMPE610::begin(uint8_t i2caddr) {
- if (_CS != -1 && _CLK == -1) {
- // hardware SPI
- pinMode(_CS, OUTPUT);
- digitalWrite(_CS, HIGH);
-
- #if defined (SPI_HAS_TRANSACTION)
- SPI.begin();
- mySPISettings = SPISettings(1000000, MSBFIRST, SPI_MODE0);
- #elif defined (__AVR__)
- SPCRbackup = SPCR;
- SPI.begin();
- SPI.setClockDivider(SPI_CLOCK_DIV16);
- SPI.setDataMode(SPI_MODE0);
- mySPCR = SPCR; // save our preferred state
- //Serial.print("mySPCR = 0x"); Serial.println(SPCR, HEX);
- SPCR = SPCRbackup; // then restore
- #elif defined (__arm__)
- SPI.begin();
- SPI.setClockDivider(84);
- SPI.setDataMode(SPI_MODE0);
- #endif
- m_spiMode = SPI_MODE0;
- } else if (_CS != -1) {
- // software SPI
- pinMode(_CLK, OUTPUT);
- pinMode(_CS, OUTPUT);
- pinMode(_MOSI, OUTPUT);
- pinMode(_MISO, INPUT);
- } else {
- Wire.begin();
- _i2caddr = i2caddr;
- }
-
- // try mode0
- if (getVersion() != 0x811) {
- if (_CS != -1 && _CLK == -1) {
- //Serial.println("try MODE1");
- #if defined (SPI_HAS_TRANSACTION)
- mySPISettings = SPISettings(1000000, MSBFIRST, SPI_MODE1);
- #elif defined (__AVR__)
- SPCRbackup = SPCR;
- SPI.begin();
- SPI.setDataMode(SPI_MODE1);
- SPI.setClockDivider(SPI_CLOCK_DIV16);
- mySPCR = SPCR; // save our new preferred state
- //Serial.print("mySPCR = 0x"); Serial.println(SPCR, HEX);
- SPCR = SPCRbackup; // then restore
- #elif defined (__arm__)
- SPI.setClockDivider(84);
- SPI.setDataMode(SPI_MODE1);
- #endif
- m_spiMode = SPI_MODE1;
-
- if (getVersion() != 0x811) {
- return false;
- }
- } else {
- return false;
- }
- }
- writeRegister8(STMPE_SYS_CTRL1, STMPE_SYS_CTRL1_RESET);
- delay(10);
-
- for (uint8_t i=0; i<65; i++) {
- readRegister8(i);
- }
-
- writeRegister8(STMPE_SYS_CTRL2, 0x0); // turn on clocks!
- writeRegister8(STMPE_TSC_CTRL, STMPE_TSC_CTRL_XYZ | STMPE_TSC_CTRL_EN); // XYZ and enable!
- //Serial.println(readRegister8(STMPE_TSC_CTRL), HEX);
- writeRegister8(STMPE_INT_EN, STMPE_INT_EN_TOUCHDET);
- writeRegister8(STMPE_ADC_CTRL1, STMPE_ADC_CTRL1_10BIT | (0x6 << 4)); // 96 clocks per conversion
- writeRegister8(STMPE_ADC_CTRL2, STMPE_ADC_CTRL2_6_5MHZ);
- writeRegister8(STMPE_TSC_CFG, STMPE_TSC_CFG_4SAMPLE | STMPE_TSC_CFG_DELAY_1MS | STMPE_TSC_CFG_SETTLE_5MS);
- writeRegister8(STMPE_TSC_FRACTION_Z, 0x6);
- writeRegister8(STMPE_FIFO_TH, 1);
- writeRegister8(STMPE_FIFO_STA, STMPE_FIFO_STA_RESET);
- writeRegister8(STMPE_FIFO_STA, 0); // unreset
- writeRegister8(STMPE_TSC_I_DRIVE, STMPE_TSC_I_DRIVE_50MA);
- writeRegister8(STMPE_INT_STA, 0xFF); // reset all ints
- writeRegister8(STMPE_INT_CTRL, STMPE_INT_CTRL_POL_HIGH | STMPE_INT_CTRL_ENABLE);
-
- #if defined (__AVR__) && !defined (SPI_HAS_TRANSACTION)
- if (_CS != -1 && _CLK == -1)
- SPCR = SPCRbackup; // restore SPI state
- #endif
- return true;
- }
-
- boolean Adafruit_STMPE610::touched(void) {
- return (readRegister8(STMPE_TSC_CTRL) & 0x80);
- }
-
- boolean Adafruit_STMPE610::bufferEmpty(void) {
- return (readRegister8(STMPE_FIFO_STA) & STMPE_FIFO_STA_EMPTY);
- }
-
- uint8_t Adafruit_STMPE610::bufferSize(void) {
- return readRegister8(STMPE_FIFO_SIZE);
- }
-
- uint16_t Adafruit_STMPE610::getVersion() {
- uint16_t v;
- //Serial.print("get version");
- v = readRegister8(0);
- v <<= 8;
- v |= readRegister8(1);
- //Serial.print("Version: 0x"); Serial.println(v, HEX);
- return v;
- }
-
-
- /*****************************/
-
- void Adafruit_STMPE610::readData(uint16_t *x, uint16_t *y, uint8_t *z) {
- uint8_t data[4];
-
- for (uint8_t i=0; i<4; i++) {
- data[i] = readRegister8(0xD7); //SPI.transfer(0x00);
- // Serial.print("0x"); Serial.print(data[i], HEX); Serial.print(" / ");
- }
- *x = data[0];
- *x <<= 4;
- *x |= (data[1] >> 4);
- *y = data[1] & 0x0F;
- *y <<= 8;
- *y |= data[2];
- *z = data[3];
-
- if (bufferEmpty())
- writeRegister8(STMPE_INT_STA, 0xFF); // reset all ints
- }
-
- TS_Point Adafruit_STMPE610::getPoint(void) {
- uint16_t x, y;
- uint8_t z;
- readData(&x, &y, &z);
- return TS_Point(x, y, z);
- }
-
- uint8_t Adafruit_STMPE610::spiIn() {
- if (_CLK == -1) {
- #if defined (SPI_HAS_TRANSACTION)
- uint8_t d = SPI.transfer(0);
- return d;
- #elif defined (__AVR__)
- SPCRbackup = SPCR;
- SPCR = mySPCR;
- uint8_t d = SPI.transfer(0);
- SPCR = SPCRbackup;
- return d;
- #elif defined (__arm__)
- SPI.setClockDivider(84);
- SPI.setDataMode(m_spiMode);
- uint8_t d = SPI.transfer(0);
- return d;
- #endif
- }
- else
- return shiftIn(_MISO, _CLK, MSBFIRST);
- }
- void Adafruit_STMPE610::spiOut(uint8_t x) {
- if (_CLK == -1) {
- #if defined (SPI_HAS_TRANSACTION)
- SPI.transfer(x);
- #elif defined (__AVR__)
- SPCRbackup = SPCR;
- SPCR = mySPCR;
- SPI.transfer(x);
- SPCR = SPCRbackup;
- #elif defined (__arm__)
- SPI.setClockDivider(84);
- SPI.setDataMode(m_spiMode);
- SPI.transfer(x);
- #endif
- }
- else
- shiftOut(_MOSI, _CLK, MSBFIRST, x);
- }
-
- uint8_t Adafruit_STMPE610::readRegister8(uint8_t reg) {
- uint8_t x ;
- if (_CS == -1) {
- // use i2c
- Wire.beginTransmission(_i2caddr);
- Wire.write((byte)reg);
- Wire.endTransmission();
- Wire.beginTransmission(_i2caddr);
- Wire.requestFrom(_i2caddr, (byte)1);
- x = Wire.read();
- Wire.endTransmission();
-
- //Serial.print("$"); Serial.print(reg, HEX);
- //Serial.print(": 0x"); Serial.println(x, HEX);
- } else {
- #if defined (SPI_HAS_TRANSACTION)
- if (_CLK == -1) SPI.beginTransaction(mySPISettings);
- #endif
- digitalWrite(_CS, LOW);
- spiOut(0x80 | reg);
- spiOut(0x00);
- x = spiIn();
- digitalWrite(_CS, HIGH);
- #if defined (SPI_HAS_TRANSACTION)
- if (_CLK == -1) SPI.endTransaction();
- #endif
- }
-
- return x;
- }
- uint16_t Adafruit_STMPE610::readRegister16(uint8_t reg) {
- uint16_t x = 0;
- if (_CS == -1) {
- // use i2c
- Wire.beginTransmission(_i2caddr);
- Wire.write((byte)reg);
- Wire.endTransmission();
- Wire.requestFrom(_i2caddr, (byte)2);
- x = Wire.read();
- x<<=8;
- x |= Wire.read();
- Wire.endTransmission();
-
- } if (_CLK == -1) {
- // hardware SPI
- #if defined (SPI_HAS_TRANSACTION)
- if (_CLK == -1) SPI.beginTransaction(mySPISettings);
- #endif
- digitalWrite(_CS, LOW);
- spiOut(0x80 | reg);
- spiOut(0x00);
- x = spiIn();
- x<<=8;
- x |= spiIn();
- digitalWrite(_CS, HIGH);
- #if defined (SPI_HAS_TRANSACTION)
- if (_CLK == -1) SPI.endTransaction();
- #endif
- }
-
- //Serial.print("$"); Serial.print(reg, HEX);
- //Serial.print(": 0x"); Serial.println(x, HEX);
- return x;
- }
-
- void Adafruit_STMPE610::writeRegister8(uint8_t reg, uint8_t val) {
- if (_CS == -1) {
- // use i2c
- Wire.beginTransmission(_i2caddr);
- Wire.write((byte)reg);
- Wire.write(val);
- Wire.endTransmission();
- } else {
- #if defined (SPI_HAS_TRANSACTION)
- if (_CLK == -1) SPI.beginTransaction(mySPISettings);
- #endif
- digitalWrite(_CS, LOW);
- spiOut(reg);
- spiOut(val);
- digitalWrite(_CS, HIGH);
- #if defined (SPI_HAS_TRANSACTION)
- if (_CLK == -1) SPI.endTransaction();
- #endif
- }
- }
-
- /****************/
-
- TS_Point::TS_Point(void) {
- x = y = 0;
- }
-
- TS_Point::TS_Point(int16_t x0, int16_t y0, int16_t z0) {
- x = x0;
- y = y0;
- z = z0;
- }
-
- bool TS_Point::operator==(TS_Point p1) {
- return ((p1.x == x) && (p1.y == y) && (p1.z == z));
- }
-
- bool TS_Point::operator!=(TS_Point p1) {
- return ((p1.x != x) || (p1.y != y) || (p1.z != z));
- }
|