NWatch多级菜单技术分析

NWatch多级菜单技术分析

typedef struct{
	menu_f btn1;
	menu_f btn2;
	menu_f btn3;
	draw_f draw;
	itemLoader_f loader;
}menuFuncs_t;

typedef struct{
	uint8_t lastSelected;
	menu_f last;
}prev_menu_s;

typedef struct{
	uint8_t selected;
	uint8_t optionCount;
	bool isOpen;
	const char* title;
	menu_type_t menuType;
	menuFuncs_t func;
	menu_f prevMenu;
}menu_s;

在这里插入图片描述
首先NWatch会通过一个菜单结构体menu_s来设置当前菜单的内容,例如设置当前的菜单的被选的应用、应用个数、菜单名字、菜单类型、菜单的函数和上一级菜单的加载函数等相关信息。

定义主菜单

menu_s Main_Menu = {0};

初始化主菜单

NWatch多级菜单的实现是通过一种类似与链表的形式。
通过菜单的设置函数来设置当前菜单的的内容。
例如下面是设置手表菜单的内容,用来显示系统的时间和日期。
在这里插入图片描述

void drawWatch(void){
	ticker();
	drawDate();
}

void watchLoad(void){
	SetDrawFunc(drawWatch);
	SetButtonFunc(NULL, menuSelect, NULL);
	SetMenuPre(&prevMenus,watchLoad);
	AnimotionInto(NULL);
}

当按下确认键以后进行NWatch主界面,重新设置菜单的内容和功能。
在这里插入图片描述

void mainMenu(void){
	SetDrawFunc(drawMenu);
	SetButtonFunc(menuUp, menuSelect, menuDown);
	SetMenuFunc(preOption, menuSelect, nextOption,loader);
    SetMenuInfo(optionCount,MENU_TYPE_ICON,PSTR(STR_MAINMENU));
	SetMenuPre(&prevMenus,mainMenu);
	
	AnimotionInto(NULL);
}

当退出当前界面时候,也是类似调用菜单函数来重新填充当前菜单的内容

效果展示

多级菜单切换

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

葛霸霸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值