UCGUI如何设置菜单系统

UCGUI如何设置菜单系统,第1张

UCGUI多级菜单设计

1 建立UCGUI主菜单

1.1 利用建立窗口函数来建立主菜单界面

用户通过利用UCGUI中WM_CreateWindow函数建立一个指定大小的窗口。

窗口对话框建立函数

GUI_CreateDialogBox(const GUI_WIDGET_CREATE_INFO* paWidget, int NumWidgets, WM_CALLBACK* cb, WM_HWIN hParent, int x0, int y0)

paWidge,对话框信息结构体,包含了对话框所有的信息,对话框中的各个部件都在该信息结构体中被设置好。

NumWidgets,对话框中所有部件的个数。

cb,窗口回调函数。

hParent,窗口父窗口的句柄

x0,y0,窗口建立时起始位置。

扩展型窗口对话框建立函数:

GUI_ExecDialogBox(const GUI_WIDGET_CREATE_INFO* paWidget,int NumWidgets, WM_CALLBACK* WM_HWIN hParent, int x0, int y0)

paWidget,窗口信息。

NumWidgets,窗口部件数目。

cb,,窗口回调函数。

hParent,父窗口句柄。

x0,y0,窗口建立时起始位置。

1.2 回调函数

一般来说,每一个窗口的建立都会附带有一个属于该窗口的回调函数,利用回调函数来实时更新窗口的内容。

UCGUI中为窗口和窗口对象(控件)提供的回调机制实质上是一个事件驱动系统。正如在大多数视窗系统中一样,原则是控制流程不只是从用户程序到图形系统(用户程序调用图形系统函数来更新窗口),而且可以从用户程序到图形系统,同时也可以从图形系统回到用户程序,意思是图形系统也可以调用用户程序提供的回调函数来达到更新窗口的目的。这种机制常常表现好莱坞法则的特点(“不要打电话给我们,我们会打电话给你”)---主要是视窗管理器为了启动窗口重绘的需要。与传统程序比较有差异,但它使对视窗管理器的无效逻辑开发成为可能。

回调函数的执行行为依赖于它收到的消息类型。上面的函数原型通常带有一个开关声明,用于定义了对于不同的使用一个或者更多的事件声明的消息所采用的不同的处理方式(典型的至少有对WM_PAINT()的处理)。

回调函数需要获得的信息包括有:目标窗口、目标窗口的消息、源窗口、源窗口下部件的ID等信息。

回调函数中可以通过获取目标窗口,然后在获取目标窗口下的各个部件的ID,这时可以根据窗口的消息类型来初始化各个部件,如消息是WM_INIT_DIALOG时,可以直接对窗口进行初始化设置,例如设置按钮按下之后的背景色、设置窗口的字体大小等。如果要使用回调函数实时更新各个窗口,必须要运行GUI_Exec()或WM_Exec函数。

1.3 常用窗口初始化函数解析

窗口初始化方式有两种,一种是在新建窗口时初始化,第二种则是利用回调函数初始化窗口。使用在新建窗口时初始化的方法与回调函数中初始化窗口差不多,在新建窗口时给窗口一个指定的句柄,在利用常用的窗口初始化函数对窗口句柄进行初始化即可。

在回调函数中对窗口初始化应该注意,进入回调函数就立即获取窗口句柄,同时必须要用缓存保存从窗口中获取的各个部件的ID。

获取窗口部件函数如下:

WM_HWIN _GetDialogItem(WM_HWIN hWin, int Id)函数从窗口中获取各个部件的ID。

hWin,为部件所在窗体的源窗口句柄,Id为建立控件时为控件设置的ID。在窗体回调函数中必须要注意WM_HWIN _GetDialogItem函数调用的位置,在WN_INIT_DIALOG前调用还是在其后调用所得到的结果不同。通过调整该函数在回调函数中所在的位置来确定程序能否正常运行。

对于窗口名的设置用FRAMEWIN的相关函数。常用的函数原型如下有:

设置窗口标题的字体大小函数:

