diff options
-rw-r--r-- | Android.mk | 4 | ||||
-rw-r--r-- | ui.cpp | 19 |
2 files changed, 23 insertions, 0 deletions
@@ -136,6 +136,10 @@ ifeq ($(BOARD_HAS_DOWNLOAD_MODE), true) LOCAL_CFLAGS += -DDOWNLOAD_MODE endif +ifeq ($(TARGET_RECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X), true) +LOCAL_CFLAGS += -DRECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X +endif + ifneq ($(BOARD_RECOVERY_BLDRMSG_OFFSET),) LOCAL_CFLAGS += -DBOARD_RECOVERY_BLDRMSG_OFFSET=$(BOARD_RECOVERY_BLDRMSG_OFFSET) endif @@ -425,13 +425,24 @@ void RecoveryUI::ProcessAbs(input_device* dev, int code, int value) { return; } } +#ifndef RECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X if (code == ABS_MT_POSITION_X) { +#else + if (code == ABS_MT_POSITION_Y) { +#endif dev->saw_pos_x = true; dev->touch_pos.x = value * fb_dimensions.x / (dev->touch_max.x - dev->touch_min.x); } +#ifndef RECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X else if (code == ABS_MT_POSITION_Y) { +#else + else if (code == ABS_MT_POSITION_X) { +#endif dev->saw_pos_y = true; dev->touch_pos.y = value * fb_dimensions.y / (dev->touch_max.y - dev->touch_min.y); +#ifdef RECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X + dev->touch_pos.y = fb_dimensions.y - dev->touch_pos.y; +#endif } } @@ -480,13 +491,21 @@ void RecoveryUI::calibrate_touch(input_device* dev) { struct input_absinfo info; memset(&info, 0, sizeof(info)); +#ifndef RECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X if (ioctl(dev->fd, EVIOCGABS(ABS_MT_POSITION_X), &info) == 0) { +#else + if (ioctl(dev->fd, EVIOCGABS(ABS_MT_POSITION_Y), &info) == 0) { +#endif dev->touch_min.x = info.minimum; dev->touch_max.x = info.maximum; dev->touch_pos.x = info.value; } memset(&info, 0, sizeof(info)); +#ifndef RECOVERY_TOUCHSCREEN_SWAP_XY_FLIP_X if (ioctl(dev->fd, EVIOCGABS(ABS_MT_POSITION_Y), &info) == 0) { +#else + if (ioctl(dev->fd, EVIOCGABS(ABS_MT_POSITION_X), &info) == 0) { +#endif dev->touch_min.y = info.minimum; dev->touch_max.y = info.maximum; dev->touch_pos.y = info.value; |