仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)
单片机源程序如下:
- #include <reg52.h> //此文件中定义了单片机的一些特殊功能寄存器
- typedef unsigned int u16; //对数据类型进行声明定义
- typedef unsigned char u8;
- long int Num=23456789;
- unsigned char SEG_Num[8]={0,0,0,0,0,0,0,0};
- sbit LSA=P2^2;
- sbit LSB=P2^3;
- sbit LSC=P2^4;
- sbit P30=P3^0;//定义要实现第一位的静态数码管
- u8 code smgduan[17]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,
- 0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};//显示0~F的值
- //子函数
- void Delay1ms();
- void DelayNms(unsigned int n);
- void DigDisplay();
- void main()
- {
- SEG_Num[0]=smgduan[Num/10000000];
- SEG_Num[1]=smgduan[Num/1000000%10];
- SEG_Num[2]=smgduan[Num/100000%10];
- SEG_Num[3]=smgduan[Num/10000%10];
- SEG_Num[4]=smgduan[Num/1000%10];
- SEG_Num[5]=smgduan[Num/100%10];
- SEG_Num[6]=smgduan[Num/10%10];
- SEG_Num[7]=smgduan[Num%10];
- while(1)
- {
- DigDisplay(); //数码管显示函数
- }
- }
- //子函数声明
- void Delay1ms() //@12.000MHz
- {
- unsigned char i, j;
- i = 2;
- j = 239;
- do
- {
- while (--j);
- } while (--i);
- }
- void DelayNms(unsigned int n)
- {
- while(n--)
- Delay1ms();
- }
- /*******************************************************************************
- * 函 数 名 : DigDisplay
- * 函数功能 : 数码管动态扫描函数,循环扫描8个数码管显示
- *******************************************************************************/
- void DigDisplay()
- {
- u8 i;
- for(i=0;i<8;i++)
- {
- switch(i) //位选,选择点亮的数码管,
- {
- case(0):
- LSA=0;LSB=0;LSC=0; break;//显示第0位
- case(1):
- LSA=1;LSB=0;LSC=0; break;//显示第1位
- case(2):
- LSA=0;LSB=1;LSC=0; break;//显示第2位
- case(3):
- LSA=1;LSB=1;LSC=0; break;//显示第3位
- case(4):
- LSA=0;LSB=0;LSC=1; break;//显示第4位
- case(5):
- LSA=1;LSB=0;LSC=1; break;//显示第5位
- case(6):
- LSA=0;LSB=1;LSC=1; break;//显示第6位
- case(7):
- LSA=1;LSB=1;LSC=1; break;//显示第7位
- }
- P0=SEG_Num[i];//发送段码
- DelayNms(1); //间隔一段时间扫描
- P0=0x00;//消隐
- P3=0x06;//通过静态数码管显示学号第一个个数
- }
- }
复制代码 全部资料51hei下载地址:
静态显示学号.zip
(83.24 KB, 下载次数: 16)
|