more touchpad stuff

This commit is contained in:
Tectu 2012-08-09 02:31:42 +02:00
parent 4c3e1847de
commit 55c8323950
2 changed files with 66 additions and 2 deletions

View file

@ -30,6 +30,13 @@
#if HAL_USE_TOUCHPAD || defined(__DOXYGEN__) #if HAL_USE_TOUCHPAD || defined(__DOXYGEN__)
/**
* @brief specifies how many conversions are made for a readout.
*
* @note higher is more accurate, but takes more time
*/
#define CONVERSIONS 3
/*===========================================================================*/ /*===========================================================================*/
/* Driver constants. */ /* Driver constants. */
/*===========================================================================*/ /*===========================================================================*/

View file

@ -60,6 +60,44 @@ volatile static struct cal cal = {
/* Driver local functions. */ /* Driver local functions. */
/*===========================================================================*/ /*===========================================================================*/
/**
* @brief returns the uncalibrated readout of the X direction from the controller
*
* @noapi
*/
static uint16_t _tpReadRealX(void) {
uint32_t results = 0;
uint16_t i, x;
for(i = 0; i < CONVERSIONS; i++) {
tp_lld_read_x(); /* dummy, reduce noise on SPI */
results += tp_lld_read_x();
}
x = (((SCREEN_WIDTH-1) * (results/CONVERSIONS)) / 2048);
return x;
}
/**
* @brief return the uncalibrated readout of the Y-direction from the controller
*
* @noapi
*/
static uint16_t _tpReadRealY(void) {
uint32_t results = 0;
uint16_t i, y;
for(i = 0; i < CONVERSIONS; i++) {
tp_lld_read_y(); /* dummy, reduce noise on SPI */
results += tp_lld_read_y();
}
y = (((SCREEN_HEIGHT-1) * (results/CONVERSIONS)) / 2048);
return y;
}
/*===========================================================================*/ /*===========================================================================*/
/* Driver exported functions. */ /* Driver exported functions. */
/*===========================================================================*/ /*===========================================================================*/
@ -105,7 +143,8 @@ uint16_t tpReadX(void) {
case landscapeInv: case landscapeInv:
return y; return y;
} }
return x;
return x;
} }
/** /**
@ -116,7 +155,24 @@ uint16_t tpReadX(void) {
* @api * @api
*/ */
uint16_t tpReadY(void) { uint16_t tpReadY(void) {
return (tp_lld_read_y()); uint16_t x, y;
x = cal.xm * _tpReadRealX() + cal.xn;
y = cal.ym * _tpReadRealY() + cal.yn;
//switch(gdispGetOrientation()) {
switch(portrait) { // implement gdispGetOrientation()
case portrait:
return y;
case landscape:
return x;
case portraitInv:
return SCREEN_HEIGHT - y;
case landscapeInv:
return SCREEN_WIDTH - x;
}
return y;
} }
#if TOUCHPAD_PRESSURE || defined(__DOXYGEN__) #if TOUCHPAD_PRESSURE || defined(__DOXYGEN__)
@ -128,6 +184,7 @@ uint16_t tpReadY(void) {
* @api * @api
*/ */
uint16_t tpReadZ(void) { uint16_t tpReadZ(void) {
/* ToDo */
return (tp_lld_read_z()); return (tp_lld_read_z());
} }
#endif #endif