【第3版emWin教程】第35章 emWin6.x的AppWizard中文实现方法
教程不断更新中:http://www.armbbs.cn/forum.php?mod=viewthread&tid=98429
第35章 emWin6.x的AppWizard中文实现方法
本期教程跟大家讲解emWin6.x新版GUIBuilder工具AppWizard的中文显示方法。
35.1 初学者重要提示
35.2 AppWizard创建带中文界面
35.3 AppWizard生成的VS工程使用VS2019运行方法
35.4 AppWizard创建的界面添加到工程
35.5 实验例程说明(RTOS)
35.6 实验例程说明(裸机)
35.7 总结
35.1 初学者重要提示
1、 使用的AppWizard版本一定要和emWin版本匹配,本章配套例子使用的emWin版本是V6.16。对应的AppWizard版本是V1.20,下载地址:
http://www.armbbs.cn/forum.php?mod=viewthread&tid=105049 。
2、 AppWizard工程路径不支持中文,使用时特别注意。
3、 AppWizard生成的emWin6.x工程可以方便的融合之前的低版本emWin工程代码,在回调函数里面可以方便的添加之前基于窗口或者对话框创建的界面。
35.2 AppWizard创建带中文界面
下面使用AppWizard设计带中文的界面,然后将设计的界面移植到板子上运行,让大家有个整体的认识,后面章节再为大家说明AppWizard具体选项的功能。
35.2.1 下载安装AppWizard
下载地址:http://www.armbbs.cn/forum.php?mod=viewthread&tid=105049 。安装后效果如下:
35.2.2 创建AppWizard工程
选择Create new project:
下面要需要设置配置项,主要是Color format颜色格式别配置错了,要跟开发板emWin工程的颜色格式一致,我们这里设置为16位色,M565。
创建后效果如下:
35.2.3 添加控件
依次点击左上角的控件对象:Screen和Box:
设置背景色:
添加两个按钮控件和一个二维码:
35.2.4 设置默认的位图格式
点击菜单Edit -> Preferences:
由于我们前面设置的M565颜色格式,这里设置GUICC_M565选项即可:
这个设置很重要,否则很容易造成AppWizard生成的工程代码移植到板子上硬件异常。
35.2.5 设置默认的字库方式
点击菜单Edit -> Preferences:
Project text only表示仅展示工程里面设置的中文汉字。
35.2.6 添加带中文的文本控件
添加text文本控件:
添加文本内容:
添加后会多出一列,方便我们添加中文:
添加文本:
设置字体:
由于我们选择的字体名称“微软雅黑”是中文,导致仅显示了_24_Normal_EXT_AA4,没有前缀,但不影响使用。现在再看TEXT控件,会发现我们前面设置的中文已经可以正常显示了:
相同的方法,再添加一个文本控件
继续使用相同的字体,只是我们这里不可以直接点击这里选择,必须按照前面的方法重新生成一次即可:
完整的效果如下:
35.2.7 运行AppWizard
点击下面这个小按钮可以运行设计的界面:
35.2.8 导出AppWizard代码
点击菜单File -> Export & Save即可导出:
导出文件在创建时设置的路径中。
35.3 AppWizard生成的VS工程使用VS2019运行方法
导出的VS工程文件位于如下路径:
运行后效果如下:
35.4 AppWizard创建的界面添加到工程
AppWizard生成界面代码后,将其添加到工程中。这个过程有几个注意事项,在下面步骤中会为大家说明。
35.4.1 添加一批xxxx_Private.h文件到工程
开发板的工程文件里面没有这些文件,需要大家从AppWizard工程路径:Simulation\GUI_Lib 里面复制到开发板工程路径\emWin\Include里面,下面是部分截图,详情看本章节配套的例子即可:
35.4.2 添加AppWizard界面文件到工程
方便起见,将AppWizard所有文件复制到开发板工程里面:
添加到工程的效果如下:
35.4.3 添加工程路径
仅添加一个路径选项即可:
35.4.4 修改程序
主要修改两个地方:
- bsp.c文件将LCD背光点亮。
void bsp_Init(void) { /* 省略未写 */ /* 延迟200ms再点亮背光,避免瞬间高亮 */ bsp_DelayMS(200); LCD_SetBackLight(255); }
- APPWConf.c文件
使能三缓冲,关闭文件系统。
/********************************************************************* * * Multibuffering */ static U8 _MultibufEnable = 1; /********************************************************************* * * Static code * ********************************************************************** */ /********************************************************************* * * _InitText */ static void _InitText(void) { // // Empty, because application does not contain any text // } /********************************************************************* * * Public code * ********************************************************************** */ /********************************************************************* * * APPW_X_Setup */ void APPW_X_Setup(void) { APPW_SetpfInitText(_InitText); //APPW_X_FS_Init(); APPW_MULTIBUF_Enable(_MultibufEnable); APPW_SetData(_apRootList, _NumScreens, _aVarList, _NumVars); }
通过前面这几步就完成了AppWizard工程界面的移植。剩下就可以编程工程代码下载到板子运行了。
35.5 实验例程说明(RTOS)
配套例子:
V7-545_emWin6.x实验_AppWizard中文显示(RTOS)
实验目的:
- 学习AppWizard中文显示。
实验内容:
1、K1按键按下,串口或者RTT打印任务执行情况(串口波特率115200,数据位8,奇偶校验位无,停止位1)。
2、(1) 凡是用到printf函数的全部通过函数App_Printf实现。
(2) App_Printf函数做了信号量的互斥操作,解决资源共享问题。
3、默认上电是通过串口打印信息,如果使用RTT打印信息:
MDK AC5,MDK AC6或IAR通过使能bsp.h文件中的宏定义为1即可
#define Enable_RTTViewer 1
4、各个任务实现的功能如下:
App Task Start 任务 :启动任务,这里用作BSP驱动包处理。
App Task MspPro任务 :消息处理,这里用作LED闪烁。
App Task UserIF 任务 :按键消息处理。
App Task COM 任务 :暂未使用。
App Task GUI 任务 :GUI任务。
μCOS-III任务调试信息(按K1按键,串口打印):
RTT 打印信息方式:
程序设计:
任务栈大小分配:
μCOS-III任务栈大小在app_cfg.h文件中配置:
#define APP_CFG_TASK_START_STK_SIZE 512u
#define APP_CFG_TASK_MsgPro_STK_SIZE 2048u
#define APP_CFG_TASK_COM_STK_SIZE 512u
#define APP_CFG_TASK_USER_IF_STK_SIZE 512u
#define APP_CFG_TASK_GUI_STK_SIZE 2048u
任务栈大小的单位是4字节,那么每个任务的栈大小如下:
App Task Start 任务 :2048字节。
App Task MspPro任务 :8192字节。
App Task UserIF 任务 :2048字节。
App Task COM 任务 :2048字节。
App Task GUI 任务 :8192字节。
系统栈大小分配:
μCOS-III的系统栈大小在os_cfg_app.h文件中配置:
#define OS_CFG_ISR_STK_SIZE 512u
系统栈大小的单位是4字节,那么这里就是配置系统栈大小为2KB
emWin动态内存配置:
GUIConf.c文件中的配置如下:
#define EX_SRAM 1/*1 used extern sram, 0 used internal sram */ #if EX_SRAM #define GUI_NUMBYTES (1024*1024*24) #else #define GUI_NUMBYTES (100*1024) #endif
通过宏定义来配置使用内部SRAM还是外部的SDRAM做为emWin的动态内存,当配置:
#define EX_SRAM 1 表示使用外部SDRAM作为emWin动态内存,大小24MB。
#define EX_SRAM 0 表示使用内部SRAM作为emWin动态内存,大小100KB。
默认情况下,本教程配套的所有emWin例子都是用外部SDRAM作为emWin动态内存。
emWin界面显示效果:
800*480分辨率界面效果。
35.6 实验例程说明(裸机)
配套例子:
V7-544_emWin6.x实验_AppWizard中文显示(裸机)
实验目的:
- 学习AppWizard中文显示。
emWin界面显示效果:
800*480分辨率界面效果。
emWin动态内存配置:
GUIConf.c文件中的配置如下:
#define EX_SRAM 1/*1 used extern sram, 0 used internal sram */ #if EX_SRAM #define GUI_NUMBYTES (1024*1024*24) #else #define GUI_NUMBYTES (100*1024) #endif
通过宏定义来配置使用内部SRAM还是外部的SDRAM做为emWin的动态内存,当配置:
#define EX_SRAM 1 表示使用外部SDRAM作为emWin动态内存,大小24MB。
#define EX_SRAM 0 表示使用内部SRAM作为emWin动态内存,大小100KB。
默认情况下,本教程配套的所有emWin例子都是用外部SDRAM作为emWin动态内存。
35.7 总结
本章节主要是为大家讲解了AppWizard中文显示的基础用法,后续章节将深入为大家说明。