UP BMP脚本
This commit is contained in:
@@ -1,13 +1,13 @@
|
||||
#include "page.h"
|
||||
#include "list.h"
|
||||
|
||||
uint8_t pageid = 0, cur = 1, cnt = 0;
|
||||
uint8_t pageid = 0, cur = 1, cnt = 0, item_h = 12;
|
||||
|
||||
static List_t list;
|
||||
Page_L_t mainp = {0, 3, 0, 0, mainpage};
|
||||
Page_L_t ap = {1, 2, 0, 0, pageA};
|
||||
Page_L_t bp = {2, 2, 0, 0, pageB};
|
||||
Page_L_t cp = {3, 2, 0, 0, pageC};
|
||||
Page_L_t mainp = {0, 3, 0, 1, 12, mainpage};
|
||||
Page_L_t ap = {1, 2, 0, 1, 12, pageA};
|
||||
Page_L_t bp = {2, 2, 0, 1, 12, pageB};
|
||||
Page_L_t cp = {3, 2, 0, 1, 12, pageC};
|
||||
|
||||
void pageinit() {
|
||||
list_init(&list);
|
||||
@@ -32,9 +32,7 @@ Page_L_t pagesearch(uint8_t id) {
|
||||
|
||||
void pagecur(OLED_T *dev) {
|
||||
if (cnt % 2) {
|
||||
if (cur > 0 && cur <= pagesearch(pageid).next)OLED_ShowString(dev, 26, cur * 12, ">", 12);
|
||||
else
|
||||
cur = 1;
|
||||
OLED_ShowString(dev, 26, cur * item_h, ">", item_h);
|
||||
}
|
||||
cnt++;
|
||||
}
|
||||
|
@@ -5,13 +5,14 @@
|
||||
|
||||
typedef void (*Page_t)(OLED_T *dev);
|
||||
|
||||
extern uint8_t pageid, cur, cnt;
|
||||
extern uint8_t pageid, cur, cnt, item_h;
|
||||
|
||||
typedef struct Page_L {
|
||||
uint8_t id;
|
||||
uint8_t next;
|
||||
uint8_t curmax: 3;
|
||||
uint8_t back;
|
||||
uint8_t enter;
|
||||
uint8_t curmin: 3;
|
||||
uint8_t item_h: 4;
|
||||
Page_t page;
|
||||
} Page_L_t;
|
||||
|
||||
|
@@ -41,6 +41,8 @@ void Key_Call_E(Key_t *key) {
|
||||
LOGT("KEY", "ID:%d EVENT:%s", key->key_id, "ClickEvent");
|
||||
if (key->key_id == SIM_KEY_UP)cur--;
|
||||
if (key->key_id == SIM_KEY_DOWN)cur++;
|
||||
if (cur < pagesearch(pageid).curmin && pagesearch(pageid).curmin != 0)cur = pagesearch(pageid).curmax;
|
||||
if (cur > pagesearch(pageid).curmax && pagesearch(pageid).curmax != 0)cur = pagesearch(pageid).curmin;
|
||||
if (key->key_id == SIM_KEY_LEFT)pageid--;
|
||||
if (key->key_id == SIM_KEY_RIGHT)pageid++;
|
||||
if (key->key_id == SIM_KEY_RESET)pageid = pagesearch(pageid).back;
|
||||
@@ -133,6 +135,7 @@ void Test_OLED() {
|
||||
pageinit();
|
||||
while (1) {
|
||||
if (pageid > 3)pageid = 0;
|
||||
item_h = pagesearch(pageid).item_h;
|
||||
// pagesearch(pageid).page(&oled);
|
||||
// sprintf(buf, "DATA:%d", s);
|
||||
// OLED_ShowString(&oled, 2, 51, buf, 12);
|
||||
|
Reference in New Issue
Block a user