2017-10-18 14:09:10 +02:00
|
|
|
/**
|
|
|
|
* @file hal_indev.h
|
|
|
|
*
|
|
|
|
* @description Input Device HAL interface layer header file
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef HAL_INDEV_H
|
|
|
|
#define HAL_INDEV_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*********************
|
|
|
|
* INCLUDES
|
|
|
|
*********************/
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdint.h>
|
2017-10-20 15:37:50 +02:00
|
|
|
#include "lv_hal.h"
|
2017-11-21 10:51:10 +01:00
|
|
|
#include "misc/gfx/area.h"
|
2017-10-18 14:09:10 +02:00
|
|
|
|
|
|
|
/*********************
|
|
|
|
* DEFINES
|
|
|
|
*********************/
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* TYPEDEFS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/*Possible input device types*/
|
|
|
|
typedef enum {
|
2017-11-19 19:28:45 +01:00
|
|
|
LV_INDEV_TYPE_TOUCHPAD, /*Touch pad*/
|
|
|
|
LV_INDEV_TYPE_MOUSE, /*Mouse or similar pointer device*/
|
2017-10-20 22:11:18 +02:00
|
|
|
LV_INDEV_TYPE_KEYPAD, /*Keypad or keyboard*/
|
2017-11-19 19:28:45 +01:00
|
|
|
LV_INDEV_TYPE_BUTTON, /*External (hardware) button assigned to a point on the screen*/
|
2017-10-18 14:09:10 +02:00
|
|
|
} lv_hal_indev_type_t;
|
|
|
|
|
2017-11-19 19:28:45 +01:00
|
|
|
/*States for input devices*/
|
2017-10-18 14:09:10 +02:00
|
|
|
typedef enum {
|
2017-11-16 10:20:30 +01:00
|
|
|
LV_INDEV_EVENT_REL,
|
|
|
|
LV_INDEV_EVENT_PR
|
2017-10-20 22:11:18 +02:00
|
|
|
}lv_indev_event_t;
|
2017-10-18 14:09:10 +02:00
|
|
|
|
2017-11-19 19:28:45 +01:00
|
|
|
/*Data type when an input device is read */
|
2017-10-18 14:09:10 +02:00
|
|
|
typedef struct {
|
|
|
|
union {
|
2017-11-19 19:28:45 +01:00
|
|
|
point_t point; /*For INDEV_TYPE_TOUCHPAD, INDEV_TYPE_POINTER, LV_INDEV_TYPE_BUTTON*/
|
|
|
|
uint32_t key; /*For INDEV_TYPE_KEYPAD*/
|
2017-10-18 14:09:10 +02:00
|
|
|
};
|
2017-11-19 19:28:45 +01:00
|
|
|
lv_indev_event_t state; /*LV_INDEV_EVENT_REL or LV_INDEV_EVENT_PR*/
|
2017-10-20 22:11:18 +02:00
|
|
|
}lv_indev_data_t;
|
2017-10-18 14:09:10 +02:00
|
|
|
|
2017-11-19 19:28:45 +01:00
|
|
|
/*Initialized by the user and registered by 'lv_indev_add()'*/
|
2017-10-18 14:09:10 +02:00
|
|
|
typedef struct {
|
|
|
|
lv_hal_indev_type_t type; /*Input device type*/
|
2017-11-19 19:28:45 +01:00
|
|
|
bool (*get_data)(lv_indev_data_t *data); /*Function pointer to read data. Return 'true' if there is still data to be read (buffered)*/
|
2017-10-20 22:11:18 +02:00
|
|
|
}lv_indev_drv_t;
|
2017-10-18 14:09:10 +02:00
|
|
|
|
2017-11-19 19:28:45 +01:00
|
|
|
struct _lv_obj_t;
|
2017-10-18 14:09:10 +02:00
|
|
|
|
2017-11-19 19:28:45 +01:00
|
|
|
typedef struct _lv_indev_state_t {
|
2017-10-20 22:11:18 +02:00
|
|
|
lv_indev_event_t event;
|
2017-11-19 19:28:45 +01:00
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
point_t act_point;
|
|
|
|
point_t last_point;
|
|
|
|
point_t vect;
|
2017-11-22 10:34:30 +01:00
|
|
|
point_t drag_sum; /*Count the dragged pixels to check LV_INDEV_DRAG_LIMIT*/
|
2017-11-19 19:28:45 +01:00
|
|
|
struct _lv_obj_t * act_obj;
|
|
|
|
struct _lv_obj_t * last_obj;
|
|
|
|
|
|
|
|
/*Flags*/
|
|
|
|
uint8_t drag_range_out :1;
|
|
|
|
uint8_t drag_in_prog :1;
|
|
|
|
uint8_t wait_unil_release :1;
|
|
|
|
};
|
|
|
|
uint32_t last_key;
|
|
|
|
};
|
|
|
|
|
2017-11-16 10:20:30 +01:00
|
|
|
uint32_t pr_timestamp; /*Pressed time stamp*/
|
|
|
|
uint32_t longpr_rep_timestamp; /*Long press repeat time stamp*/
|
2017-10-18 14:09:10 +02:00
|
|
|
|
|
|
|
/*Flags*/
|
2017-11-16 10:20:30 +01:00
|
|
|
uint8_t long_pr_sent :1;
|
2017-10-20 22:11:18 +02:00
|
|
|
uint8_t reset_query :1;
|
|
|
|
uint8_t disabled :1;
|
2017-10-18 14:09:10 +02:00
|
|
|
}lv_indev_state_t;
|
|
|
|
|
|
|
|
|
2017-11-19 19:28:45 +01:00
|
|
|
struct _lv_obj_t;
|
|
|
|
struct _lv_group_t;
|
|
|
|
|
2017-10-18 14:09:10 +02:00
|
|
|
typedef struct _lv_indev_t {
|
2017-10-20 22:11:18 +02:00
|
|
|
lv_indev_drv_t driver;
|
2017-10-18 14:09:10 +02:00
|
|
|
lv_indev_state_t state;
|
2017-11-19 19:28:45 +01:00
|
|
|
union {
|
|
|
|
struct _lv_obj_t *cursor;
|
|
|
|
struct _lv_group_t *group; /*Keypad destination group*/
|
|
|
|
};
|
2017-10-18 14:09:10 +02:00
|
|
|
struct _lv_indev_t *next;
|
|
|
|
} lv_indev_t;
|
|
|
|
|
|
|
|
/**********************
|
|
|
|
* GLOBAL PROTOTYPES
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
/**
|
2017-10-20 22:41:10 +02:00
|
|
|
* Register an initialized input device driver.
|
|
|
|
* @param driver pointer to an initialized 'lv_indev_drv_t' variable (can be local variable)
|
|
|
|
* @return pointer to the new input device or NULL on error
|
2017-10-18 14:09:10 +02:00
|
|
|
*/
|
2017-11-19 21:16:53 +01:00
|
|
|
lv_indev_t * lv_indev_register(lv_indev_drv_t *driver);
|
2017-10-18 14:09:10 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the next input device.
|
|
|
|
* @param indev pointer to the current input device. NULL to initialize.
|
2017-11-19 19:28:45 +01:00
|
|
|
* @return the next input devise or NULL if no more. Gives the first input device when the parameter is NULL
|
2017-10-18 14:09:10 +02:00
|
|
|
*/
|
|
|
|
lv_indev_t * lv_indev_next(lv_indev_t * indev);
|
|
|
|
|
2017-10-20 22:41:10 +02:00
|
|
|
/**
|
|
|
|
* Read data from an input device.
|
|
|
|
* @param indev pointer to an input device
|
|
|
|
* @param data input device will write its data here
|
|
|
|
* @return false: no more data; true: there more data to read (buffered)
|
|
|
|
*/
|
|
|
|
bool lv_indev_read(lv_indev_t * indev, lv_indev_data_t *data);
|
|
|
|
|
2017-10-18 14:09:10 +02:00
|
|
|
/**********************
|
|
|
|
* MACROS
|
|
|
|
**********************/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* extern "C" */
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|