单片机实验报告1_第1页
单片机实验报告1_第2页
单片机实验报告1_第3页
单片机实验报告1_第4页
单片机实验报告1_第5页
已阅读5页,还剩18页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、单片机实验报告 姓名: 钟林春 班级: 0801205 学号: 2012212963 任课教师: 张开碧 上课地点: s411 实验一 流水灯实验一、实验目的及要求1、闪烁的led;2、从左到右的流水灯;3、8只led左右来回点亮;4、led模拟交通灯。要求1:led按设定的时间间隔闪烁要求2:接在p0口的8个led从左到右循环依次点亮,产生走马灯效果要求3:程序利用循环移位函数_crol_和_cror_形成来回滚动的效果;二、实验原理电路图1、 电路图2、 三、源程序 要求1:#include#define uchar unsigned char#define uint unsigned i

2、ntsbit led=p10;/延时void delayms(uint x)uchar i;while(x-)for(i=0;i120;i+);/主程序void main()while(1)led=led;delayms(150);要求2:#include #include /包含程序中的_cror_(p0,y) #define uchar unsigned char #define uint unsigned intuchar led;void delay(unsigned int i)uint j;uchar k;for(j=i;j0;j-)for(k=125;k0;k-);void ma

3、in()led=0x7f;/只亮第一个delay(1000);while(1)p0=led;delay(500);led=_cror_(led,1); /p0逐步右移一位。要求3:#include #include /包含程序中的_crol_(p0,y) #define uchar unsigned char #define uint unsigned intsbit led=p00;uchar i;void delay(unsigned int i)uint j;uchar k;for(j=i;j0;j-)for(k=125;k0;k-);void main()p0=0xfe;delay(1

4、000);while(1) for(i=0;i8;i+)p0=led;delay(500);led=_crol_(led,1); /p0逐步左移一位。for(i=0;i8;i+)p0=led;delay(500);led=_cror_(led,1); /p0逐步右移一位 实验二 独立键盘实验一、实验目的1、k1-k4 按键状态显示;2、k1-k4 控制led移位;3、单只数码管循环显示09;4、k1-k4 控制数码管移位显示。 要求1:k1、k2按下时led点亮,松开时熄灭,k3、k4按下并释放时led点亮, 再次按下并释放时熄灭; 要求2: 按下k1时,p0口led上移一位; 按下k2时,p

5、0口led下移一位; 按下k3时,p2口led上移一位;按下k4时,p2口led下移一位;要求3:主程序中的循环语句反复将09的段码送至p0口,使数字09循环显示; 要求4:按下k1时加1计数并增加显示位, 按下k2时减1计数并减少显示位,按下k3时清零二、实验原理电路图1、 电路图2、 电路图3、 电路图4、三、源程序要求1:#include#define uchar unsigned char#define uint unsigned intsbit led1=p00;sbit led2=p01;sbit led3=p02;sbit led4=p03;sbit k1=p10;sbitk2=

6、p11;sbit k3=p12;sbit k4=p13;/延时voiddelayms(uint x)uchar i;while(x-) for(i=0;i120;i+);/主程序void main()p0=0xff;p1=0xff;while(1)led1=k1;led2=k2;if(k3=0)while(k3=0);led3=led3;if(k4=0)while(k4=0);led4=led4;delayms(10);要求2:#include#define uchar unsigned char#define uint unsigned intuchar led1;uchar led2;sb

7、it k1=p10;sbitk2=p11;sbit k3=p12;sbit k4=p13;/延时voiddelayms(uint x)uchar i;while(x-) for(i=0;i120;i+);/主程序void main()led1=0xfe;led2=0xfe;while(1) if(k1=0)while(k1=0);p0=led1;led=_crol_(led1,1); /p0口led上移一位。if(k2=0)while(k2=0);p0=led1;led=_cror_(led1,1); /p0口led下移一位。if(k3=0)while(k3=0);p2=led2;led1=_

8、crol_(led2,1); /p0口led上移一位。if(k4=0)while(k4=0);p2=led2;led2=_cror_(led2,1); /p0口led下移一位。要求3:#include#define uchar unsigned char#define uint unsigned intuchar code display10=0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07,0x7f,0x6f;/延时void delayms(uint x)uchar i;while(x-) for(i=0;i120;i+);/主程序void main()uch

