?? gg.lst
字號:
C51 COMPILER V8.02 GG 03/12/2009 14:01:21 PAGE 1
C51 COMPILER V8.02, COMPILATION OF MODULE GG
OBJECT MODULE PLACED IN gg.OBJ
COMPILER INVOKED BY: C:\Keil\C51\BIN\C51.EXE gg.c BROWSE DEBUG OBJECTEXTEND
line level source
1 #include<reg52.h>
2 #define uchar unsigned char
3 #define uint unsigned int
4 sbit LCM_RW=P2^1; //定義引腳
5 sbit LCM_RS=P2^0;
6 sbit LCM_E=P2^2;
7 #define LCM_Data P0
8 #define Busy 0x80 //用于檢測LCM狀態字中的Busy標識
9
10 void WriteDataLCM(unsigned char WDLCM);
11 void WriteCommandLCM(unsigned char WCLCM,BuysC);
12 unsigned char ReadDataLCM(void);
13 unsigned char ReadStatusLCM(void);
14 void LCMInit(void);
15 void DisplayOneChar(unsigned char X, unsigned char Y, unsigned char DData);
16 void DisplayListChar(unsigned char X, unsigned char Y, unsigned char code *DData);
17 void Delay5Ms(void);
18 void Delay400Ms(void);
19
20 unsigned char code cdle_net[] = {"dzcn.mcublog.com"};
21 unsigned char code email[] = {"4@163.com"};
22
23 void main(void)
24 {
25 1 Delay400Ms(); //啟動等待,等LCM講入工作狀態
26 1 LCMInit(); //LCM初始化
27 1 Delay5Ms(); //延時片刻(可不要)
28 1
29 1 DisplayListChar(0, 0, cdle_net);
30 1 DisplayListChar(0, 1, email);
31 1 while(1);
32 1 }
33
34 //寫數據
35 void WriteDataLCM(unsigned char WDLCM)
36 {
37 1 ReadStatusLCM(); //檢測忙
38 1 LCM_Data = WDLCM;
39 1 LCM_RS = 1;
40 1 LCM_RW = 0;
41 1 LCM_E = 0; //若晶振速度太高可以在這后加小的延時
42 1 LCM_E = 0; //延時
43 1 LCM_E = 1;
44 1 }
45
46 //寫指令
47 void WriteCommandLCM(unsigned char WCLCM,BuysC) //BuysC為0時忽略忙檢測
48 {
49 1 if (BuysC) ReadStatusLCM(); //根據需要檢測忙
50 1 LCM_Data = WCLCM;
51 1 LCM_RS = 0;
52 1 LCM_RW = 0;
53 1 LCM_E = 0;
54 1 LCM_E = 0;
55 1 LCM_E = 1;
C51 COMPILER V8.02 GG 03/12/2009 14:01:21 PAGE 2
56 1 }
57
58 //讀數據
59 unsigned char ReadDataLCM(void)
60 {
61 1 LCM_RS = 1;
62 1 LCM_RW = 1;
63 1 LCM_E = 0;
64 1 LCM_E = 0;
65 1 LCM_E = 1;
66 1 return(LCM_Data);
67 1 }
68
69 //讀狀態
70 unsigned char ReadStatusLCM(void)
71 {
72 1 LCM_Data = 0xFF;
73 1 LCM_RS=0;
74 1 LCM_RW = 1;
75 1 LCM_E = 0;
76 1 LCM_E = 0;
77 1 LCM_E = 1;
78 1 while (LCM_Data & Busy); //檢測忙信號
79 1 return(LCM_Data);
80 1 }
81
82 void LCMInit(void) //LCM初始化
83 {
84 1 LCM_Data = 0;
85 1 WriteCommandLCM(0x38,0); //三次顯示模式設置,不檢測忙信號
86 1 Delay5Ms();
87 1 WriteCommandLCM(0x38,0);
88 1 Delay5Ms();
89 1 WriteCommandLCM(0x38,0);
90 1 Delay5Ms();
91 1
92 1 WriteCommandLCM(0x38,1); //顯示模式設置,開始要求每次檢測忙信號
93 1 WriteCommandLCM(0x08,1); //關閉顯示
94 1 WriteCommandLCM(0x01,1); //顯示清屏
95 1 WriteCommandLCM(0x06,1); // 顯示光標移動設置
96 1 WriteCommandLCM(0x0C,1); // 顯示開及光標設置
97 1 }
98
99 //按指定位置顯示一個字符
100 void DisplayOneChar(unsigned char X, unsigned char Y, unsigned char DData)
101 {
102 1 Y &= 0x1;
103 1 X &= 0xF; //限制X不能大于15,Y不能大于1
104 1 if (Y) X |= 0x40; //當要顯示第二行時地址碼+0x40;
105 1 X |= 0x80; //算出指令碼
106 1 WriteCommandLCM(X, 0); //這里不檢測忙信號,發送地址碼
107 1 WriteDataLCM(DData);
108 1 }
109
110 //按指定位置顯示一串字符
111 void DisplayListChar(unsigned char X, unsigned char Y, unsigned char code *DData)
112 {
113 1 unsigned char ListLength;
114 1
115 1 ListLength = 0;
116 1 Y &= 0x1;
117 1 X &= 0xF; //限制X不能大于15,Y不能大于1
C51 COMPILER V8.02 GG 03/12/2009 14:01:21 PAGE 3
118 1 while (DData[ListLength]>0x20) //若到達字串尾則退出
119 1 {
120 2 if (X <= 0xF) //X坐標應小于0xF
121 2 {
122 3 DisplayOneChar(X, Y, DData[ListLength]); //顯示單個字符
123 3 ListLength++;
124 3 X++;
125 3 }
126 2 }
127 1 }
128
129 //5ms延時
130 void Delay5Ms(void)
131 {
132 1 unsigned int TempCyc = 5552;
133 1 while(TempCyc--);
134 1 }
135
136 //400ms延時
137 void Delay400Ms(void)
138 {
139 1 unsigned char TempCycA = 5;
140 1 unsigned int TempCycB;
141 1 while(TempCycA--)
142 1 {
143 2 TempCycB=7269;
144 2 while(TempCycB--);
145 2 };
146 1 }
147
MODULE INFORMATION: STATIC OVERLAYABLE
CODE SIZE = 309 ----
CONSTANT SIZE = 27 ----
XDATA SIZE = ---- ----
PDATA SIZE = ---- ----
DATA SIZE = ---- 8
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 + -