资源描述:
《数码管动态显示实验报告.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、实验四数码管动态显示实验一一、实验要求1.在Proteus软件中画好51单片机最小核心电路,包括复位电路和晶振电路2.在电路中增加四个7段数码管(共阳/共阴自选),将P1口作数据输出口与7段数码管数据引脚相连,P2.0~P2.3引脚输出选控制信号3.在Keil软件中编写程序,采用动态显示法,实现数码管分别显示数字1,2,3,4二、实验目的1.巩固Proteus软件和Keil软件的使用方法2.学习端口输入输出的高级应用3.掌握7段数码管的连接方式和动态显示法4.掌握查表程序和延时等子程序的设计三.实验说明本实验是将单片机的P1口做为
2、输出口,将四个数码管的七段引脚分别接到P1.0至P1.7。由于电路中采用共阳极的数码管,所以当P1端口相应的引脚为0时,对应的数码管段点亮。程序中预设了数字0-9的段码。由于是让四个数码管显示不同的数值,所以要用扫描的方式来实现。因此定义了scan函数,接到单片机的p2.0至p2.3在实验中,预设的数字段码表存放在数组TAB中,由于段码表是固定的,因此存储类型可设为code。在Proteus软件中按照要求画出电路,再利用Keil软件按需要实现的功能编写c程序,生成Hex文件,把Hex文件导到Proteus软件中进行仿真。为了能够更
3、好的验证实验要求,在编写程序时需要延时0.5s,能让人眼更好的分辨;89C51的一个机器周期包含12个时钟脉冲,而我们采用的是12MHz晶振,每一个时钟脉冲的时间是1/12us,所以一个机器周期为1us。在keil程序中,子函数的实现是用voiddelay_ms(intx),其中x为1时是代表1ms。四、硬件原理图及程序设计(一)硬件原理图设计电路中P1.0到P1.7为数码管七段端口的控制口,排阻RP1阻值为220Ω,p2.0到p2.3为数码管的扫描信号。AT89c51单片机的9脚(RST)为复位引脚,当RST为高电平的时间达到2
4、个机器周期时系统就会被复位;31引脚(EA)为存取外部存储器使能引脚,当EA为高电平是使用单片机内部存储器,当EA为低电平时单片机则使用外部存储器。18、19引脚是接晶振脚。而接地和电源端在软件中已经接好,所以不用在引线。如下图所示:精选范本,供参考!(二)流程图与程序设计开始声明驱动信号数组声明延时函数扫描数组的值显示数值读取数组数据及数据处理精选范本,供参考!(三)程序设源代码#include//定义8051寄存器头文件#defineSEG7PP1//定义扫描信号的位置#defineSCANPP2//定义数码
5、管的位置charcodeTAB[10]={0xc0,0xf9,0xa4,0xb0,0x99,//数字0~4的码值0x92,0x83,0xf8,0x80,0x98};//数字5~9的码值chardisp[4]={1,2,3,4};//定义要显示的数值voiddelay_ms(intx);//声明延时函数charscan[4]={0xfe,0xfd,0xfb,0xf7};//定义扫描chari,j;//定义变量i,jmain()//主函数的开始{while(1)//无限循环{for(i=0;i<4;i++)//从{j=disp[3-i
6、];//取出显示的数值SCANP=scan[i];//扫描的顺序SEG7P=TAB[j];//将TAB的数值赋给数码管delay_ms(4);//延时4ms}}}voiddelay_ms(intx){inti,j;for(i=0;i7、运行电路,电路正常显示,符合要求。通过本次的实验,在前两个实验的基础上让我复习了知识点,也让我在次掌握了新的知识。在完成这次实验后,让我想到可以用多个按键控制多个数码管实现加减和暂停和开始。我觉得这次的课程实验让我知道,一次次的失败,并不会让我放弃去追求,相反它会引领着我去发现问题,从而解决问题,完成更深入的探索。也让我明白理论知识的重要性,并且与实际相结合,多动手,在实践中成长。所以我会很重视每一次的实验。我坚信:每次实验都会给我自身很大帮助。慢慢的积累点滴的知识,到最后就会多的。【本文档内容可以自由复制内容或自由编辑修改内容精
8、选范本,供参考!期待你的好评和关注,我们将会做得更好】精选范本,供参考!