9、ar i;while(1) for(i=0;i10;i+)p0=displayi; delayms(500) i=0;要求4:#include#define uchar unsigned char#define uint unsigned intsbit k1=p10;sbit k2=p11;sbit k3=p12;uchar code display10=0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07,0x7f,0x6f;/延时void delayms(uint x)uchar i;while(x-) for(i=0;i120;i+);/主程序void ma

10、in()int num;uchar i;p2=1;while(1) if(k1=0)while(k1=0); num+; if(num=10) num=0;if(k2=0)while(k2=0); num-; if(num=-1) num=0;if(k3=0)while(k3=0); num=0;p0=displaynum; 实验三 矩阵键盘实验一、实验目的及要求1、4x4矩阵键盘控制条形led显示;2、数码管显示4x4矩阵键盘按键号;要求1:运行本例时,按下的按键值越大点亮的led越多要求2:按下任意键时,数码管都会显示其键的序号,扫描程序首先判断按键发生在哪一列,然后根据所发生的行附加不同

11、的值,从而得到按键的序号二、实验原理电路图1、 电路图2、3、 源程序要求1:#include#include#define uchar unsigned char#define uint unsigned int/矩阵键盘按键特征码表uchar code keycodetable=0x11,0x12,0x14,0x18,0x21,0x22,0x24,0x28,0x41,0x42,0x44,0x48,0x81,0x82,0x84,0x88;/延时voiddelayms(uint x)uchar i;while(x-) for(i=0;i120;i+);/键盘扫描ucharkeys_scan()

12、uchar scode,kcode,i,k;/低4位置0,放入4行p1=0xf0;/若高4位出现0,则有键按下if(p1&0xf0)!=0xf0)delayms(2);if(p1&0xf0)!=0xf0)scode=0xfe;/行扫描码初值for(k=0;k4;k+)/对4行分别进行扫描p1=scode;if(p1&0xf0)!=0xf0)kcode=p1;for(i=0;i16;i+)/查表得到按键序号并返回if(kcode=keycodetablei)return(i);elsescode=_crol_(scode,1); return(-1);/主程序void main()uchar i