FRAMEWIN_SetFont(FRAMEWIN_Handle hObj, const GUI_FONT GUI_UNI_PTR * pFont)。

FRAMEWIN_Handle,为所建立的窗口的句柄,不需要调用窗口部件获取函数去获取其部件ID,只需要在进入回调函数时调用获取源窗口句柄函数(pMsg->hWin)即可实现。

* pFont为窗口标题的字体,一般用GUI.H中UCGUI自带的字体即可,用户也可自定义GUI支持的字体,GUI自带的字体只支持英文的,不支持中文字体,如果需要显示中文字体,用户要用GUI字库生成软件生成,在添加进工程才行。

设置窗口标题字体显示的对齐方式函数:

FRAMEWIN_SetTextAlign(FRAMEWIN_Handle hObj, int Align)

hObj为源窗口句柄,Align为窗体标题显示对齐方式,其取值一般有:左对齐,右对齐,居中等,这些参数在GUI.H函数中已经被定义为宏,用户根据需要直接使用即可。

设置窗口标题的显示颜色:

FRAMEWIN_SetTextColor (FRAMEWIN_Handle hObj, GUI_COLOR Color)

hObj为源窗口句柄,Color为标题颜色,参数在GUI.H中被定义为宏。

设置窗口标题栏高度:

FRAMEWIN_SetTitleHeight (FRAMEWIN_Handle hObj, int Height)

hObj为窗口句柄,Height为标题栏高度

为窗口中添加关闭窗口按钮:

FRAMEWIN_AddCloseButton(FRAMEWIN_Handle hObj, int Flags, int Off)。

hObj为要添加按钮的窗口句柄。Flags为添加的按钮的显示方式,基本参数为FRAMEWIN_BUTTON_RIGHT或FRAMEWIN_BUTTON_LEFT,即将该关闭窗口按钮显示在窗口的最左端或是最右端。

为窗口添加最大化显示按钮:

FRAMEWIN_AddMaxButton(FRAMEWIN_Handle hObj, int Flags, int Off)与上述添加关闭窗口按钮原理相同。

为窗口添加最小化按钮:

FRAMEWIN_AddMinButton(FRAMEWIN_Handle hObj, int Flags, int Off),如上同理。一般情况下,这三个函数在窗体初始化时同时使用。

窗口BUTTON部件常用设置函数如下:

设置按钮显示的字体

BUTTON_SetFont(BUTTON_Handle hObj, const GUI_FONT GUI_UNI_PTR * pfont)

hObj为BUTTON部件句柄,在设置之前应该从窗口中获取,pfont按钮显示字体,GUI默认只能支持英文。

设置按钮按下或没有按下时的背景色

BUTTON_SetBkColor(BUTTON_Handle hObj,unsigned int Index, GUI_COLOR Color)

hObj为BUTTON部件句柄,Index为索引,0表示按钮没有按下,1表示按钮按下,Color为BUTTON的背景色。

设置按钮按下或是没有按下时,按钮上的文字的颜色:

BUTTON_SetTextColor(BUTTON_Handle hObj,unsigned int Index, GUI_COLOR Color)

hObj为BUTTON部件句柄,Index为索引,0表示按钮没有按下,1表示按钮按下,Color为文字颜色。

常用LISTBOX设置函数如下。

设置LISTBOX显示内容的字体:

LISTBOX_SetFont(LISTBOX_Handle hObj, const GUI_FONT GUI_UNI_PTR * pFont)

hObj为LISTBOX部件句柄,pFont为在LISTBOX中显示内容的字体,GUI默认只支持英文,中文字体需要用户自己添加。

往LISTBOX中添加内容:

LISTBOX_AddString (LISTBOX_Handle hObj, const char* s)

hObj为LISTBOX部件句柄,*s为要添加的内容,一般为字符串。

高亮LISTBOX中的上一个目录:

LISTBOX_DecSel (LISTBOX_Handle hObj)

高亮LISTBOX中的下一个目录:

LISTBOX_IncSel (LISTBOX_Handle hObj)

hObj为LISTBOX部件句柄。

获取LISTBOX中高亮目录:

