feat: 添加实时图像显示菜单

fix: 修改旋转编码器接口中部分拼写错误的问题
pref: 修改zf_common_font.c文件中>字符的图案,方便作为指针显示
This commit is contained in:
2024-01-04 22:07:13 +08:00
parent 59a29d4eac
commit 7efb0ee985
11 changed files with 148 additions and 106 deletions

View File

@@ -1,9 +1,11 @@
#include "cw_page.h"
#include "by_rt_button.h"
PAGE_LIST pagelist[page_max];
static uint8_t page_busy = 0;
static int8_t now_page = page_menu;
static int8_t new_page = page_menu;
static int8_t now_page = page_menu;
static int8_t new_page = page_menu;
/**
* @brief 注册一个基本页面,包含一个初始化函数,循环函数,退出函数,事件函数
@@ -16,12 +18,13 @@ static int8_t new_page = page_menu;
* @retval 无
*/
void Page_Register(uint8_t pageID, char *pageText,
CallbackFunction_t setupCallback, CallbackFunction_t loopCallback,
CallbackFunction_t exitCallback, EventFunction_t eventCallback) {
pagelist[pageID].Text = pageText;
CallbackFunction_t setupCallback, CallbackFunction_t loopCallback,
CallbackFunction_t exitCallback, EventFunction_t eventCallback)
{
pagelist[pageID].Text = pageText;
pagelist[pageID].SetupCallback = setupCallback;
pagelist[pageID].LoopCallback = loopCallback;
pagelist[pageID].ExitCallback = exitCallback;
pagelist[pageID].LoopCallback = loopCallback;
pagelist[pageID].ExitCallback = exitCallback;
pagelist[pageID].EventCallback = eventCallback;
}
@@ -30,7 +33,8 @@ void Page_Register(uint8_t pageID, char *pageText,
* @param event: 事件编号
* @retval 无
*/
void Page_EventTransmit(unsigned char event) {
void Page_EventTransmit(unsigned char event)
{
/*将事件传递到当前页面*/
if (pagelist[now_page].EventCallback != 0)
pagelist[now_page].EventCallback(event);
@@ -41,7 +45,8 @@ void Page_EventTransmit(unsigned char event) {
* @param pageID页面号
* @retval 1成功 0失败
*/
void Page_Shift(unsigned char pageID) {
void Page_Shift(unsigned char pageID)
{
if (page_busy == 0) {
new_page = pageID;
}
@@ -51,7 +56,8 @@ void Page_Shift(unsigned char pageID) {
* @brief 关闭当前页面
*
*/
void Page_CloseCurrentPage() {
void Page_CloseCurrentPage()
{
pagelist[now_page].ExitCallback();
}
@@ -59,16 +65,18 @@ void Page_CloseCurrentPage() {
* @brief 打开当前页面
*
*/
void Page_OpenCurrentPage() {
void Page_OpenCurrentPage()
{
pagelist[now_page].SetupCallback();
}
/**
* @brief 获取页面状态
*
* @return uint8_t 页面忙返回1 空闲返回0
* @return uint8_t 页面忙返回 1 空闲返回 0
*/
uint8_t Page_GetStatus(void) {
uint8_t Page_GetStatus(void)
{
if (page_busy)
return 1;
else
@@ -79,18 +87,23 @@ uint8_t Page_GetStatus(void) {
* @brief 页面运行函数
*
*/
void Page_Run(void) {
void Page_Run(void)
{
uint8_t temp_status = by_get_rb_status(); // 轮询旋钮状态
if(temp_status){
pagelist[now_page].EventCallback(temp_status);
}
if (now_page != new_page) {
if (new_page >= page_max && new_page < page_menu) {
new_page = page_menu;
}
//执行当前页面退出回调函数
// 执行当前页面退出回调函数
if ((pagelist[now_page].ExitCallback != 0)) {
pagelist[now_page].ExitCallback();
}
//执行新页面构造回调函数
// 执行新页面构造回调函数
if (pagelist[new_page].SetupCallback != 0) {
pagelist[new_page].SetupCallback();
}
@@ -99,7 +112,7 @@ void Page_Run(void) {
}
if (page_busy == 0) {
//执行循环函数
// 执行循环函数
pagelist[now_page].LoopCallback();
}
}
@@ -108,13 +121,15 @@ void Page_Run(void) {
* @brief 页面初始化(注册,构建) //ATTENTION 在此处添加新加入的页面
*
*/
void Page_Init(void) {
void Page_Init(void)
{
PAGE_REG(page_menu);
PAGE_REG(page_rtcam);
// PAGE_REG(page_argv);
// PAGE_REG(page_sys);
// PAGE_REG(page_run);
Page_Shift(page_menu);
pagelist[now_page].SetupCallback(); //先构建一遍
pagelist[now_page].SetupCallback(); // 先构建一遍
}

View File

@@ -13,10 +13,13 @@
#include "zf_common_headfile.h"
#include "by_rt_button.h"
enum PageID {
PAGE_NULL = -1,
//......
page_menu,
page_rtcam,
// page_argv,
// page_sys,
// page_run,
@@ -25,9 +28,9 @@ enum PageID {
};
typedef enum page_event{
page_event_forward,
page_event_backward,
page_event_press
page_event_forward = ROTATE_BUTTON_FORWARD,
page_event_backward = ROTATE_BUTTON_BACKWARD,
page_event_press = ROTATE_BUTTON_PRESS
} page_event;
typedef void (*CallbackFunction_t)(void);

View File

@@ -7,8 +7,8 @@
static char Text[] = "Menu";
static int8_t Curser = 1; // 定义光标位置
static int8_t Curser_Last = 1; // 定义光标位置
static int8_t Curser = LINE_HEAD; // 定义光标位置
static int8_t Curser_Last = LINE_HEAD; // 定义光标位置
static void Print_Menu_p(void);
/***************************************************************************************
*
@@ -44,7 +44,6 @@ static void Exit()
*/
static void Loop()
{
Show_Marked_Image();
}
/**
@@ -101,7 +100,7 @@ static void Print_Menu_p(void)
// SCREEN_showstr_style(5 * 8, 0, RED, WHITE, "#### MAIN MENU ####");
ips200_show_string(0, 0, Text);
for (uint8_t i = page_menu + 1; i < page_max; i++) {
ips200_show_string(8, i, pagelist[i].Text);
ips200_show_string(10, i * 16, pagelist[i].Text);
// SCREEN_showstr(8, i, pagelist[i].Text);
}
}

View File

@@ -2,13 +2,13 @@
#include "cw_page_ui_widget.h"
#include "cw_page.h"
#define LINE_HEAD 1
#define LINE_END 7
#define LINE_HEAD 11
#define LINE_END 18
static char Text[] = "RealTime Image";
static int8_t Curser = 1; // 定义光标位置
static int8_t Curser_Last = 1; // 定义光标位置
static int8_t Curser = LINE_HEAD; // 定义光标位置
static int8_t Curser_Last = LINE_HEAD; // 定义光标位置
static void Print_Menu_p(void);
/***************************************************************************************
*
@@ -23,7 +23,7 @@ static void Print_Menu_p(void);
*/
static void Setup()
{
ips114_clear();
ips200_clear();
Print_Menu_p();
Print_Curser(Curser, Curser_Last);
}
@@ -44,6 +44,7 @@ static void Exit()
*/
static void Loop()
{
Show_Marked_Image();
}
/**
@@ -99,8 +100,4 @@ static void Print_Menu_p(void)
{
// SCREEN_showstr_style(5 * 8, 0, RED, WHITE, "#### MAIN MENU ####");
ips200_show_string(0, 0, Text);
for (uint8_t i = page_menu + 1; i < page_max; i++) {
ips200_show_string(8, i, pagelist[i].Text);
// SCREEN_showstr(8, i, pagelist[i].Text);
}
}