13、,p2_led,p3_led;ucharkeyno=-1;/按键序号,-1表示无按键while(1)keyno=keys_scan();/扫描键盘获取按键序号keynoif(keyno!=-1)p2_led=0xff;p3_led=0xff;for(i=0;i=keyno;i+)/键值越大,点亮的led越多if(i=1;elsep2_led=1;p3=p3_led; /点亮条形ledp2=p2_led;要求2:#include#include#define uchar unsigned char#define uint unsigned intunsigned char code table=

14、0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d, 0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71;/0-f的码表void matrixkeyscan() /矩阵键盘p1=0xfe;temp=p1;temp=temp&0xf0;if (temp!=0xf0)delay(10);temp=p1;temp=temp&0xf0;if (temp!=0xf0)temp=p1;switch (temp)case 0xee:key=1,num=0;break;case 0xde:key=2,num=1;break;case 0xbe:key=3

15、,num=2;break;case 0x7e:key=4,num=3;break;while (temp!=0xf0)temp=p1;temp=temp&0xf0;p1=0xfd;temp=p1;temp=temp&0xf0;if (temp!=0xf0)delay(10);temp=p1;temp=temp&0xf0;if (temp!=0xf0)temp=p1;switch (temp)case 0xed:key=5,num=4;break;case 0xdd:key=6,num=5;break;case 0xbd:key=7,num=6;break;case 0x7d:key=8,num

16、=7;break;while (temp!=0xf0)temp=p1;temp=temp&0xf0;p1=0xfb;temp=p1;temp=temp&0xf0;if (temp!=0xf0)delay(10);temp=p1;temp=temp&0xf0;if (temp!=0xf0)temp=p1;switch (temp)case 0xeb:key=9,num=8;break;case 0xdb:key=9,num=9;break;case 0xbb:key=10;break; case 0x7b:key=11;break; while (temp!=0xf0)temp=p1;temp=

17、temp&0xf0;p1=0xf7;temp=p1;temp=temp&0xf0;if (temp!=0xf0)delay(10);temp=p1;temp=temp&0xf0;if (temp!=0xf0)temp=p1;switch (temp)case 0xe7:key=12;break; case 0xd7: key=13;break; case 0xb7:key=14;break; case 0x77:key=15;break; default: break;while (temp!=0xf0)temp=p1;temp=temp&0xf0; void main()while(1)ma

18、trixkeyscan();p0=tablekey; 实验四 外部中断实验一、实验目的及要求1、int0中断计数;2、外部int0中断控制led;3、int0及int1中断计数要求1:每次按下计数键时触发int0中断,中断程序累加计数, 计数值显示在3只数码管上,按下清零键时数码管清零要求2:每次按键都会触发int0中断,中断发生时将led状态取反,产生led状态由按键控制的效果要求3:每次按下第1个计数键时,第1组计数值累加并显示在右边3只数码管上, 每次按下第2个计数键时,第2组计数值累加并显示在左边3只数码管上,后两个按键分别清零。二、实验原理电路图1、 三、源程序要求1:#includ

19、e#define uchar unsigned char#define uint unsigned int/09的段码uchar code dsy_code=0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x00;/计数值分解后各个待显示的数位uchar dsy_buffer=0,0,0;uchar count=0;sbit clear_key=p36;/数码管上显示计数值void show_count_on_dsy()dsy_buffer2=count/100;/获取3个数dsy_buffer1=count%100/10;dsy_buff

20、er0=count%10;if(dsy_buffer2=0) /高位为0时不显示dsy_buffer2=0x0a;if(dsy_buffer1=0) /高位为0,若第二位为0同样不显示dsy_buffer1=0x0a;p0=dsy_codedsy_buffer0;p1=dsy_codedsy_buffer1;p2=dsy_codedsy_buffer2;/主程序void main()p0=0x00;p1=0x00;p2=0x00;ie=0x81;/允许int0中断it0=1;/下降沿触发while(1)if(clear_key=0) count=0;/清0show_count_on_dsy()

21、;/int0中断函数void ex_int0() interrupt 0count+; /计数值递增要求2:#include#define uchar unsigned char#define uint unsigned intsbit led=p00;/主程序void main()ie=0x81;/允许int0中断it0=1;/下降沿触发while(1);/int0中断函数void ex_int0() interrupt 0led=led; /控制led亮灭要求3:#include#define uchar unsigned char#define uint unsigned intunsi

22、gned char code table=0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d, 0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71;int num1,num2;sbit k3=p34;/清零1sbit k4=p35;/清零2 sbit wela1=p20; sbit wela2=p21; sbit wela3=p22; sbit wela4=p23; sbit wela5=p24; sbit wela6=p25; void display(int num2,int num1);void main()ie=0x85;/开ea

23、总中断,允许int1和int0中断,1000 0101it0=1;/下降沿触发it1=1;/下降沿触发while(1)if(k3=0)while(k3=0);num1=0;if(k4=0)while(k4=0);num2=0;display(num2,num1);/int0中断函数void ex_int0() interrupt 0num1+; /右边的数字加1void ex_int0() interrupt 0num2+; / 左边的数字加1void display(int num2,int num1)bai=num1/100;/右边num1百位shi=(num1/10)%10;/右边num

24、1十位ge=num1%10;swan=num2/100;/左边num2百位,数码管十万位wan=(num2/10)%10;qian=num2%10;wela1=1;/打开最高位数码管的位选p1=tableswan;/输入段选数据,即num2的百位数,数码管的十万位wela1=0;/关闭最高位数码管的位选wela2=1;p1=tablewan;wela2=0;wela3=1;p1=tableqian;wela3=0;wela4=1;p1=tablebai;wela4=0;wela5=1;p1=tableshi;wela5=0;wela6=1;p1=tablege;wela6=0; 实验五 定时器

25、中断实验一、实验目的1、定时器控制单只led;2、timer0控制流水灯;3、定时器控制4个led滚动闪烁; 要求1:led在定时器的中断例程控制下不断闪烁; 要求2: 定时器控制p0、p2口的led滚动显示,本例未使用中断函数;要求3:4只led在定时器控制下滚动闪烁; 二、实验原理电路图1、 三、源程序要求1:#include#define uchar unsigned char#define uint unsigned intsbit led=p00;uchar t_count=0;/主程序void main()tmod=0x00; /定时器0工作方式0th0=(8192-5000)/32;/5ms定时tl0=(8192-5000)%32;ie=0x82;/允许t0中断tr0=1;while(1);/t0中断函数void led_flash() interrupt 1th0=(8192-5000)/32;/恢复初值tl0=(8192-5000)%32;if(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论