LISTBOX_GetSel (LISTBOX_Handle hObj)

hObj,LISTBOX部件句柄,返回的是该目录在LISTBOX中的序号。获取LISTBOX中高亮目录的内容

LISTBOX_GetItemText (LISTBOX_Handle hObj, unsigned Index, char * pBuffer, int MaxSize)

hObj为LISTBOX部件句柄,Index为高亮目录在LISTBOX中的序号,* pBuffer为该目录内容的缓存区,MaxSize为高亮目录最大字节数。

设置LISTBOX的水平自动滚动步进:

LISTBOX_SetAutoScrollH (LISTBOX_Handle hObj, int OnOff)

hObj为LISTBOX部件句柄,OnOff为点击LISTBOX滑动条时,窗口目录自动水平滚动步进的大小。

设置LISTBOX的垂直自动滚动步进:

LISTBOX_SetAutoScrollV (LISTBOX_Handle hObj, int OnOff)

hObj为LISTBOX部件句柄,OnOff为点击LISTBOX滑动条时,窗口目录自动垂直滚动步进的大小。

设置LISTBOX目录水平卷动步进:

LISTBOX_SetScrollStepH (LISTBOX_Handle hObj, int Value)

hObj为LISTBOX部件句柄,Value为步进大小。

在执行回调函数中响应源窗口下的各个部件动作的时候,一般是在WM_NOTIFY_PARENT消息下来进行。在WM_NOTIFY_PARENT消息下,获取源窗口各个部件的ID以及窗口部件的数值。

如图所示,先判断目标窗口返回的消息是否是WM_NOTIFY_PARENT,如果是则获取源窗口返回的Id和消息的数值。根据消息的数值再去判断Id属于哪个部件,然后根据部件的动作,实现不同的 *** 作。

2 主菜单下子菜单的添加与功能设置

2.1建立菜单

MENU_CreateEx(int x0, int y0, int xSize, int ySize, WM_HWIN hParent, int WinFlags, int ExFlags, int Id)

x0,y0,菜单起始坐标;

xSize,ySize,菜单框的宽度与高度;

hParent,菜单所在父窗口句柄;

WinFlags,菜单显示属性;

ExFlags,菜单框属性;

Id,菜单框ID;

先利用直接建立菜单函数建立一个空菜单框,然后再往空菜单框中添加子菜单,来实现一个菜单栏下有多级子菜单的效果。

在主菜单栏下添加子菜单实现方法

先建立一个菜单栏结构体(MENU_ITEM_DATA 为菜单结构体),然后对结构体内的各个成员初始化赋值即可。

hMenu, 为主菜单句柄,即该子菜单所在的菜单栏的句柄。

hSubmenu,为该子菜单的句柄。

*pText, 为子菜单名称。

Id, 为当前子菜单的ID。

Flags,为当前子菜单的附加属性。

常用建立添加有子菜单栏的菜单栏方法

先建立一个主菜单,然后在该主菜单栏下添加子菜单即可实现。添加完子菜单之后,用户只需要点击相应的菜单该菜单下的子菜单会自动d出,无需用户自己写d出函数。

在前一子菜单与后一子菜单之间加一条分隔线:

_AddTaskMenuItem(hMenuStart,0,0,0,MENU_IF_SEPARATOR)

将已经准备好的菜单粘贴到指定的窗口上:

MENU_Attach(MENU_Handle hObj, WM_HWIN hDestWin, int x, int y, int xSize, int ySize, int Flags)

hObj,菜单句柄。

hDestWin,窗口句柄。

x,y,xSize,ySize,为菜单在窗口中的位置及菜单的高度与宽度。

Flags,菜单显示属性。

2.2 菜单回调函数

菜单回调函数通常写法

菜单建立之后返回的消息

MENU_ON_ITEMSELECT,当该菜单被选择时所收到的消息。

MENU_ON_INITMENU,对建立的菜单初始化。

MENU_ON_ITEMSELECT,当前菜单被选择时所收到的消息,根据该消息再来判断该菜单下子菜单的ID。

#include <stddef.h>

#include "GUI.h"

