|
根據郭師傅的視頻一步步走下來的,最終代碼如下,郭師傅在視頻中用實驗板能實現此功能,但我用proteus仿真仿不出來,在線求助。再就是仿真出現圖二是什么原因。
單片機源程序如下:
- //實現的功能:第一位亮一,過一秒種后第二位亮二,再過一秒后第三位亮三,然后依次類推
- #include<reg52.h>
- #include<intrins.h> //流水燈的循環移動
- #define uint unsigned int
- #define uchar unsigned char
- uchar temp,aa,numdu,numwe;
- 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 code tablewe[]={ //位的table
- 0xfe,0xfd,0xfb,
- 0xf7,0xef,0xdf};
- //{0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};
- //void delay(uint z); //使用定時器延時
- void main()
- {
- numdu=0;
- numwe=0;
- aa=0;
- TMOD=1;//0x01;確定T0T1的工作方式
- TH0=(65536-50000)/256;//50毫秒產生一次中斷
- TL0=(65536-50000)%256;
- EA=1;//開總中斷
- ET0=1;//開定時器0中斷
- TR0=1;//啟動定時器
- /*定時/計數器初始化程序應完成如下工作:
- //對TMOD賦值,以確定T0和T1的工作方式。
- //計算初值,并將其寫入TH0、TL0或TH1、TL1.
- //中斷方式時,則對IE賦值,開放中斷。
- //使TR0或TR1置位,啟動定時/計數器定時或計數*/
- while(1)
- {
- // delay(1000);//延時1000毫秒
- // temp=_crol_(temp,1);
- // P1=temp;
- if(aa==10)//200毫秒
- {
- aa=0;
- numdu++;
- if(numdu==7)
- numdu=1;
- dula=1;
- P0=table[numdu];
- dula=0;
- wela=1;
- P0=tablewe[numwe];
- wela=0;
- numwe++;
- if(numwe==6)
- numwe=0;
- }
- }
- }
- //void delay(uint z)
- //{
- // uint x,y;
- // for(x=z;x>0;x--)
- // for(y=110;y>0;y--);
- //}
- void timer0() interrupt 1
- /*51單片機中using使用在C51編程中,
- 用來在中斷函數中指定工作寄存器區,
- 工作寄存器共有4個區,分別代表R0~R7地址是:
- 第0工作區:00H~07H
- 第1工作區:08H~0FH
- 第2工作區:10H~17H
- 第3工作區:18H~1FH
- using n,那么n就是第幾區,使用方法如下:
- void exterint0() interrupt 0 using 1
- 這表示外部中斷0使用第1工作區地址。*/
- {
- TH0=(65536-50000)/256;//5毫秒產生一次中斷
- TL0=(65536-50000)%256;
- aa++;
- // if(aa==40)//2秒
- // {
- // aa=0;
- // num++;//num不需初始化,默認為0
- // if(num==16)
- // num=0;
- // dula=1;
- // P0=table[num];
- // dula=0;
- // }
- }
復制代碼
|
|