2020-03-22 15:40:18 +00:00
|
|
|
# SPDX-License-Identifier: LGPL-3.0-or-later
|
|
|
|
# Copyright (C) 2020 Daniel Thompson
|
|
|
|
|
2020-05-14 21:36:09 +01:00
|
|
|
"""Hynitron CST816S touch contoller driver
|
|
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
2020-03-08 10:18:08 +00:00
|
|
|
"""
|
|
|
|
|
|
|
|
import array
|
2020-03-06 21:09:43 +00:00
|
|
|
|
|
|
|
class CST816S:
|
2020-05-14 21:36:09 +01:00
|
|
|
"""Hynitron CST816S I2C touch controller driver.
|
|
|
|
|
|
|
|
.. automethod:: __init__
|
|
|
|
"""
|
2020-03-06 21:09:43 +00:00
|
|
|
|
2020-03-07 11:47:25 +00:00
|
|
|
def __init__(self, bus):
|
2020-05-14 21:36:09 +01:00
|
|
|
"""Specify the bus used by the touch controller.
|
|
|
|
|
|
|
|
:param machine.I2C bus: I2C bus for the CST816S.
|
|
|
|
"""
|
2020-03-07 11:47:25 +00:00
|
|
|
self.i2c = bus
|
2020-03-06 21:09:43 +00:00
|
|
|
self.dbuf = bytearray(6)
|
2020-03-08 10:18:08 +00:00
|
|
|
self.event = array.array('H', (0, 0, 0))
|
2020-03-06 21:09:43 +00:00
|
|
|
|
2020-03-08 10:18:08 +00:00
|
|
|
def get_event(self):
|
2020-03-06 21:09:43 +00:00
|
|
|
"""Receive a touch event.
|
|
|
|
|
|
|
|
Check for a pending touch event and, if an event is pending,
|
|
|
|
prepare it ready to go in the event queue.
|
|
|
|
|
2020-03-08 10:18:08 +00:00
|
|
|
:return: An event record if an event is received, None otherwise.
|
2020-03-06 21:09:43 +00:00
|
|
|
"""
|
|
|
|
dbuf = self.dbuf
|
2020-03-08 10:18:08 +00:00
|
|
|
event = self.event
|
|
|
|
|
|
|
|
# TODO: check the interrupt pin
|
2020-03-06 21:09:43 +00:00
|
|
|
|
|
|
|
try:
|
2020-03-07 11:47:25 +00:00
|
|
|
self.i2c.readfrom_mem_into(21, 1, dbuf)
|
2020-03-06 21:09:43 +00:00
|
|
|
except OSError:
|
2020-03-08 10:18:08 +00:00
|
|
|
return None
|
|
|
|
|
|
|
|
# Skip junk events
|
|
|
|
if dbuf[0] == 0:
|
|
|
|
return None
|
|
|
|
|
|
|
|
x = ((dbuf[2] & 0xf) << 8) + dbuf[3]
|
|
|
|
y = ((dbuf[4] & 0xf) << 8) + dbuf[5]
|
|
|
|
swipe_start = dbuf[2] & 0x80
|
|
|
|
|
|
|
|
# Skip identical events... when the I2C interface comes alive
|
|
|
|
# we can still get back stale events
|
|
|
|
if dbuf[0] == event[0] and x == event[1] and y == event[2] \
|
|
|
|
and not swipe_start:
|
|
|
|
return None
|
|
|
|
|
|
|
|
# This is a good event, lets save it
|
|
|
|
event[0] = dbuf[0]
|
|
|
|
event[1] = x
|
|
|
|
event[2] = y
|
|
|
|
|
|
|
|
# Do not forward swipe start events
|
|
|
|
if dbuf[2] & 0x80:
|
|
|
|
event[0] = 0
|
|
|
|
return None
|
2020-03-06 21:09:43 +00:00
|
|
|
|
2020-03-08 10:18:08 +00:00
|
|
|
return event
|