#include "DIALOG.h"

#include "WM.h"

#include "BUTTON.h"

#include "FRAMEWIN.h"

/*主界面的资源链表*/

static const GUI_WIDGET_CREATE_INFO _aDialogCreate[] = {

    { FRAMEWIN_CreateIndirect,  "Caption",           0,                       0,  0,  320,240,FRAMEWIN_CF_MOVEABLE,0},

    { BUTTON_CreateIndirect,    "BUTTON0",           GUI_ID_BUTTON0,          84, 55, 134,56, 0,0}

}

/*按钮按下之后的资源链表*/

static const GUI_WIDGET_CREATE_INFO _aButtonCreate[] = {

    { FRAMEWIN_CreateIndirect,  "Caption",           0,                       0,  0,  320,240,FRAMEWIN_CF_MOVEABLE,0},

}

/*主界面的绘制函数*/

void PaintDialog(WM_MESSAGE * pMsg)

{

    WM_HWIN hWin = pMsg->hWin

}

/*主界面的初始化函数,初始化标题栏的最大化,最小化,关闭按钮*/

void InitDialog(WM_MESSAGE * pMsg)

{

    WM_HWIN hWin = pMsg->hWin

    //

    //FRAMEWIN

    //

    FRAMEWIN_AddCloseButton(hWin, FRAMEWIN_BUTTON_RIGHT, 0)

    FRAMEWIN_AddMaxButton(hWin, FRAMEWIN_BUTTON_RIGHT, 1)

    FRAMEWIN_AddMinButton(hWin, FRAMEWIN_BUTTON_RIGHT, 2)

}

/*按钮d出界面的回调函数*/

static void _cbButtonCallback(WM_MESSAGE * pMsg) 

{

    WM_HWIN hWin = pMsg->hWin

    switch (pMsg->MsgId) 

    {

case WM_INIT_DIALOG:

            InitDialog(pMsg)

            break

        default:

            WM_DefaultProc(pMsg)

    }

}

/*主界面的回调函数*/

static void _cbCallback(WM_MESSAGE * pMsg) 

{

    int NCode, Id

    WM_HWIN hWin = pMsg->hWin

    switch (pMsg->MsgId) 

    {

        case WM_PAINT://绘制界面

            PaintDialog(pMsg)

            break

        case WM_INIT_DIALOG://初始化界面

            InitDialog(pMsg)

            break

#if 0

//这个是接收键盘上的按键的相应

        case WM_KEY:

            switch (((WM_KEY_INFO*)(pMsg->Data.p))->Key) 

            {

                case GUI_KEY_ESCAPE:

                    GUI_EndDialog(hWin, 1)

                    break

                case GUI_KEY_ENTER:

                    GUI_EndDialog(hWin, 0)

                    break

            }

            break

#endif

        case WM_NOTIFY_PARENT:

            Id = WM_GetId(pMsg->hWinSrc) 

            NCode = pMsg->Data.v        

            switch (Id) 

            {

                case GUI_ID_BUTTON0:

                    if(NCode==WM_NOTIFICATION_RELEASED)

{

                       GUI_ExecDialogBox(_aButtonCreate, GUI_COUNTOF(_aButtonCreate), &_cbButtonCallback, 0, 0, 0)

                    }

break           

            }

            break

        default:

            WM_DefaultProc(pMsg)

    }

}

/*********************************************************************

*

*       MainTask

*

**********************************************************************

*/

void MainTask(void) 

    GUI_Init()

    WM_SetDesktopColor(GUI_WHITE)      /* Automacally update desktop window */

    WM_SetCreateFlags(WM_CF_MEMDEV)  /* Use memory devices on all windows to avoid flicker */

while(1)

{

        GUI_ExecDialogBox(_aDialogCreate, GUI_COUNTOF(_aDialogCreate), &_cbCallback, 0, 0, 0)

}

}

关于界面的创建可以用ucguibuilder来创建,它会自动生成代码;然后自己根据所需修改即可。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/7733564.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-09
下一篇 2023-04-09

发表评论

登录后才能评论

评论列表(0条)

保存