




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、精选优质文档-倾情为你奉上专业方向课程设计课程设计报告题目: 心形花样流水灯与点阵显示 专业: 电子信息工程 班级: 二 班 学号: 姓名: 指导老师: 重庆交通大学信息科学与工程学院设计时间:2013年 9 月 8 日 到 2013 年 11 月 16 号一、 设计任务说明随着社会的发展,单片机得到了广泛的应用,人们越来越重视单片机的应用。比如温度是和每个人息息相关的,并且在有的生产车间里还要进行温度时时测量,甚至是对温度的进一步调控等,这些都是单片机的应用之例。本设计是用单片机和点阵加一个小的流水灯电路, 这次作品的初衷是希望通过单片机学习,做个生日礼物送给朋友。二、 总体设计本系统主要有
2、AT89C51单片机、5mm彩色LED灯、74HC245、8*8LED点阵、200欧电阻等元件组成。1.流水灯设计:(1)AT89C51单片机:AT89C51具有如下特点:40个引脚,8k Bytes Flash片内程序存储器,256 bytes的随机存取数据存储器(RAM),32个外部双向输入/输出(I/O)口,5个中断优先级2层中断嵌套中断,2个16位可编程定时计数器,2个全双工串行通信口,看门狗(WDT) AT89C51引脚图电路,片内时钟振荡器。此外,AT89S52设计和配置了振荡频率可为0Hz并可通过软件设置省电模式。空闲模式下,CPU暂停工作,而RAM定时计数器,串行口,外中断 系
3、统可继续工作,掉电模式冻结振荡器而保存RAM的数据,停止芯片其它功能直至外中断激活或硬件复位。引脚图如右图所示。此次设计把51单片机的4个I/O口与32个5mm高亮LED灯相接,通过单片机控制各I/O引脚的高低电平控制LED的亮灭从而形成各种不同亮灭的花样。2.点阵显示设计:(1)8*8点阵原理图 :从图中可以看出,8X8点阵共需要64个发光二极管组成,且每个发光二极管是放置在行线和列线的交叉点上,当对应的某一列置1电平,某一行置0电平,则相应的二极管就亮;因此要实现一根柱形的亮法,如图所示,对应的一列为一根竖柱,或者对应的一行为一根横柱,因此实现柱的亮的方法如下所述:一根竖柱:对应的列置1,
4、而行则采用扫描的方法来实现。一根横柱:对应的行置0,而列则采用扫描的方法来实现。 (2)74HC245:74HC245是一种三态输出、八路信号收发器,主要应用于大屏显示,以及其它的消费类电子产品中增加驱动 主要特性:采用CMOS工艺宽电压工作范围:3.0V5.0V双向三态输出八线双向收发器封装形式:SOP20、SOP20-2、TSSOP20、DIP20此次设计采用74HC245来驱动8*8点阵,74HC245一端与51单片机的P0口想连,另一端则与点阵的输入端相连,从而通过单片机控制驱动点阵。三、 硬件设计心型流水灯的硬件设计如下图:此次设计把51单片机的4个I/O口与32个5mm高亮LED灯
5、相接,通过单片机控制各I/O引脚的高低电平控制LED的亮灭从而形成各种不同亮灭的花样。点阵显示的硬件设计图如下:本次设计通过74HC245来驱动8*8点阵,74HC245的输入端与51单片机的P0口想连,74HC245的输出端则与点阵的行相连,而点阵的列则与单片机的P3口相连,通过单片机控制、74HC245驱动,从而完成了点阵的显示。四、 软件设计心形花样流水灯的程序如下:#include<reg52.h>#include <intrins.h>#defineuint unsigned int#defineuchar unsigned charuchar code ta
6、ble=0xfe,0xfc,0xf8,0xf0,0xe0,0xc0,0x80,0x00; / 逐个点亮07uchar code table1=0x7f,0x3f,0x1f,0x0f,0x07,0x03,0x01,0x00; / 逐个点亮70uchar code table2=0x01,0x03,0x07,0x0f,0x1f,0x3f,0x7f,0xff; / 逐个灭07uchar code table3=0x80,0xc0,0xe0,0xf0,0xf8,0xfc,0xfe,0xff; / 逐个灭70/*/void delay(uint t);/延时void zg(uint t,uchar a)
7、;/两边逐个亮void qs(uint t,uchar a);/全部闪烁void zgxh(uint t,uchar a); / 逆时针逐个点亮void djs(uint t,uchar a); /对角闪void lbzgm(uint t,uchar a);/两边逐个灭void nszgm(uint t,uchar a); / 逆时针逐个灭void sztl(uint t,uchar a);/顺时逐个同步亮void nztl(uint t,uchar a);/逆时逐个同步亮void sztm(uint t,uchar a);/顺时逐个同步灭void nztm(uint t,uchar a);/
8、逆时逐个同步灭void hwzjl(uint t,uchar a); /横往中间亮void hwzjm(uint t,uchar a); /横往中间灭void nzdl(uint t,uchar a); /逆时逐段亮void nzdgl(uint t,uchar a); /逆时逐段一个点亮void jgs(uint t,uchar a); /间隔闪/*/void zg(uint t,uchar a)/两边逐个亮uchar i,j; for(j=0;j<a;j+) P0=P1=P2=P3=0xff; P0=0x7f;delay(t); for(i=0;i<7;i+) P0=table
9、1i+1; P2=table1i; delay(t); P2=0x00;P1=0xfe; delay(t); for(i=0;i<7;i+) P1=tablei+1;P3=table1i;delay(t); P3=0x00;delay(t); void qs(uint t,uchar a) /全部闪烁uchar j;for(j=0;j<a;j+) P0=P1=P2=P3=0xff; delay(t); P0=P1=P2=P3=0x00; delay(t); void zgxh(uint t,uchar a) / 逆时针逐个点亮uchar i,j;for (j=0;j<a;j+
10、)P0=P1=P2=P3=0xff;for (i=0;i<8;i+)P0=table1i;delay(t);for(i=0;i<8;i+)P1=tablei;delay(t);for(i=0;i<8;i+)P3=tablei;delay(t);for(i=0;i<8;i+)P2=tablei;delay(t);void nszgm(uint t,uchar a) / 逆时针逐个灭uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0x00;for (i=0;i<8;i+)P0=table3i;delay(t);for (i=0;i<
11、;8;i+)P1=table2i;delay(t);for (i=0;i<8;i+)P3=table2i;delay(t);for (i=0;i<8;i+)P2=table2i;delay(t);void djs(uint t,uchar a) /对角闪uchar j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;P0=P3=0x00;delay(t);P0=P1=P2=P3=0xff;P1=P2=0x00;delay(t);void lbzgm(uint t,uchar a)/两边逐个灭 uchar i,j; for (j=0;j<a;j+) P0=
12、P2=0x00;P3=0x01;delay(t);for(i=7;i>1;i-)P1=tablei-1;P3=table1i-2;delay(t);P1=0xfe;P3=0xff;delay(t);P1=0xff;P2=0x01;delay(t);for(i=7;i>1;i-)P0=table1i-1;P2=table1i-2;delay(t);P0=0x7f;P2=0xff;delay(t);P0=0xff;delay(t); void sztl(uint t,uchar a)/顺时逐个同步亮uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff
13、;for(i=0;i<8;i+)P0=tablei;P1=P2=P3=table1i;delay(t);void nztl(uint t,uchar a)/逆时逐个同步亮uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=table1i;P1=P2=P3=tablei;delay(t);void sztm(uint t,uchar a)/顺时逐个同步灭uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0x00;for(i=0;i<8;i+)P0=table2i;P1=P2=
14、P3=table3i;delay(t);void nztm(uint t,uchar a)/逆时逐个同步灭uchar i,j;for(j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=table3i;P1=P2=P3=table2i;delay(t);void hwzjl(uint t,uchar a) /横往中间亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=P2=P1=table1i;P3=tablei;delay(t);void hwzjm(uin
15、t t,uchar a) /横往中间灭uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0x00;for(i=0;i<8;i+)P0=P2=P1=table3i;P3=table2i;delay(t);void nzdl(uint t,uchar a) /逆时逐段亮uchar i,j;for (j=0;j<a;j+)P0=P1=P2=P3=0xff;for(i=0;i<8;i+)P0=table1i;delay(t);P0=0xff;for(i=0;i<8;i+)P1=tablei;delay(t);P1=0xff;for(i=0;i&l
16、t;8;i+)P3=tablei;delay(t);P3=0xff;for(i=0;i<8;i+)P2=tablei;delay(t);P2=0xff;void nzdgl(uint t,uchar a) /逆时逐段一个点亮uchar i,j,k,l;for (j=0;j<a;j+)k=table10;P0=k;l=table0;P1=P2=P3=l;delay(t);for(i=0;i<8;i+)k=_crol_(k,-1);P0=k;l=_crol_(l,1);P1=P2=P3=l;delay(t);void jgs(uint t,uchar a) /间隔闪uchar j
17、;for (j=0;j<a;j+)P0=0x55;P1=P2=P3=0xaa;delay(t);P0=0xaa;P1=P2=P3=0x55;delay(t);void main()uchar i;while(1) zg(100,1); /两边逐个亮 lbzgm(100,1); /两边逐个灭 jgs(300,10); djs(100,20); /对角闪/P1=P2=P3=0xff;for(i=0;i<3;i+) P0=0x00;delay(800); P0=0xff;delay(800); P0=0x00; for(i=0;i<3;i+) P1=0x00;delay(800);
18、 P1=0xff;delay(800); P1=0x00; for(i=0;i<3;i+) P3=0x00;delay(800); P3=0xff;delay(800); P3=0x00; for(i=0;i<3;i+) P2=0x00;delay(800); P2=0xff;delay(800); qs(500,3);/for(i=0;i<6;i+) zgxh(50,1); nszgm(50,1); djs(100,20); /对角闪for(i=0;i<3;i+) zg(100,1); /两边逐个亮 lbzgm(100,1); /两边逐个灭 qs(200,10);dj
19、s(100,50); for(i=0;i<5;i+) sztl(200,1); /顺时逐个同步亮nztm(200,1); nztl(200,1);sztm(200,1); /顺时逐个同步灭 djs(300,10); /对角闪 nzdgl(300,10); /逆时逐段一个点亮 jgs(300,10); /间隔闪for(i=0;i<3;i+) zgxh(100,1); nszgm(100,1); nzdl(200,3); /逆时逐段亮 jgs(50,100); /间隔闪/nzdgl(50,40); /逆时逐段一个点亮for(i=0;i<4;i+) zg(100,1);qs(100
20、,10); lbzgm(100,1); for(i=0;i<3;i+) zgxh(100,1); nszgm(100,1); djs(1000,10); for(i=0;i<10;i+) hwzjl(200,1); /横往中间亮hwzjm(200,1); /横往中间灭 djs(300,10); /对角闪for(i=0;i<5;i+) zgxh(100,1); nszgm(100,1); djs(100,20); /对角闪 zg(300,1); lbzgm(300,1); for(i=0;i<5;i+) sztl(200,1); /顺时逐个同步亮nztm(200,1);
21、nztl(200,1);sztm(200,1); /顺时逐个同步灭 djs(500,20); /对角闪 djs(100,30); /对角闪 djs(50,50); /对角闪 delay(1000);void delay(uint t) uint x,y;for (x=t;x>0;x-)for (y=120;y>0;y-);点阵显示的程序如下:RS_CNTEQU30HNUMEQU31HTCON_TEQU32HORG00HLJMPSTARTORG0BHLJMPINT_T0START:MOVRS_CNT,#00HMOV NUM,#00HMOVTCON_T,#00HMOVTMOD,#01H
22、MOVTH0,#(65536-5000)/256MOVTL0,#(65536-5000)MOD 256MOVIE,#82HSETBTR0SJMP$INT_T0:MOVTH0,#(65536-5000)/256MOVTL0,#(65536-5000)MOD 256MOV DPTR,#TABLEMOVA,RS_CNTMOVCA,A+DPTRMOVP3,AMOVDPTR,#TABLE1MOVA,NUMMOVB,#8MULABADDA,RS_CNTMOVCA,A+DPTRCPLAMOVP0,AINCRS_CNTMOVA,RS_CNTCJNEA,#8,NEXTMOVRS_CNT,#00H NEXT:INCTCON_T MOVA,TCON_TCJNEA,#200,RETUNEMOVTCON_T,#00HINCNUMMOVA,NUMCJNEA,#7,RETUNEMOVNUM,#00HRETUNE:R
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 掀起复习热潮2024年陪诊师考试试题及答案
- 14普罗米修斯(教学设计)-2024-2025学年语文四年级上册统编版
- 通过故事分享提升道德认知计划
- 如何有效地进行预算控制计划
- 总结中发现机会与挑战的管理思路计划
- 促进社区经济循环的策略计划
- 全面了解宠物殡葬师考试试题及答案
- 深度解读监理工程师考试试题及答案
- 优化教师资格证复习试题及答案
- 夏季防蛇安全
- 《清华大学介绍》课件
- 重症专科护士考试题库(含答案)
- 《作文吹泡泡》-完整版课件
- 电化学储能保险发展报告
- 不合格产品统计表
- 《外科学》第七节 直肠癌
- DG-TJ 08-2002-2020 悬挑式脚手架安全技术标准 高质量清晰版
- Z世代消费态度洞察报告
- 办公楼办公室改档案室结构加固施工方案(15页)
- (完整版)二十四山年月日时吉凶定局详解,
- 支撑掩护式液压支架总体方案及底座设计
评论
0/150
提交评论