?? menufunc.lst
字號:
C51 COMPILER V7.20 MENUFUNC 09/04/2007 23:38:43 PAGE 1
C51 COMPILER V7.20, COMPILATION OF MODULE MENUFUNC
OBJECT MODULE PLACED IN .\Obj\MenuFunc.obj
COMPILER INVOKED BY: D:\Keil\C51\BIN\C51.EXE Src\MenuFunc.C LARGE BROWSE DEBUG OBJECTEXTEND PRINT(.\Lst\MenuFunc.lst) OB
-JECT(.\Obj\MenuFunc.obj)
line level source
1 /******************************************************************************
2 * MenuFunc.C - "功能"菜單 條項動態生成代碼
3 *
4 *
5 * DESCRIPTION: -
6 *
7 * modification history
8 * --------------------
9 * 01a, 04/sep/2007, 梁炎昌 written
10 * --------------------
11 ******************************************************************************/
12 #include "CPU.H"
13
14 #include "Ks0108.H"
15 #include "Menu.H"
16 #include "KeyScan.H"
17
18
19 //功能
20 //Bar型菜單
21 void DispMenuFuncInit()
22 {
23 1 //--------------------
24 1 GUI_Clear();
25 1 //--------------------
26 1 BarMenu = &MenuFunc[language];
27 1 ItemNum = (*BarMenu).TextNum;
28 1 DispItem = (*BarMenu).Text;
29 1
30 1 //顯示按鍵對應的文字提示,1-->"進入"
31 1 GUI_DispStringAtBar(*(Tip[language].Text+1),0,Enter_PosY,126,GUI_TA_HCENTER);
32 1
33 1 //用戶定義的初始化代碼請放在這里
34 1 BarMenuInit();//調用公共初始化的代碼
35 1 }
36
37 void DispMenuFuncUp()
38 {
39 1
40 1 switch(Item){
41 2 case 0:{
42 3 #ifdef DynamicBar
Jump2Menu(MenuDataIndex,FlashMode_AutoInit);
#else
45 3 Jump2Menu(SelfMenuIndex,FlashMode_NoAction);
46 3 #endif
47 3
48 3 break;
49 3 }
50 2 case 1:{
51 3 Jump2Menu(SelfMenuIndex,FlashMode_NoAction);
52 3 break;
53 3 }
54 2 default:{
C51 COMPILER V7.20 MENUFUNC 09/04/2007 23:38:43 PAGE 2
55 3 Jump2Menu(SelfMenuIndex,FlashMode_NoAction);
56 3 break;
57 3 }
58 2 }
59 1
60 1 }
61 void DispMenuFuncDown()
62 {
63 1 POP();
64 1 }
65
66 void DispMenuFuncLeft()
67 {
68 1 BarMenuLeft();
69 1 }
70 void DispMenuFuncRight()
71 {
72 1 BarMenuRight();
73 1 }
74
75
76
77
78
79 #ifdef DynamicBar
//------------------------------------------------
#define DataItemSize 8
U8 DataItem[DispMax][DataItemSize]=
{
{"DataX "},
{"DataX "},
{"DataX "},
};
U8 *_CONST_ DataItem_p[]=
{
DataItem[0],
DataItem[1],
DataItem[2]
};
U8 DynamicItem;
U8 MaxDynamicItem = 0;
/*
實現動態數據顯示的最簡單的方式設定一定大小的緩沖,而后填充數據,但這樣把可以顯示的項限制了。這個方法對于維
-護來說是最為簡單的
2006/08/27
如何利用有限緩沖來實現動態數據的條項層顯示?
比如僅僅緩沖液晶可以顯示的條項數目,然后發現上/下越界了,就刷新緩沖?
但這樣就要重新另外寫類似BarMenuLeft等函數來維護顯示
*/
/*
這里使用一個僅僅跟LCD顯示條項數目一致的緩沖區來緩沖動態生成的條項
當實際條項數目MaxDynamicItem<=DispMax時 函數BarMenuLeft BarMenuRight工作正常
而當MaxDynamicItem>DispMax時,我們設ItemNum = DispMax,在原本的代碼中,這意味著LCD剛剛能顯示所有的項
于是一旦到了頂部上翻時就反顯底部,到了底部下翻時就反顯頂部 但是事實上的項的數目不是ItemNum!而是MaxDynamicI
-tem
C51 COMPILER V7.20 MENUFUNC 09/04/2007 23:38:43 PAGE 3
我們期望的行為是頂部上翻時,修改底部的項為新的項的數據,屏幕整個刷新(底部下翻類似)
做法是設ItemNum = DispMax 并讓上下翻的行為跟 ItemNum > DispMax時的行為一致,跟蹤位置動態修改顯示內容
*/
void DispMenuDataInit(void)
{
U8 Menu_j; //計數變量
U8 *ChangeDispItem; //項顯示內容指針
//----------------------
GUI_Clear();
//--------------------
GUI_Delay(100);
// do{
// MaxDynamicItem = InputNum(4,4,9);//要求輸入一個動態菜單的值,我們根據這個值生成菜單
MaxDynamicItem = 8;
// if(MaxDynamicItem == 0xFF){//退出
// Jump2Menu(SelfMenuIndex,FlashMode_AutoInit);
// // ReFlash = true;
// return;
// }
// }while(MaxDynamicItem ==0x00);//大于0才有效
// GUI_Clear();
DynamicItem = 0;
if(MaxDynamicItem >DispMax){//需要顯示的項數比液晶可以顯示的多
ItemNum = DispMax;
//08/29
BarDataMode = DynamicData;//通知BarMenuLeft和BarMenuRight函數現在的數據是動態數據
//當ItemNum == DispMax時,默認的顯示方式是到頭了直接跳到尾部的(到尾部了直接跳到頭部的)
//但是既然這是動態內容的話,而且實際上的項是MaxDynamicItem不少于DispMax,應當翻滾顯示的,通過修正B
-arDataMode這個標志
//通知BarMenuLeft和BarMenuRight
} else {
ItemNum = MaxDynamicItem;
}
for(Menu_j = 0;Menu_j < ItemNum; Menu_j++){//初始化動態內容
ChangeDispItem = (U8 *)&DataItem[Menu_j];
*(ChangeDispItem + 4) = Menu_j+'0';
// *(DataItem_p[Menu_j]+4) = Menu_j+'0';
}
DispItem = (U8 **)DataItem_p;
//顯示按鍵對應的文字提示,2-->"OK"
GUI_DispStringAtBar(*(Tip[language].Text+1),0,Enter_PosY,126,GUI_TA_HCENTER);
BarMenuInit();
Bar(DynamicItem,MaxDynamicItem,MenuBarPosX,MenuBarNumPosX); //維護滾動條
}
void DispMenuDataUp()
{
//沒有動作,停留在本層菜單
Jump2Menu(SelfMenuIndex,FlashMode_NoAction);
}
void DispMenuDataDown()
{
//08/29
BarDataMode = FixedData;
C51 COMPILER V7.20 MENUFUNC 09/04/2007 23:38:43 PAGE 4
POP();
}
void DispMenuDataLeft()
{
U8 *ChangeDispItem; //項顯示內容指針
U8 ItemBackup;
if(DynamicItem == 0){//
DynamicItem = MaxDynamicItem-1;
} else {
DynamicItem--;
}
if(Where == 0){//頂部上移,需要修改數據
if (Item == 0) {//獲得Item
ItemBackup = ItemNum-1;
} else {
ItemBackup = Item-1;
}
ChangeDispItem = (U8*)&DataItem[ItemBackup];
*(ChangeDispItem + 4) = DynamicItem+'0';
}
BarMenuLeft();//
Bar(DynamicItem,MaxDynamicItem,MenuBarPosX,MenuBarNumPosX); //維護滾動條
}
void DispMenuDataRight()
{
U8 *ChangeDispItem; //項顯示內容指針
U8 ItemBackup;
if(DynamicItem == MaxDynamicItem-1){//維護實際的Item值
DynamicItem = 0;
} else {
DynamicItem++;
}
if(Where == (DispMin-1)){//底部下移,需要修改數據
if (Item == (ItemNum-1)) {//獲得Item
ItemBackup = 0;
} else {
ItemBackup = Item + 1;
}
ChangeDispItem = (U8*)&DataItem[ItemBackup];//獲得修改位置
*(ChangeDispItem + 4) = DynamicItem+'0';
}
BarMenuRight();
Bar(DynamicItem,MaxDynamicItem,MenuBarPosX,MenuBarNumPosX); //維護滾動條
}
#endif
225
MODULE INFORMATION: STATIC OVERLAYABLE
CODE SIZE = 155 ----
CONSTANT SIZE = ---- ----
XDATA SIZE = ---- ----
PDATA SIZE = ---- ----
DATA SIZE = ---- ----
IDATA SIZE = ---- ----
BIT SIZE = ---- ----
END OF MODULE INFORMATION.
C51 COMPILATION COMPLETE. 0 WARNING(S), 0 ERROR(S)
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -