|
@@ -23,6 +23,12 @@
|
23
|
23
|
|
24
|
24
|
#include "xpt2046.h"
|
25
|
25
|
#include "../../inc/MarlinConfig.h"
|
|
26
|
+#include "../../lcd/dogm/ultralcd_DOGM.h" // for LCD_FULL_PIXEL_WIDTH, etc.
|
|
27
|
+
|
|
28
|
+#define BUTTON_AREA_TOP 175
|
|
29
|
+#define BUTTON_AREA_BOT 234
|
|
30
|
+#define SCREEN_START_TOP ((LCD_PIXEL_OFFSET_Y) * 240 / (LCD_FULL_PIXEL_HEIGHT))
|
|
31
|
+#define TOUCHABLE_Y_HEIGHT (BUTTON_AREA_TOP - (SCREEN_START_TOP))
|
26
|
32
|
|
27
|
33
|
#ifndef TOUCH_INT_PIN
|
28
|
34
|
#define TOUCH_INT_PIN -1
|
|
@@ -78,13 +84,23 @@ uint8_t XPT2046::read_buttons() {
|
78
|
84
|
y = uint16_t(((uint32_t(getInTouch(XPT2046_Y))) * tsoffsets[2]) >> 16) + tsoffsets[3];
|
79
|
85
|
if (!isTouched()) return 0; // Fingers must still be on the TS for a valid read.
|
80
|
86
|
|
81
|
|
- if (y < 175 || y > 234) return 0;
|
|
87
|
+ // Touch within the button area simulates an encoder button
|
|
88
|
+ if (y > BUTTON_AREA_TOP && y < BUTTON_AREA_BOT)
|
|
89
|
+ return WITHIN(x, 14, 77) ? EN_D
|
|
90
|
+ : WITHIN(x, 90, 153) ? EN_A
|
|
91
|
+ : WITHIN(x, 166, 229) ? EN_B
|
|
92
|
+ : WITHIN(x, 242, 305) ? EN_C
|
|
93
|
+ : 0;
|
|
94
|
+
|
|
95
|
+ if (x > LCD_FULL_PIXEL_WIDTH || !WITHIN(y, SCREEN_START_TOP, BUTTON_AREA_TOP)) return 0;
|
|
96
|
+
|
|
97
|
+ // Column and row above BUTTON_AREA_TOP
|
|
98
|
+ int8_t col = x * (LCD_WIDTH) / (LCD_FULL_PIXEL_WIDTH),
|
|
99
|
+ row = (y - (SCREEN_START_TOP)) * (LCD_HEIGHT) / (TOUCHABLE_Y_HEIGHT);
|
82
|
100
|
|
83
|
|
- return WITHIN(x, 14, 77) ? EN_D
|
84
|
|
- : WITHIN(x, 90, 153) ? EN_A
|
85
|
|
- : WITHIN(x, 166, 229) ? EN_B
|
86
|
|
- : WITHIN(x, 242, 305) ? EN_C
|
87
|
|
- : 0;
|
|
101
|
+ // Send the touch to the UI (which will simulate the encoder wheel)
|
|
102
|
+ MarlinUI::screen_click(row, col, x, y);
|
|
103
|
+ return 0;
|
88
|
104
|
}
|
89
|
105
|
|
90
|
106
|
bool XPT2046::isTouched() {
|