2022-04-09 02:07:38 +02:00
|
|
|
def intify_coordinate(row, col, len_cols):
|
|
|
|
return len_cols * row + col
|
|
|
|
|
|
|
|
|
|
|
|
class DiodeOrientation:
|
|
|
|
'''
|
|
|
|
Orientation of diodes on handwired boards. You can think of:
|
|
|
|
COLUMNS = vertical
|
|
|
|
ROWS = horizontal
|
|
|
|
|
|
|
|
COL2ROW and ROW2COL are equivalent to their meanings in QMK.
|
|
|
|
'''
|
|
|
|
|
|
|
|
COLUMNS = 0
|
|
|
|
ROWS = 1
|
|
|
|
COL2ROW = COLUMNS
|
|
|
|
ROW2COL = ROWS
|
|
|
|
|
|
|
|
|
2021-10-03 16:40:18 +02:00
|
|
|
class Scanner:
|
|
|
|
'''
|
|
|
|
Base class for scanners.
|
|
|
|
'''
|
|
|
|
|
2022-04-16 22:04:42 +02:00
|
|
|
# for split keyboards, the offset value will be assigned in Split module
|
|
|
|
offset = 0
|
|
|
|
|
|
|
|
@property
|
|
|
|
def coord_mapping(self):
|
|
|
|
return tuple(range(self.offset, self.offset + self.key_count))
|
2022-02-21 02:34:44 +01:00
|
|
|
|
2022-04-10 01:54:23 +02:00
|
|
|
@property
|
|
|
|
def key_count(self):
|
|
|
|
raise NotImplementedError
|
|
|
|
|
2021-10-03 16:40:18 +02:00
|
|
|
def scan_for_changes(self):
|
|
|
|
'''
|
|
|
|
Scan for key events and return a key report if an event exists.
|
|
|
|
|
|
|
|
The key report is a byte array with contents [row, col, True if pressed else False]
|
|
|
|
'''
|
2022-04-16 22:04:42 +02:00
|
|
|
raise NotImplementedError
|