繼上次移植了GUI-Guider生成的GUI界面后,顯示沒什么問題了。但是只有顯示,不能操作,看起來還是不完整。這次就分享如何移植輸入設(shè)備,可以點擊和移動操作。
輸入設(shè)備移植文件主要是這個。如圖,可以看到lvgl支持觸摸指針設(shè)備,鼠標(biāo),鍵盤,encoder,button。
本次是通過串口方式發(fā)送數(shù)據(jù)模擬觸摸指針設(shè)備。下面是主要修改步驟。
串口接收6個字節(jié),定義結(jié)構(gòu)體變量映射6個字節(jié)。代碼如下。
主要是初始化,獲取點擊狀態(tài),獲取x,y坐標(biāo)這3個函數(shù)。
extern union Indev_uart_data
{
struct
{
uint8_t flag;
uint8_t press;
uint16_t x;
uint16_t y;
}touch;
uint8_t buff[6];
}g_input;
/*------------------
* Touchpad
* -----------------*/
/*Initialize your touchpad*/
static void touchpad_init(void)
{
/*Your code comes here*/
memset(g_input.buff, 0, sizeof(g_input.buff));
}
/* Will be called by the library to read the touchpad */
static bool touchpad_read(lv_indev_drv_t * indev_drv, lv_indev_data_t * data)
{
static lv_coord_t last_x = 0;
static lv_coord_t last_y = 0;
/*Save the pressed coordinates and the state*/
if(touchpad_is_pressed()) {
touchpad_get_xy(&last_x, &last_y);
data->state = LV_INDEV_STATE_PR;
} else {
data->state = LV_INDEV_STATE_REL;
}
/*Set the last pressed coordinates*/
data->point.x = last_x;
data->point.y = last_y;
/*Return `false` because we are not buffering and no more data to read*/
return false;
}
/*Return true is the touchpad is pressed*/
static bool touchpad_is_pressed(void)
{
/*Your code comes here*/
if((g_input.touch.flag == 'T')&&(g_input.touch.press))
{
return true;
}
return false;
}
/*Get the x and y coordinates if the touchpad is pressed*/
static void touchpad_get_xy(lv_coord_t * x, lv_coord_t * y)
{
/*Your code comes here*/
if(g_input.touch.flag == 'T')
{
(*x) = g_input.touch.x;
(*y) = g_input.touch.y;
}
}
然后就是主函數(shù)中調(diào)用輸入設(shè)備初始化。
主循環(huán)通過串口接收數(shù)據(jù),模擬觸摸指針設(shè)備。注意串口接收使用非阻塞方式。
下面是通過串口助手發(fā)送數(shù)據(jù)效果,可以看到指針位置。
具體參考如下代碼:lpc55s69_lcd.rar (7.49 MB, 點擊下方附件下載)