標題: 萌新51單片機程序調試求助!涉及矩陣鍵盤方面 [打印本頁]
作者: 啊_奶瓶 時間: 2020-12-29 22:27
標題: 萌新51單片機程序調試求助!涉及矩陣鍵盤方面
剛剛寫代碼的時候發現我寫的代碼有問題。
我寫了兩篇代碼,分別關于用數碼管做計時器從1至1000和用矩陣鍵盤在數碼管顯示1到F的。
要求如下
51hei.png (26.82 KB, 下載次數: 53)
下載附件
2020-12-29 23:51 上傳
下面是我寫的代碼,我發現主函數那段,定時器的代碼和矩陣按鍵的代碼不能同時運行(按鍵在數碼管顯示的數字只有在按鍵按下時才顯示,松手不顯示,不滿足要求),但是當我把他們兩個代碼分別運行的時候,所得到的現象是滿足預期的,為什么當我把這兩個代碼合在一起時不能滿足預期?是哪個地方錯了,求大佬們告訴我
作者: 啊_奶瓶 時間: 2020-12-29 22:27
這是代碼在附件里這是要求
原理圖也在附件里了
麻煩大佬們看看我的錯誤在哪
謝謝了
#include "reg52.h"
#define uchar unsigned char
#define uint unsigned int
sbit dula=P2^6;
sbit wela=P2^7;
char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
uint num;
void delayms(uint);
int apple,pear,a;
void knowledge(int,int,int);
uchar num1,ge,shi,bai,qian;
void display(uchar,uchar,uchar,uchar);
void display(uchar ge,uchar shi,ucharbai,uchar qian) //計時器部分
{
dula=1;
P0=table[qian];
dula=0;
P0=0xff;
wela=1;
P0=0XFE;
wela=0;
delayms(5);
dula=1;
P0=table[bai];
dula=0;
P0=0XFd;
wela=1;
P0=0XFd;
wela=0;
delayms(5);
dula=1;
P0=table[shi];
dula=0;
P0=0xff;
wela=1;
P0=0XFb;
wela=0;
delayms(5);
dula=1;
P0=table[ge];
dula=0;
P0=0xff;
wela=1;
P0=0XF7;
wela=0;
delayms(5);
}
void delayms(uint times)
{
uinti,j;
for(i=0;i<60;i++)
for(j=0;j>times;j++);
}
void T1_time() interrupt 1
{
TH0=(65536-18432)/256;
TL0=(65536-18432)%256;
num1++;
if(num1==50)
{
num1=0;
num++;
if(num ==1000)
TR0=0;
qian= num/1000%10;
bai=num/100%10;
shi= num/10%10;
ge=num%10;
}
}
void knowledge(int apple,pear,a) //矩陣按鍵部分
{
P3= 0xf0;
apple = P3&0xf0;
if(apple!=0xf0)
{
P3 = 0xf0;
apple = P3&0xf0;
delayms(10);
if(apple!=0xf0)
{
P3= 0xf0;
apple = P3&0xf0;
switch(apple)
{
case(0xe0):pear ==0;break;
case(0xd0):pear= 1;break;
case(0xb0):pear= 2;break;
case(0x70):pear= 3;break;
}
P3 = 0x0f;
apple =P3;
switch(apple)
{
case(0x0e):pear =pear;break;
case(0x0d):pear=pear+4;break;
case(0x0b):pear=pear+8;break;
case(0x07):pear=pear+12;break;
}
delayms(50);
dula=1;
P0=table[pear];
dula=0;
P0=0xff;
wela=1;
P0=0X7f;
wela=0;
delayms(5);
P0=0xff;
}
}
}
void main()
{
TMOD=0X01;
ET0=1;
TR0=1;
TH0=(65536-18432)/256;
TL0=(65536-18432)%256;
EA=1;
dula= 0;
while(1)
{
knowledge(apple,pear,a);
display(ge,shi, bai, qian);
}
}
...
-
-
BST-V51原理圖 v3.0.pdf
2020-12-29 22:34 上傳
點擊文件名下載附件
70.84 KB, 下載次數: 7
作者: cheney03 時間: 2020-12-30 21:35
因為你定時器中斷打開后,時間還沒到就進入while(1)循環了。在中斷服務函數中加個標志位flag=1,然后在while(1)循環中對標志位加以判斷并清0,響應中斷。
作者: wulin 時間: 2020-12-31 06:47
樓主顯示方式不當,給你改為有鍵操作顯示鍵值,無鍵操作2秒自動恢復顯示時間。
- #include "reg52.h"
- #define uchar unsigned char
- #define uint unsigned int
- sbit dula=P2^6;
- sbit wela=P2^7;
- uchar code table[]={
- 0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
- 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};
- uchar num;//中斷計數變量
- uchar sec,min;//秒、分變量
- uint count;//計數變量
- uchar keyValue;//鍵值變量
- void delayms(uint);//延時
- void keyscan();//按鍵掃描
- void display();//數碼管顯示
- void display() //數碼管動態顯示
- {
- static uchar i=0;//動態掃描計數變量
- uchar buf[4];//顯示內容緩存數組
- if(count==0)
- {
- buf[0]=table[min/10];//顯示十分
- buf[1]=table[min%10]|0x80;//顯示分加小數點
- buf[2]=table[sec/10];//顯示十秒
- buf[3]=table[sec%10];//顯示秒
- }
- else
- {
- buf[0]=0;//不顯示
- buf[1]=0;//不顯示
- buf[2]=0;//不顯示
- buf[3]=table[keyValue];//顯示鍵值
- }
- P0=0x00;//消隱
- dula=1;//鎖存
- dula=0;
- P0=~(0x01<<i);//送位碼
- wela=1;//鎖存
- wela=0;
- P0=buf[i];//送段碼
- dula=1;//鎖存
- dula=0;
- i++;
- i%=4;
- }
- void delayms(uint times)
- {
- uint i,j;
- for(i=0;i<60;i++)
- for(j=0;j>times;j++);
- }
- void keyscan() //矩陣按鍵部分
- {
- static bit time=0;
- P3=0xf0;
- if(P3!=0xf0)
- {
- delayms(10);
- if(P3!=0xf0&&time==0)
- {
- time=1;
- count=250;//預置5秒切換
- switch(P3)
- {
- case(0xe0):keyValue=0;break;
- case(0xd0):keyValue=1;break;
- case(0xb0):keyValue=2;break;
- case(0x70):keyValue=3;break;
- }
- P3=0x0f;
- switch(P3)
- {
- case(0x0e):keyValue=keyValue;break;
- case(0x0d):keyValue=keyValue+4;break;
- case(0x0b):keyValue=keyValue+8;break;
- case(0x07):keyValue=keyValue+12;break;
- }
- }
- }
- else time=0;
- }
- void main()
- {
- TMOD=0X01;
- TH0=(65536-18432)/256;//20ms
- TL0=(65536-18432)%256;
- TR0=1;
- ET0=1;
- EA=1;
- while(1)
- {
- keyscan();
- display();
- }
- }
-
- void T1_time() interrupt 1
- {
- TH0=(65536-18432)/256;
- TL0=(65536-18432)%256;
- num++;
- if(num>=50)//秒
- {
- num=0;
- sec++;
- if(sec>=60)
- {
- sec=0;
- min++;
- if(min>=60)
- min=0;
- }
- }
- if(count>0)
- count--;
- }
復制代碼
作者: 人人學會單片機 時間: 2020-12-31 10:40
#include "all.h"
u8 xdata Key4x4_Read_Byte=3;//矩陣結果輸出變量
u8 code Key4x4_Buffer[4]={0xfe,0xfd,0xfb,0xf7};
void Key4x4_Scan_Drive()
{
static xdata u16 count=0;
u8 i,j,Value;
count++;
if(count>1000)
{
count=0;
IE2&=~0x08;
for(i=0;i<4;i++)
{
P0=Key4x4_Buffer[i];
Value=0x80;
for(j=0;j<4;j++)
{
if((P0&Value)==0)
{
Key4x4_Read_Byte=j*4+i+1;
}
Value>>=1;
}
}
P0=0xff;
IE2|=0x08;
}
}
主函數 高速調用上面的函數 就行。主函數必須高速循環。不能有while(key)的這種 死等。
作者: 啊_奶瓶 時間: 2021-1-1 00:14
謝謝你
作者: 啊_奶瓶 時間: 2021-1-1 00:15
好的,謝謝你
作者: 啊_奶瓶 時間: 2021-1-1 00:16
好的,謝謝你
| 歡迎光臨 (http://m.raoushi.com/bbs/) |
Powered by Discuz! X3.1 |